From 1470cbb0bf6883c03837725aa3a64eb2a31ed4e0 Mon Sep 17 00:00:00 2001 From: Niklas Hauser Date: Thu, 28 Nov 2024 22:05:47 +0100 Subject: [PATCH] [examples] WIP Replace Protothreads with Fibers --- examples/arduino_nano/color/main.cpp | 100 ++--- examples/arduino_nano/color/project.xml | 3 +- examples/avr/block_device_mirror/main.cpp | 8 +- examples/avr/fiber/main.cpp | 101 ++--- examples/avr/fiber/project.xml | 10 +- examples/avr/fiber_benchmark/main.cpp | 94 ++++ examples/avr/fiber_benchmark/project.xml | 12 + examples/avr/protothread/main.cpp | 112 ----- examples/avr/protothread/project.xml | 15 - examples/avr/pwm/pca9685/main.cpp | 8 +- examples/avr/qmc5883l/main.cpp | 6 +- examples/blue_pill_f103/adns_9800/main.cpp | 120 ++---- examples/blue_pill_f103/adns_9800/project.xml | 2 +- examples/blue_pill_f103/environment/main.cpp | 10 +- .../blue_pill_f103/environment/project.xml | 2 +- .../environment/thread_blink.cpp | 26 +- .../environment/thread_blink.hpp | 32 -- .../environment/thread_bme280.cpp | 53 +-- .../environment/thread_bme280.hpp | 9 +- .../environment/thread_bmp180.cpp | 47 +- .../environment/thread_bmp180.hpp | 9 +- .../blue_pill_f103/environment/threads.hpp | 3 +- examples/blue_pill_f103/logger/main.cpp | 51 +-- examples/blue_pill_f103/logger/project.xml | 2 - examples/blue_pill_f103/tlc594x/main.cpp | 2 +- .../weight_scale_hx711/main.cpp | 64 +-- .../weight_scale_hx711/project.xml | 3 +- examples/generic/i2c_multiplex/main.cpp | 73 +--- examples/generic/i2c_multiplex/project.xml | 8 +- examples/generic/resumable/main.cpp | 87 ---- examples/generic/resumable/project.xml | 13 - examples/generic/ros/environment/main.cpp | 110 ++--- examples/generic/ros/environment/project.xml | 3 +- .../generic/ros/environment/thread_bme280.cpp | 85 ++-- .../generic/ros/environment/thread_bme280.hpp | 9 +- .../ros/environment/thread_display.cpp | 14 +- .../ros/environment/thread_display.hpp | 8 +- examples/linux/block_device/file/main.cpp | 8 +- examples/linux/block_device/mirror/main.cpp | 8 +- examples/linux/block_device/ram/main.cpp | 8 +- examples/nucleo_f042k6/lis3mdl/main.cpp | 12 +- examples/nucleo_f042k6/lp503x/main.cpp | 18 +- examples/nucleo_f042k6/lsm6ds33/main.cpp | 13 +- examples/nucleo_f042k6/ms5837/main.cpp | 4 +- examples/nucleo_f042k6/tmp12x/main.cpp | 2 +- examples/nucleo_f103rb/stts22h/main.cpp | 4 +- .../temperature_mcp990x/main.cpp | 4 +- .../nucleo_f401re/distance_vl53l0/main.cpp | 152 +++---- .../nucleo_f401re/distance_vl53l0/project.xml | 2 +- .../dw3110-communication/main.cpp | 115 +++-- .../dw3110-communication/project.xml | 2 +- examples/nucleo_f411re/imu_bno055/main.cpp | 84 ++-- examples/nucleo_f411re/imu_bno055/project.xml | 2 +- examples/nucleo_f411re/sx1276_rx/main.cpp | 22 +- examples/nucleo_f411re/sx1276_tx/main.cpp | 16 +- examples/nucleo_f429zi/adc_ads816x/main.cpp | 8 +- examples/nucleo_f429zi/imu_adis16470/main.cpp | 30 +- examples/nucleo_f429zi/pat9125el/main.cpp | 80 +--- examples/nucleo_f429zi/pat9125el/project.xml | 2 - examples/nucleo_f429zi/rtc_mcp7941x/main.cpp | 135 +++--- .../nucleo_f429zi/rtc_mcp7941x/project.xml | 3 +- examples/nucleo_f429zi/spi_flash/main.cpp | 16 +- .../nucleo_f429zi/spi_flash_fatfs/main.cpp | 2 - .../nucleo_f429zi/spi_flash_fatfs/project.xml | 2 - .../nucleo_f429zi/spistack_flash/main.cpp | 16 +- examples/nucleo_f439zi/spi_dma/main.cpp | 72 ++-- examples/nucleo_f439zi/spi_dma/project.xml | 2 - examples/nucleo_f446re/color/main.cpp | 94 ++-- examples/nucleo_f446re/color/project.xml | 3 +- examples/nucleo_f767zi/spi_dma/main.cpp | 72 ++-- examples/nucleo_f767zi/spi_dma/project.xml | 2 - examples/nucleo_g071rb/amnb/main.cpp | 76 ++-- examples/nucleo_g071rb/amnb/project.xml | 4 +- examples/nucleo_g071rb/amnb_fiber/main.cpp | 166 ------- examples/nucleo_g071rb/amnb_fiber/project.xml | 18 - examples/nucleo_g071rb/apa102/main.cpp | 2 +- examples/nucleo_g071rb/matrix/main.cpp | 10 +- examples/nucleo_g474re/ads101x/main.cpp | 251 +++++------ examples/nucleo_g474re/ads101x/project.xml | 4 +- examples/nucleo_g474re/ads7828/main.cpp | 302 ++++++------- examples/nucleo_g474re/ads7828/project.xml | 5 +- examples/nucleo_g474re/as5047/main.cpp | 52 +-- examples/nucleo_g474re/as5047/project.xml | 4 +- examples/nucleo_g474re/imu_lsm6dso/main.cpp | 14 +- examples/nucleo_g474re/ixm42xxx/main.cpp | 100 ++--- examples/nucleo_g474re/ixm42xxx/project.xml | 5 +- examples/nucleo_g474re/ixm42xxx_fifo/main.cpp | 77 ++-- .../nucleo_g474re/ixm42xxx_fifo/project.xml | 5 +- examples/nucleo_g474re/max31855/main.cpp | 100 ++--- examples/nucleo_g474re/max31855/project.xml | 5 +- examples/nucleo_g474re/ms5611/main.cpp | 127 ++---- examples/nucleo_g474re/ms5611/project.xml | 5 +- examples/nucleo_g474re/sx128x_lora/main.cpp | 408 +++++++++--------- .../nucleo_g474re/sx128x_lora/project.xml | 6 +- examples/nucleo_h723zg/bmi088/i2c/project.xml | 2 - examples/nucleo_h723zg/bmi088/spi/project.xml | 2 - examples/nucleo_l432kc/gyroscope/main.cpp | 87 ++-- examples/nucleo_l432kc/gyroscope/project.xml | 2 - .../nucleo_l452re/graphics_touch/main.cpp | 6 +- examples/nucleo_l452re/lvgl/main.cpp | 4 +- examples/nucleo_l476rg/i2c_test/main.cpp | 95 ++-- examples/nucleo_l476rg/i2c_test/project.xml | 4 +- examples/rp_pico/logger/main.cpp | 49 +-- examples/rp_pico/logger/project.xml | 3 - examples/rp_pico/mclogger/main.cpp | 61 +-- examples/rp_pico/mclogger/project.xml | 3 +- examples/rp_pico/rtc_mcp7941x/main.cpp | 137 +++--- examples/rp_pico/rtc_mcp7941x/project.xml | 3 +- .../i2c-eeprom/at24mac402/main.cpp | 8 +- .../i2c-eeprom/generic/main.cpp | 6 +- .../samv71_xplained_ultra/mcp3008/main.cpp | 2 +- examples/stm32_f4ve/flash/main.cpp | 14 +- .../stm32f072_discovery/rotation/main.cpp | 67 +-- .../stm32f072_discovery/rotation/project.xml | 3 - .../stm32f072_discovery/stusb4500/main.cpp | 10 +- examples/stm32f072_discovery/tmp102/main.cpp | 119 ++--- .../stm32f072_discovery/tmp102/project.xml | 3 +- .../stm32f3_discovery/accelerometer/main.cpp | 81 ++-- .../accelerometer/project.xml | 3 - examples/stm32f3_discovery/rotation/main.cpp | 8 +- .../stm32f3_discovery/rotation/project.xml | 5 +- .../accelerometer/main.cpp | 76 ++-- .../accelerometer/project.xml | 7 - .../stm32f401_discovery/gyroscope/main.cpp | 69 +-- .../stm32f401_discovery/gyroscope/project.xml | 4 - examples/stm32f407vet6_devebox/flash/main.cpp | 14 +- .../stm32f469_discovery/game_of_life/main.cpp | 5 +- .../game_of_life/project.xml | 1 - examples/stm32f469_discovery/lvgl/main.cpp | 4 +- .../stm32f469_discovery/max31865/main.cpp | 72 ++-- .../stm32f469_discovery/max31865/project.xml | 6 +- .../stm32f469_discovery/touchscreen/main.cpp | 35 +- .../touchscreen/project.xml | 3 +- .../stm32f4_discovery/accelerometer/main.cpp | 86 ++-- .../accelerometer/project.xml | 4 - .../barometer_bmp085_bmp180/main.cpp | 129 ++---- .../barometer_bmp085_bmp180/project.xml | 3 - .../stm32f4_discovery/colour_tcs3414/main.cpp | 116 ++--- .../colour_tcs3414/project.xml | 5 +- .../display/hd44780/main.cpp | 138 +++--- .../display/hd44780/project.xml | 5 +- .../display/nokia_5110/main.cpp | 101 ++--- .../display/nokia_5110/project.xml | 5 +- .../distance_vl6180/main.cpp | 138 +++--- .../distance_vl6180/project.xml | 2 +- .../pressure_ams5915/main.cpp | 78 +--- .../pressure_ams5915/project.xml | 6 +- .../stm32f4_discovery/protothreads/main.cpp | 126 ------ .../temperature_ltc2984/main.cpp | 115 +++-- .../temperature_ltc2984/project.xml | 4 +- examples/stm32f4_discovery/tmp102/main.cpp | 86 ++++ .../{protothreads => tmp102}/project.xml | 6 +- .../stm32f746g_discovery/adc_ad7928/main.cpp | 100 ++--- .../adc_ad7928/project.xml | 3 - examples/stm32f746g_discovery/tmp102/main.cpp | 108 ++--- .../stm32f746g_discovery/tmp102/project.xml | 3 +- 156 files changed, 2386 insertions(+), 4139 deletions(-) create mode 100644 examples/avr/fiber_benchmark/main.cpp create mode 100644 examples/avr/fiber_benchmark/project.xml delete mode 100644 examples/avr/protothread/main.cpp delete mode 100644 examples/avr/protothread/project.xml delete mode 100644 examples/blue_pill_f103/environment/thread_blink.hpp delete mode 100644 examples/generic/resumable/main.cpp delete mode 100644 examples/generic/resumable/project.xml delete mode 100644 examples/nucleo_g071rb/amnb_fiber/main.cpp delete mode 100644 examples/nucleo_g071rb/amnb_fiber/project.xml delete mode 100644 examples/stm32f4_discovery/protothreads/main.cpp create mode 100644 examples/stm32f4_discovery/tmp102/main.cpp rename examples/stm32f4_discovery/{protothreads => tmp102}/project.xml (68%) diff --git a/examples/arduino_nano/color/main.cpp b/examples/arduino_nano/color/main.cpp index 80d7cd9d52..84cda3924d 100644 --- a/examples/arduino_nano/color/main.cpp +++ b/examples/arduino_nano/color/main.cpp @@ -15,65 +15,59 @@ using namespace modm::platform; -class Sensorthread : public modm::pt::Protothread +modm::Fiber fiber_blink([] { -private: - modm::ShortTimeout timeout; - - modm::tcs3472::Data data; - modm::Tcs3472 sensor{data}; - using TCS3472_INT = Board::D2; - -public: - bool - update() + LedD13::setOutput(); + while (true) { - PT_BEGIN(); + LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); - TCS3472_INT::setInput(Gpio::InputType::PullUp); +modm::tcs3472::Data data; +modm::Tcs3472 sensor{data}; +using TCS3472_INT = Board::D2; +modm::Fiber fiber_sensor([] +{ + TCS3472_INT::setInput(Gpio::InputType::PullUp); - MODM_LOG_INFO << "Ping TCS34725" << modm::endl; - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(sensor.ping())) { break; } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + MODM_LOG_INFO << "Ping TCS34725" << modm::endl; + // ping the device until it responds + while (true) + { + // we wait until the task started + if (sensor.ping()) break; + // otherwise, try again in 100ms + modm::this_fiber::sleep_for(100ms); + } - MODM_LOG_INFO << "TCS34725 responded" << modm::endl; + MODM_LOG_INFO << "TCS34725 responded" << modm::endl; - PT_CALL(sensor.initialize(sensor.Enable_InterruptMode_Waittime)); - PT_CALL(sensor.configure(modm::tcs3472::Gain::X16, modm::tcs3472::IntegrationTime::MSEC_2_4)); - PT_CALL(sensor.setInterruptPersistenceFilter(modm::tcs3472::InterruptPersistence::CNT_20)); - // Setup WaitTime to further slow down samplerate - PT_CALL(sensor.setWaitTime(modm::tcs3472::WaitTime::MSEC_2_4)); + sensor.initialize(sensor.Enable_InterruptMode_Waittime); + sensor.configure(modm::tcs3472::Gain::X16, modm::tcs3472::IntegrationTime::MSEC_2_4); + sensor.setInterruptPersistenceFilter(modm::tcs3472::InterruptPersistence::CNT_20); + // Setup WaitTime to further slow down samplerate + sensor.setWaitTime(modm::tcs3472::WaitTime::MSEC_2_4); - // Dummy read required - PT_CALL(sensor.readColor()); - // Fetch one sample ... - PT_CALL(sensor.readColor()); - // ...and set the high threshold 20% above current clear - PT_CALL(sensor.setInterruptHighThreshold(data.getClear() * 1.2)); + // Dummy read required + sensor.readColor(); + // Fetch one sample ... + sensor.readColor(); + // ...and set the high threshold 20% above current clear + sensor.setInterruptHighThreshold(data.getClear() * 1.2); - while (true) + while (true) + { + sensor.reloadInterrupt(); + modm::this_fiber::poll([]{ return not TCS3472_INT::read(); }); + if (sensor.readColor()) { - PT_CALL(sensor.reloadInterrupt()); - PT_WAIT_UNTIL(TCS3472_INT::read() == false); - if (PT_CALL(sensor.readColor())) - { - const auto rgb = data.getColor(); - MODM_LOG_INFO << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; - } + const auto rgb = data.getColor(); + MODM_LOG_INFO << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; } - - PT_END(); } -}; - -Sensorthread sensorthread; +}); int main() @@ -81,12 +75,6 @@ main() Board::initialize(); I2cMaster::initialize(); - LedD13::setOutput(); - modm::ShortPeriodicTimer heartbeat(500ms); - - while (true) - { - sensorthread.update(); - if (heartbeat.execute()) Board::LedD13::toggle(); - } + modm::fiber::Scheduler::run(); + return 0; } diff --git a/examples/arduino_nano/color/project.xml b/examples/arduino_nano/color/project.xml index 3a249e8797..80e6ae2182 100644 --- a/examples/arduino_nano/color/project.xml +++ b/examples/arduino_nano/color/project.xml @@ -5,8 +5,7 @@ modm:build:scons - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:platform:i2c modm:driver:tcs3472 diff --git a/examples/avr/block_device_mirror/main.cpp b/examples/avr/block_device_mirror/main.cpp index 3a2809d416..8a825d9140 100644 --- a/examples/avr/block_device_mirror/main.cpp +++ b/examples/avr/block_device_mirror/main.cpp @@ -61,7 +61,7 @@ main() modm::BdMirror, modm::BdHeap> storageDevice; - if(!RF_CALL_BLOCKING(storageDevice.initialize())) { + if(!storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; exit(1); } @@ -71,20 +71,20 @@ main() for(uint16_t iteration = 0; iteration < 10; iteration++) { uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; - if(!RF_CALL_BLOCKING(storageDevice.erase(0, MemorySize))) { + if(!storageDevice.erase(0, MemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; exit(1); } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.program(pattern, i, BlockSize))) { + if(!storageDevice.program(pattern, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; exit(1); } } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.read(bufferC, i, BlockSize))) { + if(!storageDevice.read(bufferC, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; exit(1); } diff --git a/examples/avr/fiber/main.cpp b/examples/avr/fiber/main.cpp index b7571a17c9..841dd11863 100644 --- a/examples/avr/fiber/main.cpp +++ b/examples/avr/fiber/main.cpp @@ -1,5 +1,7 @@ /* - * Copyright (c) 2020, Erik Henriksson + * Copyright (c) 2010-2011, Fabian Greif + * Copyright (c) 2012-2013, 2015-2017, Niklas Hauser + * Copyright (c) 2014, Sascha Schade * * This file is part of the modm project. * @@ -9,86 +11,57 @@ */ // ---------------------------------------------------------------------------- -#include -#include +#include +#include #include -using namespace Board; +using namespace modm::platform; using namespace std::chrono_literals; -constexpr uint32_t cycles = 100'000; -volatile uint32_t f1counter = 0, f2counter = 0; -uint32_t total_counter=0; +using LedGreen = GpioOutputB0; +using LedRed = GpioOutputB1; -void -fiber_function1() +modm::Fiber fiber_green([] { - MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; - while (++f1counter < cycles) { modm::this_fiber::yield(); total_counter++; } -} - -void -fiber_function2(uint32_t cyc) -{ - MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; - while (++f2counter < cyc) { modm::this_fiber::yield(); total_counter++; } -} + LedGreen::setOutput(); + LedGreen::set(); -struct Test -{ - void - fiber_function3() + while (true) { - MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; - while (++f3counter < cycles) { modm::this_fiber::yield(); total_counter++; } + LedGreen::set(); + modm::this_fiber::sleep_for(100ms); + + LedGreen::reset(); + modm::this_fiber::sleep_for(600ms); } +}); + +modm::Fiber fiber_red([] +{ + LedRed::setOutput(); + LedRed::set(); - void - fiber_function4(uint32_t cyc) + while (true) { - MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; - while (++f4counter < cyc) { modm::this_fiber::yield(); total_counter++; } - } + LedRed::set(); + modm::this_fiber::sleep_for(200ms); + + LedRed::reset(); + modm::this_fiber::sleep_for(300ms); - volatile uint32_t f3counter{0}; - volatile uint32_t f4counter{0}; -} test; + LedRed::set(); + modm::this_fiber::sleep_for(200ms); -modm::Fiber<> fiber1(fiber_function1); -modm::Fiber<> fiber2(+[](){ fiber_function2(cycles); }); -modm::Fiber<> fiber3(+[](){ test.fiber_function3(); }); -modm::Fiber<> fiber4([cyc=uint32_t(cycles)]() mutable { cyc++; test.fiber_function4(cyc); }); + LedRed::reset(); + modm::this_fiber::sleep_for(1s); + } +}); -// ATmega2560@16MHz: 239996 yields in 2492668us, 96280 yields per second, 10386ns per yield int main() { - Board::initialize(); - Board::LedD13::setOutput(); - MODM_LOG_INFO << "Starting fiber modm::yield benchmark..." << modm::endl; - MODM_LOG_INFO.flush(); - - fiber1.stack_watermark(); - fiber2.stack_watermark(); - fiber3.stack_watermark(); - fiber4.stack_watermark(); + SystemClock::enable(); + enableInterrupts(); - const modm::PreciseTimestamp start = modm::PreciseClock::now(); modm::fiber::Scheduler::run(); - const auto diff = (modm::PreciseClock::now() - start); - - MODM_LOG_INFO << "Benchmark done!" << modm::endl; - MODM_LOG_INFO << "Executed " << total_counter << " yields in " << diff << modm::endl; - MODM_LOG_INFO << uint32_t((total_counter * 1'000'000ull) / std::chrono::microseconds(diff).count()); - MODM_LOG_INFO << " yields per second, "; - MODM_LOG_INFO << uint32_t(std::chrono::nanoseconds(diff).count() / total_counter); - MODM_LOG_INFO << "ns per yield" << modm::endl; - - MODM_LOG_INFO << "Stack usage 1 = " << fiber1.stack_usage() << modm::endl; - MODM_LOG_INFO << "Stack usage 2 = " << fiber2.stack_usage() << modm::endl; - MODM_LOG_INFO << "Stack usage 3 = " << fiber3.stack_usage() << modm::endl; - MODM_LOG_INFO << "Stack usage 4 = " << fiber4.stack_usage() << modm::endl; - - while(1) ; - return 0; } diff --git a/examples/avr/fiber/project.xml b/examples/avr/fiber/project.xml index d06e96568a..b277d24da6 100644 --- a/examples/avr/fiber/project.xml +++ b/examples/avr/fiber/project.xml @@ -1,12 +1,14 @@ - modm:mega-2560-pro - + + - modm:build:scons - modm:processing:timer + modm:platform:core + modm:platform:clock + modm:platform:gpio modm:processing:fiber + modm:build:scons diff --git a/examples/avr/fiber_benchmark/main.cpp b/examples/avr/fiber_benchmark/main.cpp new file mode 100644 index 0000000000..b7571a17c9 --- /dev/null +++ b/examples/avr/fiber_benchmark/main.cpp @@ -0,0 +1,94 @@ +/* + * Copyright (c) 2020, Erik Henriksson + * + * This file is part of the modm project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ +// ---------------------------------------------------------------------------- + +#include +#include +#include + +using namespace Board; +using namespace std::chrono_literals; + +constexpr uint32_t cycles = 100'000; +volatile uint32_t f1counter = 0, f2counter = 0; +uint32_t total_counter=0; + +void +fiber_function1() +{ + MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; + while (++f1counter < cycles) { modm::this_fiber::yield(); total_counter++; } +} + +void +fiber_function2(uint32_t cyc) +{ + MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; + while (++f2counter < cyc) { modm::this_fiber::yield(); total_counter++; } +} + +struct Test +{ + void + fiber_function3() + { + MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; + while (++f3counter < cycles) { modm::this_fiber::yield(); total_counter++; } + } + + void + fiber_function4(uint32_t cyc) + { + MODM_LOG_INFO << MODM_FILE_INFO << modm::endl; + while (++f4counter < cyc) { modm::this_fiber::yield(); total_counter++; } + } + + volatile uint32_t f3counter{0}; + volatile uint32_t f4counter{0}; +} test; + +modm::Fiber<> fiber1(fiber_function1); +modm::Fiber<> fiber2(+[](){ fiber_function2(cycles); }); +modm::Fiber<> fiber3(+[](){ test.fiber_function3(); }); +modm::Fiber<> fiber4([cyc=uint32_t(cycles)]() mutable { cyc++; test.fiber_function4(cyc); }); + +// ATmega2560@16MHz: 239996 yields in 2492668us, 96280 yields per second, 10386ns per yield +int +main() +{ + Board::initialize(); + Board::LedD13::setOutput(); + MODM_LOG_INFO << "Starting fiber modm::yield benchmark..." << modm::endl; + MODM_LOG_INFO.flush(); + + fiber1.stack_watermark(); + fiber2.stack_watermark(); + fiber3.stack_watermark(); + fiber4.stack_watermark(); + + const modm::PreciseTimestamp start = modm::PreciseClock::now(); + modm::fiber::Scheduler::run(); + const auto diff = (modm::PreciseClock::now() - start); + + MODM_LOG_INFO << "Benchmark done!" << modm::endl; + MODM_LOG_INFO << "Executed " << total_counter << " yields in " << diff << modm::endl; + MODM_LOG_INFO << uint32_t((total_counter * 1'000'000ull) / std::chrono::microseconds(diff).count()); + MODM_LOG_INFO << " yields per second, "; + MODM_LOG_INFO << uint32_t(std::chrono::nanoseconds(diff).count() / total_counter); + MODM_LOG_INFO << "ns per yield" << modm::endl; + + MODM_LOG_INFO << "Stack usage 1 = " << fiber1.stack_usage() << modm::endl; + MODM_LOG_INFO << "Stack usage 2 = " << fiber2.stack_usage() << modm::endl; + MODM_LOG_INFO << "Stack usage 3 = " << fiber3.stack_usage() << modm::endl; + MODM_LOG_INFO << "Stack usage 4 = " << fiber4.stack_usage() << modm::endl; + + while(1) ; + return 0; +} diff --git a/examples/avr/fiber_benchmark/project.xml b/examples/avr/fiber_benchmark/project.xml new file mode 100644 index 0000000000..d60a677b8a --- /dev/null +++ b/examples/avr/fiber_benchmark/project.xml @@ -0,0 +1,12 @@ + + modm:mega-2560-pro + + + + + + modm:build:scons + modm:processing:timer + modm:processing:fiber + + diff --git a/examples/avr/protothread/main.cpp b/examples/avr/protothread/main.cpp deleted file mode 100644 index cff2977046..0000000000 --- a/examples/avr/protothread/main.cpp +++ /dev/null @@ -1,112 +0,0 @@ -/* - * Copyright (c) 2010-2011, Fabian Greif - * Copyright (c) 2012-2013, 2015-2017, Niklas Hauser - * Copyright (c) 2014, Sascha Schade - * - * This file is part of the modm project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ -// ---------------------------------------------------------------------------- - -#include -#include -#include -#include - -using namespace modm::platform; -using namespace std::chrono_literals; - -typedef GpioOutputB0 LedGreen; -typedef GpioOutputB1 LedRed; - -class BlinkingLightGreen : public modm::pt::Protothread -{ -public: - bool - run() - { - PT_BEGIN(); - - // set everything up - LedGreen::setOutput(); - LedGreen::set(); - - while (true) - { - LedGreen::set(); - - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - - LedGreen::reset(); - - timeout.restart(600ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; -}; - -class BlinkingLightRed : public modm::pt::Protothread -{ -public: - bool - run() - { - PT_BEGIN(); - - // set everything up - LedRed::setOutput(); - LedRed::set(); - - while (true) - { - LedRed::set(); - - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - - LedRed::reset(); - - timeout.restart(300ms); - PT_WAIT_UNTIL(timeout.isExpired()); - - LedRed::set(); - - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - - LedRed::reset(); - - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; -}; - -int -main() -{ - SystemClock::enable(); - enableInterrupts(); - - BlinkingLightGreen greenLight; - BlinkingLightRed redLight; - while (true) - { - greenLight.run(); - redLight.run(); - } -} diff --git a/examples/avr/protothread/project.xml b/examples/avr/protothread/project.xml deleted file mode 100644 index 1dd52d5caf..0000000000 --- a/examples/avr/protothread/project.xml +++ /dev/null @@ -1,15 +0,0 @@ - - - - - - - - modm:platform:core - modm:platform:clock - modm:platform:gpio - modm:processing:protothread - modm:processing:timer - modm:build:scons - - diff --git a/examples/avr/pwm/pca9685/main.cpp b/examples/avr/pwm/pca9685/main.cpp index 8a4a1e1e95..f8862d2f49 100644 --- a/examples/avr/pwm/pca9685/main.cpp +++ b/examples/avr/pwm/pca9685/main.cpp @@ -33,18 +33,18 @@ main() // Initialize the controller. I use RGB-LEDs with common annode. // Therfore the controllers output needs to be inverted. - RF_CALL_BLOCKING(pwmController.initialize(0, modm::pca9685::MODE2_INVRT)); + pwmController.initialize(0, modm::pca9685::MODE2_INVRT); uint16_t pwm = 0; while (true) { // Fade all LEDS but LED 5 and 11 - RF_CALL_BLOCKING(pwmController.setAllChannels(pwm)); + pwmController.setAllChannels(pwm); // LED 5 is always off - RF_CALL_BLOCKING(pwmController.setChannel(5, 0)); + pwmController.setChannel(5, 0); // LED 11 is always on - RF_CALL_BLOCKING(pwmController.setChannel(11, 0xfff)); + pwmController.setChannel(11, 0xfff); // Increase brighness with each cycle. It would be better to use a // timer instead... diff --git a/examples/avr/qmc5883l/main.cpp b/examples/avr/qmc5883l/main.cpp index 124962fcf1..edcee2a985 100644 --- a/examples/avr/qmc5883l/main.cpp +++ b/examples/avr/qmc5883l/main.cpp @@ -36,17 +36,17 @@ main() Board::D19::setInputTrigger(Gpio::InputTrigger::RisingEdge); Board::D19::enableExternalInterrupt(); - RF_CALL_BLOCKING(compass.initialize()); + compass.initialize(); auto mode = Compass::Mode_t(Compass::Mode::Continious); auto rate = Compass::OutputDataRate_t(Compass::OutputDataRate::_10Hz); auto scale = Compass::FullScale_t(Compass::FullScale::_8G); - RF_CALL_BLOCKING(compass.configure(mode, rate | scale)); + compass.configure(mode, rate | scale); for (;;) { if (dataReady.testAndSet(false)) { - if (RF_CALL_BLOCKING(compass.readData())) + if (compass.readData()) { MODM_LOG_INFO << "X:" << compass.x() << " Y: " << compass.y() << " Z: " << compass.z() diff --git a/examples/blue_pill_f103/adns_9800/main.cpp b/examples/blue_pill_f103/adns_9800/main.cpp index 4ba52d34fe..8464e666af 100644 --- a/examples/blue_pill_f103/adns_9800/main.cpp +++ b/examples/blue_pill_f103/adns_9800/main.cpp @@ -13,9 +13,8 @@ // ---------------------------------------------------------------------------- #include -#include -#include -#include +#include +#include #include @@ -36,95 +35,65 @@ modm::log::Logger modm::log::info(loggerDevice); modm::log::Logger modm::log::warning(loggerDevice); modm::log::Logger modm::log::error(loggerDevice); -class BlinkThread : public modm::pt::Protothread + +modm::Fiber fiber_blink([] { -public: - BlinkThread() - { - timeout.restart(100ms); - } + modm::ShortTimeout timeout(100ms); + uint32_t uptime{}; - bool - update() + while (true) { - PT_BEGIN(); - - while (true) - { - Board::LedGreen::reset(); + Board::LedGreen::reset(); - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(100ms); - - Board::LedGreen::set(); + timeout.wait(); + timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()) ; - timeout.restart(4.9s); + Board::LedGreen::set(); - MODM_LOG_INFO << "Seconds since reboot: " << uptime << modm::endl; + timeout.wait(); + timeout.restart(4.9s); - uptime += 5; - } + MODM_LOG_INFO << "Seconds since reboot: " << uptime << modm::endl; - PT_END(); + uptime += 5; } +}); + -private: - modm::ShortTimeout timeout; - uint32_t uptime; -}; +using Cs = GpioOutputA4; +using Adns9800 = modm::Adns9800< + /* Spi = */ SpiMaster1, + /* Ncs = */ Cs >; -class Adns9800Thread : public modm::pt::Protothread +modm::Fiber fiber_adns9800([] { -public: - Adns9800Thread() : timer(10ms), x(0), y(0) - { - } + modm::ShortPeriodicTimer timer(10ms); + int32_t x{}, y{}; - bool - update() - { - PT_BEGIN(); + Cs::setOutput(modm::Gpio::High); - Cs::setOutput(modm::Gpio::High); + SpiMaster1::connect(); + SpiMaster1::initialize(); + SpiMaster1::setDataMode(SpiMaster1::DataMode::Mode3); - SpiMaster1::connect(); - SpiMaster1::initialize(); - SpiMaster1::setDataMode(SpiMaster1::DataMode::Mode3); + Adns9800::initialise(); - adns9800::initialise(); + while (true) + { + timer.wait(); - while (true) { - PT_WAIT_UNTIL(timer.execute()); - - { - int16_t delta_x, delta_y; - adns9800::getDeltaXY(delta_x, delta_y); - MODM_LOG_INFO.printf("dx = %5" PRId16 ", dy = %5" PRId16"; x = %9" PRId32", y=%9" PRId32 "\n", delta_x, delta_y, x, y); - - x += delta_x; - y += delta_y; - } + int16_t delta_x, delta_y; + Adns9800::getDeltaXY(delta_x, delta_y); + MODM_LOG_INFO.printf( + "dx = %5"PRId16", dy = %5"PRId16"; x = %9"PRId32", y=%9"PRId32"\n", + delta_x, delta_y, x, y); + + x += delta_x; + y += delta_y; } - - PT_END(); } - -private: - modm::ShortPeriodicTimer timer; - int32_t x, y; - - using Cs = GpioOutputA4; - - using adns9800 = modm::Adns9800< - /* Spi = */ SpiMaster1, - /* Ncs = */ Cs >; -}; - - -BlinkThread blinkThread; -Adns9800Thread adns9800Thread; +}); // ---------------------------------------------------------------------------- @@ -146,11 +115,6 @@ main() MODM_LOG_INFO << "Welcome to ADNS 9800 demo." << modm::endl; - while (true) - { - blinkThread.update(); - adns9800Thread.update(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/blue_pill_f103/adns_9800/project.xml b/examples/blue_pill_f103/adns_9800/project.xml index 4f54e9196d..a49056e800 100644 --- a/examples/blue_pill_f103/adns_9800/project.xml +++ b/examples/blue_pill_f103/adns_9800/project.xml @@ -10,7 +10,7 @@ modm:platform:gpio modm:platform:spi:1 modm:platform:uart:2 - modm:processing:protothread + modm:processing:fiber modm:processing:timer modm:build:scons diff --git a/examples/blue_pill_f103/environment/main.cpp b/examples/blue_pill_f103/environment/main.cpp index 8050ba91e0..fff74a2031 100644 --- a/examples/blue_pill_f103/environment/main.cpp +++ b/examples/blue_pill_f103/environment/main.cpp @@ -21,7 +21,6 @@ // ---------------------------------------------------------------------------- #include "threads.hpp" -BlinkThread blinkThread; Bmp180Thread bmp180Thread; Bme280Thread bme280Thread; @@ -65,14 +64,7 @@ main() MODM_LOG_DEBUG << "Welcome to Environment Sensor Test" << modm::endl; - LedGreen::set(); - - while (true) - { - blinkThread.update(); - bmp180Thread.update(); - bme280Thread.update(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/blue_pill_f103/environment/project.xml b/examples/blue_pill_f103/environment/project.xml index a679f45f7c..b930caf338 100644 --- a/examples/blue_pill_f103/environment/project.xml +++ b/examples/blue_pill_f103/environment/project.xml @@ -13,7 +13,7 @@ modm:platform:i2c:2 modm:platform:uart:2 modm:processing:timer - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/blue_pill_f103/environment/thread_blink.cpp b/examples/blue_pill_f103/environment/thread_blink.cpp index 4607ac0f37..54855ca64e 100644 --- a/examples/blue_pill_f103/environment/thread_blink.cpp +++ b/examples/blue_pill_f103/environment/thread_blink.cpp @@ -21,32 +21,24 @@ #undef MODM_LOG_LEVEL #define MODM_LOG_LEVEL modm::log::INFO -// ---------------------------------------------------------------------------- -BlinkThread::BlinkThread() : - timer(5s), - uptime(0) -{ -} +modm::ShortPeriodicTimer timer(5s); +uint32_t uptime; -bool -BlinkThread::update() +// ---------------------------------------------------------------------------- +modm::Fiber fiber_blink([] { - PT_BEGIN(); - while (true) { - PT_WAIT_UNTIL(timer.execute()); - timeout.restart(100ms); + timer.wait(); Board::LedGreen::set(); bmp180Thread.startMeasurement(); bme280Thread.startMeasurement(); - - PT_WAIT_UNTIL(timeout.isExpired()) ; + modm::this_fiber::sleep_for(100ms); Board::LedGreen::reset(); - PT_WAIT_UNTIL(bmp180Thread.isNewDataAvailable() and bme280Thread.isNewDataAvailable()); + modm::this_fiber::poll([&]{ return bmp180Thread.isNewDataAvailable() and bme280Thread.isNewDataAvailable(); }); int16_t bmp180_a_temp = bmp180Thread.getTemperatureA(); int32_t bmp180_a_press = bmp180Thread.getPressureA(); @@ -73,6 +65,4 @@ BlinkThread::update() ++uptime; } - - PT_END(); -} +}); diff --git a/examples/blue_pill_f103/environment/thread_blink.hpp b/examples/blue_pill_f103/environment/thread_blink.hpp deleted file mode 100644 index b26753381b..0000000000 --- a/examples/blue_pill_f103/environment/thread_blink.hpp +++ /dev/null @@ -1,32 +0,0 @@ -/* - * Copyright (c) 2016, Sascha Schade - * - * This file is part of the modm project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ -// ---------------------------------------------------------------------------- - -#ifndef THREAD_BLINK -#define THREAD_BLINK - -#include -#include - -class BlinkThread: public modm::pt::Protothread -{ -public: - BlinkThread(); - - bool - update(); - -private: - modm::ShortTimeout timeout; - modm::ShortPeriodicTimer timer; - uint32_t uptime; -}; - -#endif // THREAD_BLINK diff --git a/examples/blue_pill_f103/environment/thread_bme280.cpp b/examples/blue_pill_f103/environment/thread_bme280.cpp index a9d46443fd..6e92cadb66 100644 --- a/examples/blue_pill_f103/environment/thread_bme280.cpp +++ b/examples/blue_pill_f103/environment/thread_bme280.cpp @@ -23,6 +23,7 @@ // ---------------------------------------------------------------------------- Bme280Thread::Bme280Thread() : + Fiber([this] { this->update(); }), barometerA(dataA, 0x76), barometerB(dataB, 0x76), start_measurement(false), @@ -38,11 +39,9 @@ Bme280Thread::startMeasurement() return true; } -bool +void Bme280Thread::update() { - PT_BEGIN() - MODM_LOG_DEBUG << MODM_FILE_INFO; MODM_LOG_DEBUG << "Ping the BME280" << modm::endl; @@ -50,21 +49,19 @@ Bme280Thread::update() while(true) { // we wait until the task started - if (PT_CALL(barometerA.ping())) + if (barometerA.ping()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } while(true) { // we wait until the task started - if (PT_CALL(barometerB.ping())) + if (barometerB.ping()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } // stream << "Barometer BME280 responded" << modm::endl; @@ -73,21 +70,19 @@ Bme280Thread::update() while(true) { // we wait until the task started - if (PT_CALL(barometerA.initialize())) + if (barometerA.initialize()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } while(true) { // we wait until the task started - if (PT_CALL(barometerB.initialize())) + if (barometerB.initialize()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } MODM_LOG_DEBUG << MODM_FILE_INFO; @@ -145,28 +140,24 @@ Bme280Thread::update() while (true) { - PT_WAIT_UNTIL(start_measurement); + modm::this_fiber::poll([&]{ return start_measurement; }); // Returns when new data was read from the sensor - PT_CALL(barometerA.readout()); - PT_CALL(barometerB.readout()); + barometerA.readout(); + barometerB.readout(); new_data = true; - { - int32_t temp = dataA.getTemperature(); - int32_t press = dataA.getPressure(); - int32_t hum = dataA.getHumidity(); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated temperature in 0.01 degree Celsius is: %" PRId32 "\n", temp ); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated pressure in mPa is : %" PRId32 "\n", press ); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated humidity in 0.001 %% is : %" PRId32 "\n", hum ); - } + int32_t temp = dataA.getTemperature(); + int32_t press = dataA.getPressure(); + int32_t hum = dataA.getHumidity(); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated temperature in 0.01 degree Celsius is: %" PRId32 "\n", temp ); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated pressure in mPa is : %" PRId32 "\n", press ); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated humidity in 0.001 %% is : %" PRId32 "\n", hum ); start_measurement = false; } - - PT_END(); } diff --git a/examples/blue_pill_f103/environment/thread_bme280.hpp b/examples/blue_pill_f103/environment/thread_bme280.hpp index 54315ede74..38890d49db 100644 --- a/examples/blue_pill_f103/environment/thread_bme280.hpp +++ b/examples/blue_pill_f103/environment/thread_bme280.hpp @@ -12,19 +12,18 @@ #ifndef THREAD_BME280 #define THREAD_BME280 -#include -#include +#include #include #include "hardware.hpp" -class Bme280Thread: public modm::pt::Protothread +class Bme280Thread: public modm::Fiber<> { public: Bme280Thread(); - bool + void update(); bool @@ -66,8 +65,6 @@ class Bme280Thread: public modm::pt::Protothread } private: - modm::ShortTimeout timeout; - modm::bme280::Data dataA; modm::Bme280 barometerA; diff --git a/examples/blue_pill_f103/environment/thread_bmp180.cpp b/examples/blue_pill_f103/environment/thread_bmp180.cpp index e9c30fb50b..81dc9d6937 100644 --- a/examples/blue_pill_f103/environment/thread_bmp180.cpp +++ b/examples/blue_pill_f103/environment/thread_bmp180.cpp @@ -23,6 +23,7 @@ // ---------------------------------------------------------------------------- Bmp180Thread::Bmp180Thread() : + Fiber([this] { this->update(); }), barometerA(dataA, 0x77), barometerB(dataB, 0x77), start_measurement(false), @@ -38,11 +39,9 @@ Bmp180Thread::startMeasurement() return true; } -bool +void Bmp180Thread::update() { - PT_BEGIN(); - MODM_LOG_DEBUG << MODM_FILE_INFO; MODM_LOG_DEBUG << "Ping the Barometer BMP180" << modm::endl; @@ -50,21 +49,19 @@ Bmp180Thread::update() while(true) { // we wait until the task started - if (PT_CALL(barometerA.ping())) + if (barometerA.ping()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } while(true) { // we wait until the task started - if (PT_CALL(barometerB.ping())) + if (barometerB.ping()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } MODM_LOG_DEBUG << MODM_FILE_INFO; @@ -74,21 +71,19 @@ Bmp180Thread::update() while(true) { // we wait until the task started - if (PT_CALL(barometerA.initialize())) + if (barometerA.initialize()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } while(true) { // we wait until the task started - if (PT_CALL(barometerB.initialize())) + if (barometerB.initialize()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } MODM_LOG_DEBUG << MODM_FILE_INFO; @@ -111,25 +106,23 @@ Bmp180Thread::update() while (true) { - PT_WAIT_UNTIL(start_measurement); + modm::this_fiber::poll([&]{ return start_measurement; }); // Returns when new data was read from the sensor - PT_CALL(barometerA.readout()); - PT_CALL(barometerB.readout()); + barometerA.readout(); + barometerB.readout(); new_data = true; - { - auto temp = dataA.getTemperature(); - auto press = dataA.getPressure(); + auto temp = dataA.getTemperature(); + auto press = dataA.getPressure(); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BMP180: Calibrated temperature in 0.1 degree Celsius is : %d\n", temp ); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BMP180: Calibrated pressure in Pa is : %" PRId32 "\n", press ); - } + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BMP180: Calibrated temperature in 0.1 degree Celsius is : %d\n", temp ); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BMP180: Calibrated pressure in Pa is : %" PRId32 "\n", press ); start_measurement = false; } - PT_END(); + } diff --git a/examples/blue_pill_f103/environment/thread_bmp180.hpp b/examples/blue_pill_f103/environment/thread_bmp180.hpp index 0bddcb82fd..7c9bdd781c 100644 --- a/examples/blue_pill_f103/environment/thread_bmp180.hpp +++ b/examples/blue_pill_f103/environment/thread_bmp180.hpp @@ -12,19 +12,18 @@ #ifndef THREAD_BMP180 #define THREAD_BMP180 -#include -#include +#include #include #include "hardware.hpp" -class Bmp180Thread: public modm::pt::Protothread +class Bmp180Thread: public modm::Fiber<> { public: Bmp180Thread(); - bool + void update(); bool @@ -56,8 +55,6 @@ class Bmp180Thread: public modm::pt::Protothread } private: - modm::ShortTimeout timeout; - modm::bmp085::Data dataA; modm::Bmp085 barometerA; diff --git a/examples/blue_pill_f103/environment/threads.hpp b/examples/blue_pill_f103/environment/threads.hpp index c6a38440a2..fd52075f01 100644 --- a/examples/blue_pill_f103/environment/threads.hpp +++ b/examples/blue_pill_f103/environment/threads.hpp @@ -12,12 +12,11 @@ #ifndef THREADS #define THREADS -#include "thread_blink.hpp" #include "thread_bmp180.hpp" #include "thread_bme280.hpp" -extern BlinkThread blinkThread; extern Bmp180Thread bmp180Thread; extern Bme280Thread bme280Thread; #endif // THREADS + diff --git a/examples/blue_pill_f103/logger/main.cpp b/examples/blue_pill_f103/logger/main.cpp index 6fd55305b8..b3b3fc8e0b 100644 --- a/examples/blue_pill_f103/logger/main.cpp +++ b/examples/blue_pill_f103/logger/main.cpp @@ -14,8 +14,6 @@ #include #include -#include -#include // ---------------------------------------------------------------------------- // Set the log level @@ -32,46 +30,6 @@ modm::log::Logger modm::log::info(loggerDevice); modm::log::Logger modm::log::warning(loggerDevice); modm::log::Logger modm::log::error(loggerDevice); - -class BlinkThread : public modm::pt::Protothread -{ -public: - BlinkThread() - { - timeout.restart(100ms); - } - - bool - update() - { - PT_BEGIN(); - - while (true) - { - Board::LedGreen::reset(); - - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(100ms); - - Board::LedGreen::set(); - - PT_WAIT_UNTIL(timeout.isExpired()) ; - timeout.restart(900ms); - - MODM_LOG_INFO << "Seconds since reboot: " << ++uptime << modm::endl; - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - uint32_t uptime; -}; - -BlinkThread blinkThread; - - // ---------------------------------------------------------------------------- int main() @@ -90,9 +48,16 @@ main() MODM_LOG_ERROR << "error" << modm::endl; + uint32_t uptime{}; while (true) { - blinkThread.update(); + Board::LedGreen::reset(); + modm::delay(100ms); + + Board::LedGreen::set(); + modm::delay(900ms); + + MODM_LOG_INFO << "Seconds since reboot: " << ++uptime << modm::endl; } return 0; diff --git a/examples/blue_pill_f103/logger/project.xml b/examples/blue_pill_f103/logger/project.xml index 04550dbc87..11c8de6645 100644 --- a/examples/blue_pill_f103/logger/project.xml +++ b/examples/blue_pill_f103/logger/project.xml @@ -8,8 +8,6 @@ modm:debug modm:platform:gpio modm:platform:uart:2 - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/blue_pill_f103/tlc594x/main.cpp b/examples/blue_pill_f103/tlc594x/main.cpp index 986453afaa..81264ff14f 100644 --- a/examples/blue_pill_f103/tlc594x/main.cpp +++ b/examples/blue_pill_f103/tlc594x/main.cpp @@ -39,7 +39,7 @@ main() { tlc594x.setAllChannels(0x000); tlc594x.setChannel(i, 0xfff); - RF_CALL_BLOCKING(tlc594x.writeChannels()); + tlc594x.writeChannels(); modm::delay(500ms); } diff --git a/examples/blue_pill_f103/weight_scale_hx711/main.cpp b/examples/blue_pill_f103/weight_scale_hx711/main.cpp index 51edafd9db..b1622dd02f 100644 --- a/examples/blue_pill_f103/weight_scale_hx711/main.cpp +++ b/examples/blue_pill_f103/weight_scale_hx711/main.cpp @@ -11,8 +11,7 @@ #include #include -#include -#include +#include #include using namespace Board; @@ -40,54 +39,25 @@ struct hx711_config : public modm::hx711::Config // static const modm::hx711::InputChannelAndGain mode = modm::hx711::InputChannelAndGain::ChA_64; }; using Hx711 = modm::Hx711< hx711_config >; +Hx711 hx711; -class Hx711Thread : public modm::pt::Protothread +modm::Fiber fiber_hx711([] { -public: - bool - run() + while (true) { - PT_BEGIN(); - - while (true) - { - result = PT_CALL(hx711.singleConversion()); - MODM_LOG_DEBUG.printf("%" PRIi32 "\n", result); - } - - PT_END(); + const int32_t result = hx711.singleConversion(); + MODM_LOG_DEBUG.printf("%" PRIi32 "\n", result); } +}); -protected: - Hx711 hx711; - int32_t result; -}; - -Hx711Thread hx711_thread; - - -class BlinkThread : public modm::pt::Protothread +modm::Fiber fiber_blink([] { -public: - bool - run() + while (true) { - PT_BEGIN(); - - while (true) { - PT_WAIT_UNTIL(timer.execute()); - LedGreen::toggle(); - } - - PT_END(); + modm::this_fiber::sleep_for(1s); + LedGreen::toggle(); } - -protected: - modm::ShortPeriodicTimer timer{1s}; -}; - -BlinkThread blink_thread; - +}); /* * Blinks the green user LED with 1 Hz while measuring. @@ -106,18 +76,12 @@ main() Usart1::initialize(); // Use the logging streams to print some messages. - MODM_LOG_DEBUG << "HX711 demo" << modm::endl; + MODM_LOG_DEBUG << "HX711 demo" << modm::endl; hx711_config::Sck::setOutput(); hx711_config::Data::setInput(); - LedGreen::set(); - - while (true) - { - blink_thread.run(); - hx711_thread.run(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/blue_pill_f103/weight_scale_hx711/project.xml b/examples/blue_pill_f103/weight_scale_hx711/project.xml index 7858b9c500..6f3d9e0927 100644 --- a/examples/blue_pill_f103/weight_scale_hx711/project.xml +++ b/examples/blue_pill_f103/weight_scale_hx711/project.xml @@ -8,8 +8,7 @@ modm:debug modm:platform:gpio modm:platform:uart:1 - modm:processing:timer - modm:processing:protothread + modm:processing:fiber modm:build:scons modm:driver:hx711 diff --git a/examples/generic/i2c_multiplex/main.cpp b/examples/generic/i2c_multiplex/main.cpp index af93619dc3..804d05d2fe 100644 --- a/examples/generic/i2c_multiplex/main.cpp +++ b/examples/generic/i2c_multiplex/main.cpp @@ -8,8 +8,7 @@ * file, You can obtain one at http://mozilla.org/MPL/2.0/. */ #include -#include -#include +#include #include #include #include @@ -54,32 +53,13 @@ namespace multiplexer using Ch7 = I2cMultiplexer::Ch7< i2cMultiplexer >; } +modm::I2cDevice dev0(0x29); +modm::I2cDevice dev1(0x29); +modm::I2cDevice dev2(0x29); +modm::I2cDevice dev3(0x29); -class DeviceThread: public modm::pt::Protothread +modm::Fiber fiber_ping([] { -public: - DeviceThread() : dev0(0x29), dev1(0x29), dev2(0x29), dev3(0x29) - {} - - bool - update(); - -private: - modm::ShortTimeout timeout; - - // Simple devices which are just pingable. - // Independent of real device. Any I2C device should be pingable at its address. - modm::I2cDevice dev0; - modm::I2cDevice dev1; - modm::I2cDevice dev2; - modm::I2cDevice dev3; -}; - -bool -DeviceThread::update() -{ - PT_BEGIN(); - MODM_LOG_DEBUG << MODM_FILE_INFO; MODM_LOG_DEBUG << "Ping the Devices" << modm::endl; @@ -87,20 +67,28 @@ DeviceThread::update() while(true) { MODM_LOG_DEBUG.printf("[dev ] ping0\n"); - MODM_LOG_DEBUG.printf("[dev ] ping0 res: %d\n", PT_CALL(dev0.ping())); + MODM_LOG_DEBUG.printf("[dev ] ping0 res: %d\n", dev0.ping()); MODM_LOG_DEBUG.printf("[dev ] ping1\n"); - MODM_LOG_DEBUG.printf("[dev ] ping1 res: %d\n", PT_CALL(dev1.ping())); + MODM_LOG_DEBUG.printf("[dev ] ping1 res: %d\n", dev1.ping()); MODM_LOG_DEBUG.printf("[dev ] ping2\n"); - MODM_LOG_DEBUG.printf("[dev ] ping2 res: %d\n", PT_CALL(dev2.ping())); + MODM_LOG_DEBUG.printf("[dev ] ping2 res: %d\n", dev2.ping()); MODM_LOG_DEBUG.printf("[dev ] ping3\n"); - MODM_LOG_DEBUG.printf("[dev ] ping3 res: %d\n", PT_CALL(dev3.ping())); + MODM_LOG_DEBUG.printf("[dev ] ping3 res: %d\n", dev3.ping()); // Do again in 1s - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(1s); } +}); - PT_END(); -} +modm::Fiber fiber_blink([] +{ + uint32_t counter{}; + while (true) + { + Board::Leds::toggle(); + MODM_LOG_INFO << "Loop counter: " << (counter++) << modm::endl; + modm::this_fiber::sleep_for(1s); + } +}); int main() @@ -115,22 +103,7 @@ main() modm::platform::I2cMaster1::connect(); modm::platform::I2cMaster1::initialize(); - constexpr std::chrono::milliseconds interval{1000}; - modm::ShortPeriodicTimer heartbeat{interval}; - - // Main loop - DeviceThread deviceThread; - - uint32_t counter(0); - while (true) - { - deviceThread.update(); - - if (heartbeat.execute()) { - Board::Leds::toggle(); - MODM_LOG_INFO << "Loop counter: " << (counter++) << modm::endl; - } - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/generic/i2c_multiplex/project.xml b/examples/generic/i2c_multiplex/project.xml index 46757ef9db..5df4462f19 100644 --- a/examples/generic/i2c_multiplex/project.xml +++ b/examples/generic/i2c_multiplex/project.xml @@ -1,9 +1,7 @@ - ../../../src/modm/board/nucleo_f303k8/board.xml + modm:nucleo-f303k8 - - @@ -13,9 +11,7 @@ :driver:pca9548a :platform:i2c:1 :platform:uart:2 - :processing:protothread - :processing:resumable - :processing:timer + :processing:fiber :build:scons diff --git a/examples/generic/resumable/main.cpp b/examples/generic/resumable/main.cpp deleted file mode 100644 index a8cfec5291..0000000000 --- a/examples/generic/resumable/main.cpp +++ /dev/null @@ -1,87 +0,0 @@ -/* - * Copyright (c) 2017, Sascha Schade - * - * This file is part of the modm project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ - -#include -#include -#include - -using Led = Board::LedGreen; - -using namespace std::chrono_literals; - -class BlinkingLight : public modm::pt::Protothread, private modm::NestedResumable<2> -{ -public: - bool - run() - { - PT_BEGIN(); - - // set everything up - Led::setOutput(); - Led::set(); - - while (true) - { - Led::set(); - PT_CALL(waitForTimer()); - - Led::reset(); - PT_CALL(setTimer(200ms)); - - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - - modm::ResumableResult - waitForTimer() - { - RF_BEGIN(); - - // nested calling is allowed - if (RF_CALL(setTimer(100ms))) - { - RF_WAIT_UNTIL(timeout.isExpired()); - RF_RETURN(true); - } - - RF_END_RETURN(false); - } - - modm::ResumableResult - setTimer(std::chrono::milliseconds new_timeout) - { - RF_BEGIN(); - - timeout.restart(new_timeout); - - if(timeout.isArmed()) { - RF_RETURN(true); - } - - // clean up code goes here - - RF_END_RETURN(false); - } - -private: - modm::ShortTimeout timeout; -}; - -BlinkingLight light; - -int main(void) -{ - while (true) { - light.run(); - } -} diff --git a/examples/generic/resumable/project.xml b/examples/generic/resumable/project.xml deleted file mode 100644 index c04c67c333..0000000000 --- a/examples/generic/resumable/project.xml +++ /dev/null @@ -1,13 +0,0 @@ - - modm:nucleo-l476rg - - - - - modm:architecture:delay - modm:processing:protothread - modm:processing:resumable - modm:processing:timer - modm:build:scons - - diff --git a/examples/generic/ros/environment/main.cpp b/examples/generic/ros/environment/main.cpp index e27aea7187..bba80c7ea8 100644 --- a/examples/generic/ros/environment/main.cpp +++ b/examples/generic/ros/environment/main.cpp @@ -45,6 +45,14 @@ namespace ros } ros::ModmNodeHandle nh; +modm::Fiber fiber_ros([] +{ + while (true) + { + nh.spinOnce(); + modm::this_fiber::yield(); + } +}); sensor_msgs::Temperature temperature_msg; sensor_msgs::FluidPressure pressure_msg; @@ -54,6 +62,50 @@ ros::Publisher pub_temperature("/environment/temperature", &temperature_ms ros::Publisher pub_pressure ("/environment/pressure", &pressure_msg); ros::Publisher pub_humidity ("/environment/relative_humidity", &humidity_msg); +Bme280Thread bme280thread; +DisplayThread display_thread; + +modm::Fiber fiber_display([] +{ + modm::ShortPeriodicTimer timer(1s); + while(true) + { + timer.wait(); + bme280thread.startMeasurement(); + modm::this_fiber::poll([&]{ return bme280thread.isNewDataAvailable(); }); + + Board::LedGreen::toggle(); + int32_t temp = bme280thread.getTemperature(); + int32_t pres = bme280thread.getPressure(); + int32_t humi = bme280thread.getHumidity(); + + // Convert to standard ROS units. + temperature_msg.temperature = temp / 100.0; + temperature_msg.variance = 1.0; + temperature_msg.header.stamp = nh.now(); + + pressure_msg.fluid_pressure = pres / 1000.0; + pressure_msg.variance = 100; + pressure_msg.header.stamp = nh.now(); + + humidity_msg.relative_humidity = humi / 100000.0; + humidity_msg.variance = 0.03; + humidity_msg.header.stamp = nh.now(); + + pub_temperature.publish(&temperature_msg); + pub_pressure.publish(&pressure_msg); + pub_humidity.publish(&humidity_msg); + + display_thread.setSeq(temperature_msg.header.stamp.sec); + display_thread.setTemp(temp); + display_thread.setPres(pres); + display_thread.setHumi(humi); + + // Do not enable when STlink UART is used for rosserial + MODM_LOG_DEBUG.printf("Temp = %6.2f\n", temp / double(100.0)); + } +}); + // ---------------------------------------------------------------------------- int main() @@ -64,8 +116,8 @@ main() // Do not use it for logging because this will destroy ROS serial messages. Board::stlink::Uart::initialize(); - MyI2cMaster::connect(); - MyI2cMaster::initialize(); + MyI2cMaster::connect(); + MyI2cMaster::initialize(); Board::LedGreen::set(); @@ -75,59 +127,7 @@ main() nh.advertise(pub_pressure); nh.advertise(pub_humidity); - Bme280Thread bme280thread; - DisplayThread display_thread; - - modm::ShortPeriodicTimer timer(1s); - bool bme_sampling(false); - - while (true) - { - bme280thread.update(); - display_thread.update(); - - if (timer.execute()) - { - bme280thread.startMeasurement(); - bme_sampling = true; - } - - if (bme_sampling and bme280thread.isNewDataAvailable()) - { - bme_sampling = false; - Board::LedGreen::toggle(); - int32_t temp = bme280thread.getTemperature(); - int32_t pres = bme280thread.getPressure(); - int32_t humi = bme280thread.getHumidity(); - - // Convert to standard ROS units. - temperature_msg.temperature = temp / 100.0; - temperature_msg.variance = 1.0; - temperature_msg.header.stamp = nh.now(); - - pressure_msg.fluid_pressure = pres / 1000.0; - pressure_msg.variance = 100; - pressure_msg.header.stamp = nh.now(); - - humidity_msg.relative_humidity = humi / 100000.0; - humidity_msg.variance = 0.03; - humidity_msg.header.stamp = nh.now(); - - pub_temperature.publish(&temperature_msg); - pub_pressure.publish(&pressure_msg); - pub_humidity.publish(&humidity_msg); - - display_thread.setSeq(temperature_msg.header.stamp.sec); - display_thread.setTemp(temp); - display_thread.setPres(pres); - display_thread.setHumi(humi); - - // Do not enable when STlink UART is used for rosserial - MODM_LOG_DEBUG.printf("Temp = %6.2f\n", temp / double(100.0)); - } - - nh.spinOnce(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/generic/ros/environment/project.xml b/examples/generic/ros/environment/project.xml index db5f8c94a8..a7ce1829de 100644 --- a/examples/generic/ros/environment/project.xml +++ b/examples/generic/ros/environment/project.xml @@ -8,8 +8,7 @@ modm:driver:ssd1306 modm:ros modm:communication:ros - modm:processing:timer - modm:processing:protothread + modm:processing:fiber modm:platform:i2c:1 modm:build:scons modm:platform:heap diff --git a/examples/generic/ros/environment/thread_bme280.cpp b/examples/generic/ros/environment/thread_bme280.cpp index ea26af3086..274b2a197c 100644 --- a/examples/generic/ros/environment/thread_bme280.cpp +++ b/examples/generic/ros/environment/thread_bme280.cpp @@ -20,6 +20,7 @@ // ---------------------------------------------------------------------------- Bme280Thread::Bme280Thread() : + Fiber([this]{ this->update(); }), barometer(data, 0x76), start_measurement(false), new_data(false) @@ -34,11 +35,9 @@ Bme280Thread::startMeasurement() return true; } -bool +void Bme280Thread::update() { - PT_BEGIN(); - MODM_LOG_DEBUG << MODM_FILE_INFO; MODM_LOG_DEBUG << "Ping the BME280" << modm::endl; @@ -46,74 +45,66 @@ Bme280Thread::update() while(true) { // we wait until the task started - if (PT_CALL(barometer.ping())) + if (barometer.ping()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } // Configure the device until it responds while(true) { // we wait until the task started - if (PT_CALL(barometer.initialize())) + if (barometer.initialize()) break; // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); } MODM_LOG_DEBUG << MODM_FILE_INFO; MODM_LOG_DEBUG << "BME280 configured" << modm::endl; - { - static modm::bme280::Calibration &cal = data.getCalibration(); + const modm::bme280::Calibration &cal = data.getCalibration(); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG << "BME280 Calibration data is: " << modm::endl; - MODM_LOG_DEBUG.printf(" T1 %d\n", cal.T1); - MODM_LOG_DEBUG.printf(" T2 %d\n", cal.T2); - MODM_LOG_DEBUG.printf(" T3 %d\n", cal.T3); - MODM_LOG_DEBUG.printf(" P1 %d\n", cal.P1); - MODM_LOG_DEBUG.printf(" P2 %d\n", cal.P2); - MODM_LOG_DEBUG.printf(" P3 %d\n", cal.P3); - MODM_LOG_DEBUG.printf(" P4 %d\n", cal.P4); - MODM_LOG_DEBUG.printf(" P5 %d\n", cal.P5); - MODM_LOG_DEBUG.printf(" P6 %d\n", cal.P6); - MODM_LOG_DEBUG.printf(" P7 %d\n", cal.P7); - MODM_LOG_DEBUG.printf(" P8 %d\n", cal.P8); - MODM_LOG_DEBUG.printf(" P9 %d\n", cal.P9); - MODM_LOG_DEBUG.printf(" H1 %d\n", cal.H1); - MODM_LOG_DEBUG.printf(" H2 %d\n", cal.H2); - MODM_LOG_DEBUG.printf(" H3 %d\n", cal.H3); - MODM_LOG_DEBUG.printf(" H4 %d\n", cal.H4); - MODM_LOG_DEBUG.printf(" H5 %d\n", cal.H5); - MODM_LOG_DEBUG.printf(" H6 %d\n", cal.H6); - } + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG << "BME280 Calibration data is: " << modm::endl; + MODM_LOG_DEBUG.printf(" T1 %d\n", cal.T1); + MODM_LOG_DEBUG.printf(" T2 %d\n", cal.T2); + MODM_LOG_DEBUG.printf(" T3 %d\n", cal.T3); + MODM_LOG_DEBUG.printf(" P1 %d\n", cal.P1); + MODM_LOG_DEBUG.printf(" P2 %d\n", cal.P2); + MODM_LOG_DEBUG.printf(" P3 %d\n", cal.P3); + MODM_LOG_DEBUG.printf(" P4 %d\n", cal.P4); + MODM_LOG_DEBUG.printf(" P5 %d\n", cal.P5); + MODM_LOG_DEBUG.printf(" P6 %d\n", cal.P6); + MODM_LOG_DEBUG.printf(" P7 %d\n", cal.P7); + MODM_LOG_DEBUG.printf(" P8 %d\n", cal.P8); + MODM_LOG_DEBUG.printf(" P9 %d\n", cal.P9); + MODM_LOG_DEBUG.printf(" H1 %d\n", cal.H1); + MODM_LOG_DEBUG.printf(" H2 %d\n", cal.H2); + MODM_LOG_DEBUG.printf(" H3 %d\n", cal.H3); + MODM_LOG_DEBUG.printf(" H4 %d\n", cal.H4); + MODM_LOG_DEBUG.printf(" H5 %d\n", cal.H5); + MODM_LOG_DEBUG.printf(" H6 %d\n", cal.H6); while (true) { - PT_WAIT_UNTIL(start_measurement); + modm::this_fiber::poll([&]{ return start_measurement; }); // Returns when new data was read from the sensor - PT_CALL(barometer.readout()); + barometer.readout(); new_data = true; - { - int32_t temp = data.getTemperature(); - int32_t press = data.getPressure(); - int32_t hum = data.getHumidity(); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated temperature in 0.01 degree Celsius is: %" PRId32 "\n", temp ); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated pressure in mPa is : %" PRId32 "\n", press ); - MODM_LOG_DEBUG << MODM_FILE_INFO; - MODM_LOG_DEBUG.printf("BME280: Calibrated humidity in 0.001 %% is : %" PRId32 "\n", hum ); - } + int32_t temp = data.getTemperature(); + int32_t press = data.getPressure(); + int32_t hum = data.getHumidity(); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated temperature in 0.01 degree Celsius is: %" PRId32 "\n", temp ); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated pressure in mPa is : %" PRId32 "\n", press ); + MODM_LOG_DEBUG << MODM_FILE_INFO; + MODM_LOG_DEBUG.printf("BME280: Calibrated humidity in 0.001 %% is : %" PRId32 "\n", hum ); start_measurement = false; } - - PT_END(); } diff --git a/examples/generic/ros/environment/thread_bme280.hpp b/examples/generic/ros/environment/thread_bme280.hpp index 922c595ca6..1c2da163e0 100644 --- a/examples/generic/ros/environment/thread_bme280.hpp +++ b/examples/generic/ros/environment/thread_bme280.hpp @@ -11,19 +11,18 @@ #ifndef THREAD_BME280 #define THREAD_BME280 -#include -#include +#include #include #include "hardware.hpp" -class Bme280Thread: public modm::pt::Protothread +class Bme280Thread: public modm::Fiber<> { public: Bme280Thread(); - bool + void update(); bool @@ -50,8 +49,6 @@ class Bme280Thread: public modm::pt::Protothread } private: - modm::ShortTimeout timeout; - modm::bme280::Data data; modm::Bme280 barometer; diff --git a/examples/generic/ros/environment/thread_display.cpp b/examples/generic/ros/environment/thread_display.cpp index 1ebd624621..d96d565f9f 100644 --- a/examples/generic/ros/environment/thread_display.cpp +++ b/examples/generic/ros/environment/thread_display.cpp @@ -21,18 +21,16 @@ // ---------------------------------------------------------------------------- DisplayThread::DisplayThread() : + Fiber([this]{ this->update(); }), _dirty(true), _seq(0), _temp(0), _pres(0), _humi(0) { } -bool +void DisplayThread::update() { - PT_BEGIN(); - // Wait for 100 msec unitl display powered up. - boot_timeout.restart(100ms); - PT_WAIT_UNTIL(boot_timeout.isExpired()); + modm::this_fiber::sleep_for(100ms); display.initializeBlocking(); display.setFont(modm::font::Assertion); @@ -42,7 +40,7 @@ DisplayThread::update() while(true) { - PT_WAIT_UNTIL(_dirty); + modm::this_fiber::poll([&]{ return _dirty; }); display.clear(); @@ -54,6 +52,4 @@ DisplayThread::update() _dirty = false; } - - PT_END(); -} \ No newline at end of file +} diff --git a/examples/generic/ros/environment/thread_display.hpp b/examples/generic/ros/environment/thread_display.hpp index 15440cfa12..95de48f3f2 100644 --- a/examples/generic/ros/environment/thread_display.hpp +++ b/examples/generic/ros/environment/thread_display.hpp @@ -11,19 +11,18 @@ #ifndef THREAD_DISPLAY #define THREAD_DISPLAY -#include -#include +#include #include #include "hardware.hpp" -class DisplayThread: public modm::pt::Protothread +class DisplayThread: public modm::Fiber<> { public: DisplayThread(); - bool + void update(); bool @@ -56,7 +55,6 @@ class DisplayThread: public modm::pt::Protothread protected: modm::Ssd1306 display; - modm::ShortTimeout boot_timeout; bool _dirty; int32_t _seq; int32_t _temp; diff --git a/examples/linux/block_device/file/main.cpp b/examples/linux/block_device/file/main.cpp index 42f7cda13b..bde39b9f5b 100644 --- a/examples/linux/block_device/file/main.cpp +++ b/examples/linux/block_device/file/main.cpp @@ -54,12 +54,12 @@ main() modm::BdFile storageDevice; - if(!RF_CALL_BLOCKING(storageDevice.initialize())) { + if(!storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; exit(1); } - if(!RF_CALL_BLOCKING(storageDevice.erase(0, MemorySize))) { + if(!storageDevice.erase(0, MemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; exit(1); } @@ -70,14 +70,14 @@ main() uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.write(pattern, i, BlockSize))) { + if(!storageDevice.write(pattern, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; exit(1); } } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.read(bufferC, i, BlockSize))) { + if(!storageDevice.read(bufferC, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; exit(1); } diff --git a/examples/linux/block_device/mirror/main.cpp b/examples/linux/block_device/mirror/main.cpp index 3abe172338..36053142cb 100644 --- a/examples/linux/block_device/mirror/main.cpp +++ b/examples/linux/block_device/mirror/main.cpp @@ -62,7 +62,7 @@ main() modm::BdMirror, modm::BdFile> storageDevice; - if(!RF_CALL_BLOCKING(storageDevice.initialize())) { + if(!storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; exit(1); } @@ -72,20 +72,20 @@ main() for(uint16_t iteration = 0; iteration < 10; iteration++) { uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; - if(!RF_CALL_BLOCKING(storageDevice.erase(0, MemorySize))) { + if(!storageDevice.erase(0, MemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; exit(1); } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.program(pattern, i, BlockSize))) { + if(!storageDevice.program(pattern, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; exit(1); } } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.read(bufferC, i, BlockSize))) { + if(!storageDevice.read(bufferC, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; exit(1); } diff --git a/examples/linux/block_device/ram/main.cpp b/examples/linux/block_device/ram/main.cpp index d6f2dfd2ca..8c82903cb7 100644 --- a/examples/linux/block_device/ram/main.cpp +++ b/examples/linux/block_device/ram/main.cpp @@ -45,11 +45,11 @@ main() std::memset(bufferB, 0x55, BlockSize); modm::BdHeap storageDevice; - if(!RF_CALL_BLOCKING(storageDevice.initialize())) { + if(!storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; exit(1); } - RF_CALL_BLOCKING(storageDevice.erase(0, MemorySize)); + storageDevice.erase(0, MemorySize); MODM_LOG_INFO << "Starting memory test!" << modm::endl; @@ -57,14 +57,14 @@ main() uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.write(pattern, i, BlockSize))) { + if(!storageDevice.write(pattern, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; exit(1); } } for(uint32_t i = 0; i < MemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.read(bufferC, i, BlockSize))) { + if(!storageDevice.read(bufferC, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; exit(1); } diff --git a/examples/nucleo_f042k6/lis3mdl/main.cpp b/examples/nucleo_f042k6/lis3mdl/main.cpp index 461a11c476..7a95e5a811 100644 --- a/examples/nucleo_f042k6/lis3mdl/main.cpp +++ b/examples/nucleo_f042k6/lis3mdl/main.cpp @@ -32,18 +32,14 @@ main() modm::Lis3mdl sensor(0x1E); // Turn on and configure the magnetometer - bool success = RF_CALL_BLOCKING(sensor.configure(modm::lis3mdl::DataRate::Rate_5_Hz, - modm::lis3mdl::Scale::Scale_8_gauss)); - - - if(!success) + if(not sensor.configure(modm::lis3mdl::DataRate::Rate_5_Hz, + modm::lis3mdl::Scale::Scale_8_gauss)) { MODM_LOG_INFO << "Sensor could not be configured!" << modm::endl; } // Set the sensor to continous acquistion and turn on the temperature sensing - success = RF_CALL_BLOCKING(sensor.setMode(modm::lis3mdl::OperationMode::Continous)); - if(!success) + if(not sensor.setMode(modm::lis3mdl::OperationMode::Continous)) { MODM_LOG_INFO << "Sensor could not be started!" << modm::endl; } @@ -53,7 +49,7 @@ main() while (true) { //Read the sensor data and print it out - success = RF_CALL_BLOCKING(sensor.readMagnetometer(magVector)); + success = sensor.readMagnetometer(magVector); if(success) { diff --git a/examples/nucleo_f042k6/lp503x/main.cpp b/examples/nucleo_f042k6/lp503x/main.cpp index 3245db712a..1852a35660 100644 --- a/examples/nucleo_f042k6/lp503x/main.cpp +++ b/examples/nucleo_f042k6/lp503x/main.cpp @@ -43,13 +43,13 @@ main() LedEnable::set(); // Initialize and enable chip - RF_CALL_BLOCKING(leds.initialize()); - RF_CALL_BLOCKING(leds.enable()); + leds.initialize(); + leds.enable(); // Turn on all leds with increasing brightness for(uint8_t channel = 0; channel < 36; ++channel) { const uint8_t brightness = (channel + 1) * 7; - RF_CALL_BLOCKING(leds.setChannelBrightness(channel, brightness)); + leds.setChannelBrightness(channel, brightness); } modm::delay(1s); @@ -57,18 +57,18 @@ main() // Configure outputs 0-5 (rgb led 0-1) in bank mode using LedBankMode = modm::lp503x::LedBankMode; const auto bankLeds = LedBankMode::Led0 | LedBankMode::Led1; - RF_CALL_BLOCKING(leds.setBankModeEnabled(bankLeds)); + leds.setBankModeEnabled(bankLeds); // Set bank leds to full brightness - RF_CALL_BLOCKING(leds.setBankABrightness(255)); - RF_CALL_BLOCKING(leds.setBankBBrightness(255)); - RF_CALL_BLOCKING(leds.setBankCBrightness(255)); + leds.setBankABrightness(255); + leds.setBankBBrightness(255); + leds.setBankCBrightness(255); // Blink leds in bank mode while(true) { - RF_CALL_BLOCKING(leds.setBankBrightness(255)); + leds.setBankBrightness(255); modm::delay(0.5s); - RF_CALL_BLOCKING(leds.setBankBrightness(0)); + leds.setBankBrightness(0); modm::delay(0.5s); } } diff --git a/examples/nucleo_f042k6/lsm6ds33/main.cpp b/examples/nucleo_f042k6/lsm6ds33/main.cpp index 0c839f9d24..aea08e4401 100644 --- a/examples/nucleo_f042k6/lsm6ds33/main.cpp +++ b/examples/nucleo_f042k6/lsm6ds33/main.cpp @@ -32,11 +32,11 @@ main() modm::Lsm6ds33 sensor(0x6B); // Turn on and configure the acceleration sensor - bool accSuccess = RF_CALL_BLOCKING(sensor.configureAccelerationSensor(modm::lsm6ds33::AccDataRate::Rate_13_Hz, - modm::lsm6ds33::AccScale::Scale_16_G)); + bool accSuccess = sensor.configureAccelerationSensor(modm::lsm6ds33::AccDataRate::Rate_13_Hz, + modm::lsm6ds33::AccScale::Scale_16_G); // Turn on and configure the gyroscope - bool gyroSuccess = RF_CALL_BLOCKING(sensor.configureGyroscope(modm::lsm6ds33::GyroDataRate::Rate_13_Hz, - modm::lsm6ds33::GyroScale::Scale_125_dps)); + bool gyroSuccess = sensor.configureGyroscope(modm::lsm6ds33::GyroDataRate::Rate_13_Hz, + modm::lsm6ds33::GyroScale::Scale_125_dps); if(!(accSuccess && gyroSuccess)) { @@ -49,8 +49,8 @@ main() while (true) { //Read the sensor data and print it out - accSuccess = RF_CALL_BLOCKING(sensor.readAcceleration(accVector)); - gyroSuccess = RF_CALL_BLOCKING(sensor.readGyroscope(gyroVector)); + accSuccess = sensor.readAcceleration(accVector); + gyroSuccess = sensor.readGyroscope(gyroVector); if(accSuccess && gyroSuccess) { MODM_LOG_INFO << "Acceleration Vector:" << modm::endl; @@ -64,7 +64,6 @@ main() MODM_LOG_INFO << "Y: "<< gyroVector.y << " deg/s" << modm::endl; MODM_LOG_INFO << "Z: "<< gyroVector.z << " deg/s" << modm::endl; MODM_LOG_INFO << modm::endl; - } else { diff --git a/examples/nucleo_f042k6/ms5837/main.cpp b/examples/nucleo_f042k6/ms5837/main.cpp index 5befdf22bb..a048027ad9 100644 --- a/examples/nucleo_f042k6/ms5837/main.cpp +++ b/examples/nucleo_f042k6/ms5837/main.cpp @@ -37,7 +37,7 @@ main() float press_f, temp_f; // Turn on and configure the pressure sensor - bool success = RF_CALL_BLOCKING(sensor.initialize()); + bool success = sensor.initialize(); if(!success) { @@ -47,7 +47,7 @@ main() while (true) { //Read the sensor data and print it out - success = RF_CALL_BLOCKING(sensor.readout()); + success = sensor.readout(); if(success) { diff --git a/examples/nucleo_f042k6/tmp12x/main.cpp b/examples/nucleo_f042k6/tmp12x/main.cpp index 0b30ebf4b3..221a171b9a 100644 --- a/examples/nucleo_f042k6/tmp12x/main.cpp +++ b/examples/nucleo_f042k6/tmp12x/main.cpp @@ -43,7 +43,7 @@ main() modm::PeriodicTimer timer{500ms}; while(true) { if (timer.execute()) { - const modm::Tmp123Temperature temperature = RF_CALL_BLOCKING(sensor.read()); + const modm::Tmp123Temperature temperature = sensor.read(); MODM_LOG_INFO.printf("Temperature %2.2f\n", (double)temperature.getTemperatureFloat()); } } diff --git a/examples/nucleo_f103rb/stts22h/main.cpp b/examples/nucleo_f103rb/stts22h/main.cpp index 5286683e66..9106ae3914 100644 --- a/examples/nucleo_f103rb/stts22h/main.cpp +++ b/examples/nucleo_f103rb/stts22h/main.cpp @@ -32,7 +32,7 @@ main() modm::stts22h::Data data{}; modm::Stts22h sensor{data, 0x3f}; - bool success = RF_CALL_BLOCKING(sensor.initialize()); + bool success = sensor.initialize(); if(!success) { MODM_LOG_ERROR << "Initialization failed" << modm::endl; @@ -45,7 +45,7 @@ main() { LedD13::toggle(); - RF_CALL_BLOCKING(sensor.readTemperature()); + sensor.readTemperature(); MODM_LOG_INFO << "temperature: " << data.getTemperatureFractional(); MODM_LOG_INFO << " [1/100th °C]" << modm::endl; } diff --git a/examples/nucleo_f303re/temperature_mcp990x/main.cpp b/examples/nucleo_f303re/temperature_mcp990x/main.cpp index 17f3cb7abc..8c448e766f 100644 --- a/examples/nucleo_f303re/temperature_mcp990x/main.cpp +++ b/examples/nucleo_f303re/temperature_mcp990x/main.cpp @@ -37,7 +37,7 @@ int main() // wait for sensor boot-up time modm::delay(15ms); - bool success = RF_CALL_BLOCKING(sensor.initialize()); + bool success = sensor.initialize(); if (!success) { MODM_LOG_ERROR << "Initialization failed" << modm::endl; @@ -48,7 +48,7 @@ int main() { if (timer.execute()) { - if (RF_CALL_BLOCKING(sensor.readInternalTemperature())) + if (sensor.readInternalTemperature()) { MODM_LOG_INFO.printf("temperature: %3.3f\n °C\n", (double)data.getTemperature()); } diff --git a/examples/nucleo_f401re/distance_vl53l0/main.cpp b/examples/nucleo_f401re/distance_vl53l0/main.cpp index 17505791d7..bf196a057d 100644 --- a/examples/nucleo_f401re/distance_vl53l0/main.cpp +++ b/examples/nucleo_f401re/distance_vl53l0/main.cpp @@ -14,7 +14,7 @@ #include #include -#include +#include #include #include @@ -45,112 +45,85 @@ modm::Vl53l0 distance(data); constexpr uint32_t MeasurementTimeFast = 30000; constexpr uint32_t MeasurementTimePrecision = 200000; -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_name([] { -public: - bool - update() - { - PT_BEGIN(); + using namespace modm::this_fiber; + MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; + // ping the device until it responds - // ping the device until it responds - while (true) - { - // we wait until the device started - if (PT_CALL(distance.ping())) { - break; - } - - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + while(not distance.ping()) sleep_for(100ms); + MODM_LOG_DEBUG << "Device responded" << modm::endl; - MODM_LOG_DEBUG << "Device responded" << modm::endl; + while(not distance.initialize()) sleep_for(100ms); + MODM_LOG_DEBUG << "Device initialized" << modm::endl; - while (true) - { - if (PT_CALL(distance.initialize())) { - break; - } + // set measurement time to 200ms (high accuracy mode) + bool highAccuracyMode = distance.setMaxMeasurementTime(MeasurementTimePrecision); + if(not highAccuracyMode) { + MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; + } - // otherwise, try again in 200ms - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + modm::ShortPeriodicTimer timer(1s); - MODM_LOG_DEBUG << "Device initialized" << modm::endl; + while (true) + { + modm::Timestamp stamp = modm::Clock::now(); - // set measurement time to 200ms (high accuracy mode) - if(not PT_CALL(distance.setMaxMeasurementTime(MeasurementTimePrecision))) { - MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; - } else { - this->highAccuracyMode = true; + if (distance.readDistance()) + { + modm::vl53l0::RangeErrorCode error = distance.getRangeError(); + if (distance.getData().isValid()) + { + uint16_t mm = distance.getData().getDistance(); + MODM_LOG_DEBUG << "mm: " << mm; + } + else + { + MODM_LOG_DEBUG << "Error: " << static_cast(error); + } } + MODM_LOG_DEBUG << ", t = " << (modm::Clock::now() - stamp) << "ms" << modm::endl; - timeout.restart(1s); - - while (true) + // query button state every 1s + if(timer.execute()) { - stamp = modm::Clock::now(); - - if (PT_CALL(distance.readDistance())) + // toggle between fast and high accuracy mode when button is pressed + if(Button::read()) { - modm::vl53l0::RangeErrorCode error = distance.getRangeError(); - if (distance.getData().isValid()) + if(highAccuracyMode) { - uint16_t mm = distance.getData().getDistance(); - MODM_LOG_DEBUG << "mm: " << mm; + if(distance.setMaxMeasurementTime(MeasurementTimeFast)) { + MODM_LOG_DEBUG << "Enable fast mode" << modm::endl; + highAccuracyMode = false; + } else { + MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; + } } else { - MODM_LOG_DEBUG << "Error: " << static_cast(error); - } - } - MODM_LOG_DEBUG << ", t = " << (modm::Clock::now() - stamp) << "ms" << modm::endl; - - // query button state every 1s - if(timeout.isExpired()) - { - // toggle between fast and high accuracy mode when button is pressed - if(Button::read()) - { - if(this->highAccuracyMode) - { - if(PT_CALL(distance.setMaxMeasurementTime(MeasurementTimeFast))) { - MODM_LOG_DEBUG << "Enable fast mode" << modm::endl; - this->highAccuracyMode = false; - } else { - MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; - } - } - else - { - if(PT_CALL(distance.setMaxMeasurementTime(MeasurementTimePrecision))) { - MODM_LOG_DEBUG << "Enable high accuracy mode" << modm::endl; - this->highAccuracyMode = true; - } else { - MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; - } + if(distance.setMaxMeasurementTime(MeasurementTimePrecision)) { + MODM_LOG_DEBUG << "Enable high accuracy mode" << modm::endl; + highAccuracyMode = true; + } else { + MODM_LOG_DEBUG << "Setting measurement time failed" << modm::endl; } } - - timeout.restart(1s); } } - PT_END(); + sleep_for(100ms); } +}); -private: - modm::ShortTimeout timeout; - modm::Timestamp stamp; - bool highAccuracyMode = true; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + while(true) + { + LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int @@ -164,16 +137,7 @@ main() MODM_LOG_INFO << "\n\nWelcome to VL53L0X demo!\n\n"; - modm::ShortPeriodicTimer tmr(500ms); - - while (true) - { - one.update(); - if(tmr.execute()) { - LedD13::toggle(); - } - - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_f401re/distance_vl53l0/project.xml b/examples/nucleo_f401re/distance_vl53l0/project.xml index e06a51f19f..76b76481cc 100644 --- a/examples/nucleo_f401re/distance_vl53l0/project.xml +++ b/examples/nucleo_f401re/distance_vl53l0/project.xml @@ -8,7 +8,7 @@ modm:driver:vl53l0 modm:platform:gpio modm:platform:i2c:1 - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/nucleo_f401re/dw3110-communication/main.cpp b/examples/nucleo_f401re/dw3110-communication/main.cpp index 7667be9aab..3b11b5c929 100644 --- a/examples/nucleo_f401re/dw3110-communication/main.cpp +++ b/examples/nucleo_f401re/dw3110-communication/main.cpp @@ -13,8 +13,7 @@ #include #include #include -#include -#include +#include using namespace Board; using namespace std::chrono_literals; @@ -23,101 +22,107 @@ using MySpiMaster = modm::platform::SpiMaster1; using MyDw3110_a = modm::Dw3110Phy; using MyDw3110_b = modm::Dw3110Phy; -class TXThread : public modm::pt::Protothread +class TXThread : public modm::Fiber<> { public: + TXThread() : Fiber([this]{ run(); }) {} + bool init() { - auto ret = RF_CALL_BLOCKING(radio.initialize( + auto ret = radio.initialize( modm::Dw3110::Channel::Channel9, modm::Dw3110::PreambleCode::Code_64Mhz_9, modm::Dw3110::PreambleLength::Preamble_128, - modm::Dw3110::StartFrameDelimiter::Decawave_8)); - RF_CALL_BLOCKING(radio.setEnableLongFrames(true)); + modm::Dw3110::StartFrameDelimiter::Decawave_8); + radio.setEnableLongFrames(true); return ret; } + size_t + getCount() + { + return sentCount; + } + +private: bool run() { - PT_BEGIN(); while (true) { txdata[txdata.size() - 1]++; - timeout.restart(Button::read() ? 500ms : 10ms); - PT_WAIT_UNTIL(timeout.execute()); - if (PT_CALL(radio.transmit(txdata, true)) == MyDw3110_b::Error::None) - { + modm::this_fiber::sleep_for(Button::read() ? 500ms : 10ms); + + if (radio.transmit(txdata, true) == MyDw3110_b::Error::None) { sentCount++; - } else - { + } else { MODM_LOG_DEBUG << "[TX] Failed to trasmit!" << modm::endl; } } - PT_END(); } - size_t - getCount() - { - return sentCount; - } - -private: MyDw3110_b radio{}; std::array txdata = {0xBA, 0xDE, 0xAF, 0xFE, 0x00}; modm::Timeout timeout{10ms}; size_t sentCount{0}; -}; +} tx; -class RXThread : public modm::pt::Protothread +class RXThread : public modm::Fiber<> { public: + RXThread() : Fiber([this]{ run(); }) {} + bool init() { - auto ret = RF_CALL_BLOCKING(radio.initialize( + auto ret = radio.initialize( modm::Dw3110::Channel::Channel9, modm::Dw3110::PreambleCode::Code_64Mhz_9, modm::Dw3110::PreambleLength::Preamble_128, - modm::Dw3110::StartFrameDelimiter::Decawave_8)); - RF_CALL_BLOCKING(radio.setEnableLongFrames(true)); + modm::Dw3110::StartFrameDelimiter::Decawave_8); + radio.setEnableLongFrames(true); return ret; } + size_t + getCount() + { + return recvCount; + } + +private: bool run() { - PT_BEGIN(); while (true) { - while (!PT_CALL(radio.packetReady())) + while (not radio.packetReady()) { - if (!PT_CALL(radio.isReceiving())) - { - // KEEP ON SEPERATE LINE - PT_CALL(radio.startReceive()); - } - PT_YIELD(); + if (not radio.isReceiving()) + radio.startReceive(); + modm::this_fiber::yield(); } - if (PT_CALL(radio.fetchPacket(rxdata, rxlen))) { recvCount++; } + if (radio.fetchPacket(rxdata, rxlen)) recvCount++; + modm::this_fiber::yield(); } - PT_END(); } - size_t - getCount() - { - return recvCount; - } - -private: constexpr static size_t RxBufferSize = 1021; // Maximum supported packet size MyDw3110_a radio{}; size_t rxlen{0}, recvCount{0}; std::array rxdata = {}; -}; +} rx; + +modm::Fiber fiber_report([] +{ + while(true) + { + modm::this_fiber::sleep_for(1s); + MODM_LOG_DEBUG << "Sent " << tx.getCount() << ", received " << rx.getCount() + << ". Diff:" << tx.getCount() - rx.getCount() << modm::endl; + } +}); int main() @@ -137,34 +142,20 @@ main() MODM_LOG_INFO << "Initializing Devices..." << modm::endl; bool success = true; - TXThread tx; - if (!tx.init()) + if (not tx.init()) { MODM_LOG_ERROR << "Failed to initialize TX Device!" << modm::endl; success = false; } - - RXThread rx; - if (!rx.init()) + if (not rx.init()) { MODM_LOG_ERROR << "Failed to initialize TR Device!" << modm::endl; success = false; } - if (!success) - while (true) { __NOP(); } + modm_assert(success, "user", "Failed to initialize devices!"); - modm::PeriodicTimer timer{1000ms}; MODM_LOG_INFO << "Starting ping pong..." << modm::endl; - while (true) - { - rx.run(); - tx.run(); - if (timer.execute()) - { - MODM_LOG_DEBUG << "Sent " << tx.getCount() << ", received " << rx.getCount() - << ". Diff:" << tx.getCount() - rx.getCount() << modm::endl; - } - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_f401re/dw3110-communication/project.xml b/examples/nucleo_f401re/dw3110-communication/project.xml index c4d4d61ed7..be4d795176 100644 --- a/examples/nucleo_f401re/dw3110-communication/project.xml +++ b/examples/nucleo_f401re/dw3110-communication/project.xml @@ -7,6 +7,6 @@ modm:build:scons modm:driver:dw3110 modm:platform:spi:1 - modm:processing:protothread + modm:processing:fiber diff --git a/examples/nucleo_f411re/imu_bno055/main.cpp b/examples/nucleo_f411re/imu_bno055/main.cpp index 57a74788e9..212f647bec 100644 --- a/examples/nucleo_f411re/imu_bno055/main.cpp +++ b/examples/nucleo_f411re/imu_bno055/main.cpp @@ -39,81 +39,49 @@ using MyI2cMaster = I2cMaster1; modm::bno055::Data data; modm::Bno055 imu(data); -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_bno055([] { -public: - bool - update() - { - PT_BEGIN(); - - MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - - // ping the device until it responds - while (true) - { - // we wait until the device started - if (PT_CALL(imu.ping())) { - break; - } - PT_WAIT_UNTIL(timer.execute()); - } - - MODM_LOG_DEBUG << "Device responded" << modm::endl; - - while (true) - { - if (PT_CALL(imu.configure())) { - break; - } - - PT_WAIT_UNTIL(timer.execute()); - } + using namespace modm::this_fiber; + MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - MODM_LOG_DEBUG << "Device configured" << modm::endl; + // ping the device until it responds + while(not imu.ping()) sleep_for(100ms); + MODM_LOG_DEBUG << "Device responded" << modm::endl; - while (true) - { - PT_WAIT_UNTIL(timer.execute()); - PT_CALL(imu.readData()); - MODM_LOG_INFO << (int)imu.getData().heading() << modm::endl; - } + while(not imu.configure()) sleep_for(100ms); + MODM_LOG_DEBUG << "Device configured" << modm::endl; - PT_END(); + while (true) + { + sleep_for(100ms); + imu.readData(); + MODM_LOG_INFO << (int)imu.getData().heading() << modm::endl; } +}); -private: - modm::ShortPeriodicTimer timer{100ms}; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + LedD13::setOutput(); + while(true) + { + LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int main() { Board::initialize(); - LedD13::setOutput(); - // Board::D13::setOutput(modm::Gpio::Low); MyI2cMaster::connect(); MyI2cMaster::initialize(); MODM_LOG_INFO << "\n\nWelcome to BNO055 demo!\n\n" << modm::endl; - modm::ShortPeriodicTimer tmr(500ms); - - // Board::D15::setOutput(); - - while (true) - { - one.update(); - if(tmr.execute()) { - LedD13::toggle(); - // Board::D15::toggle(); - } - - } - + modm::fiber::Scheduler::run(); return 0; } + + diff --git a/examples/nucleo_f411re/imu_bno055/project.xml b/examples/nucleo_f411re/imu_bno055/project.xml index 146a01add6..7020753175 100644 --- a/examples/nucleo_f411re/imu_bno055/project.xml +++ b/examples/nucleo_f411re/imu_bno055/project.xml @@ -9,7 +9,7 @@ modm:platform:gpio modm:platform:i2c:1 modm:platform:i2c.bitbang - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/nucleo_f411re/sx1276_rx/main.cpp b/examples/nucleo_f411re/sx1276_rx/main.cpp index d09f857412..49258a2c31 100644 --- a/examples/nucleo_f411re/sx1276_rx/main.cpp +++ b/examples/nucleo_f411re/sx1276_rx/main.cpp @@ -45,19 +45,19 @@ main() Sx1276 loraModem; // Initialize the modem - RF_CALL_BLOCKING(loraModem.initialize()); + loraModem.initialize(); // Set Modulation Parameters - RF_CALL_BLOCKING(loraModem.setModemParams(sx1276::Bandwidth::BW_7, - sx1276::SpreadingFactor::SF_8, - sx1276::CodingRate::CR_4_8, - false, - false)); + loraModem.setModemParams(sx1276::Bandwidth::BW_7, + sx1276::SpreadingFactor::SF_8, + sx1276::CodingRate::CR_4_8, + false, + false); // Set Carrier Frequency - RF_CALL_BLOCKING(loraModem.setCarrierFrequency(433.920_MHz)); + loraModem.setCarrierFrequency(433.920_MHz); // Enable the continous listening mode - RF_CALL_BLOCKING(loraModem.enableListening()); + loraModem.enableListening(); //the variable to hold the counter transmitted by the tx example uint32_t rxCounter(0); @@ -65,16 +65,16 @@ main() while (true) { //check the modem if new data is available and read it - uint8_t bytesReceived = RF_CALL_BLOCKING(loraModem.readPacket(reinterpret_cast(&rxCounter),4)); + uint8_t bytesReceived = loraModem.readPacket(reinterpret_cast(&rxCounter),4); if(bytesReceived > 0) { - int8_t snr = RF_CALL_BLOCKING(loraModem.getPacketSnr()); + int8_t snr = loraModem.getPacketSnr(); //dirty fixed point numbers uint8_t snr_dec = (snr & 0x03) * 25; snr = snr >> 2; - int16_t rssi = RF_CALL_BLOCKING(loraModem.getPacketRssi()); + int16_t rssi = loraModem.getPacketRssi(); MODM_LOG_DEBUG << "Received Message" << modm::endl; MODM_LOG_DEBUG << "Counter Value: " << rxCounter << modm::endl; diff --git a/examples/nucleo_f411re/sx1276_tx/main.cpp b/examples/nucleo_f411re/sx1276_tx/main.cpp index 51141f1f55..3a7d21b54b 100644 --- a/examples/nucleo_f411re/sx1276_tx/main.cpp +++ b/examples/nucleo_f411re/sx1276_tx/main.cpp @@ -43,16 +43,16 @@ main() Sx1276 loraModem; // Initialize the modem - RF_CALL_BLOCKING(loraModem.initialize()); + loraModem.initialize(); // Set Modulation Parameters - RF_CALL_BLOCKING(loraModem.setModemParams(sx1276::Bandwidth::BW_7, - sx1276::SpreadingFactor::SF_8, - sx1276::CodingRate::CR_4_8, - false, - false)); + loraModem.setModemParams(sx1276::Bandwidth::BW_7, + sx1276::SpreadingFactor::SF_8, + sx1276::CodingRate::CR_4_8, + false, + false); // Set Carrier Frequency - RF_CALL_BLOCKING(loraModem.setCarrierFrequency(433.920_MHz)); + loraModem.setCarrierFrequency(433.920_MHz); //The message to be sent uint32_t counter(0); @@ -60,7 +60,7 @@ main() while (true) { MODM_LOG_INFO << "Trasmitting Message " << counter << modm::endl; - RF_CALL_BLOCKING(loraModem.transmit(reinterpret_cast(&counter),4)); + loraModem.transmit(reinterpret_cast(&counter),4); counter++; modm::delay(1000ms); } diff --git a/examples/nucleo_f429zi/adc_ads816x/main.cpp b/examples/nucleo_f429zi/adc_ads816x/main.cpp index a338477689..da0339fa0f 100644 --- a/examples/nucleo_f429zi/adc_ads816x/main.cpp +++ b/examples/nucleo_f429zi/adc_ads816x/main.cpp @@ -47,7 +47,7 @@ main() modm::delay(1ms); MODM_LOG_INFO << "Initializing ADC in manual mode..." << modm::endl; - RF_CALL_BLOCKING(adc.initialize(modm::ads816x::Mode::Manual)); + adc.initialize(modm::ads816x::Mode::Manual); adc.setTConv(3us); @@ -62,10 +62,10 @@ main() if (i == 0) { // Set channel 0 and 1 as next channels, throw away first two // conversion results - RF_CALL_BLOCKING(adc.manualModeConversion(0)); - RF_CALL_BLOCKING(adc.manualModeConversion(1)); + adc.manualModeConversion(0); + adc.manualModeConversion(1); } - uint16_t result = RF_CALL_BLOCKING(adc.manualModeConversion((i + 2) % 8)); + uint16_t result = adc.manualModeConversion((i + 2) % 8); MODM_LOG_INFO.printf(" %05u", result); } diff --git a/examples/nucleo_f429zi/imu_adis16470/main.cpp b/examples/nucleo_f429zi/imu_adis16470/main.cpp index 302bfe4902..5cfdb5062d 100644 --- a/examples/nucleo_f429zi/imu_adis16470/main.cpp +++ b/examples/nucleo_f429zi/imu_adis16470/main.cpp @@ -51,23 +51,23 @@ main() modm::delay(252ms); MODM_LOG_INFO << "Initializing IMU..." << modm::endl; - RF_CALL_BLOCKING(imu.initialize()); + imu.initialize(); // Software reset - RF_CALL_BLOCKING(imu.writeGlobCmd(modm::adis16470::GlobCmd::SoftwareReset)); + imu.writeGlobCmd(modm::adis16470::GlobCmd::SoftwareReset); // Wait start-up time after reset modm::delay(252ms); // Trigger self test - RF_CALL_BLOCKING(imu.writeGlobCmd(modm::adis16470::GlobCmd::SensorSelfTest)); + imu.writeGlobCmd(modm::adis16470::GlobCmd::SensorSelfTest); // Wait for self test to complete modm::delay(14ms); - modm::adis16470::DiagStat_t diagStat = RF_CALL_BLOCKING(imu.readDiagStat()); + modm::adis16470::DiagStat_t diagStat = imu.readDiagStat(); MODM_LOG_INFO << "Reading DIAG_STAT register = " << diagStat << modm::endl; modm::delay(1ms); - auto result = RF_CALL_BLOCKING(imu.readRegister(modm::adis16470::Register::PROD_ID)); + auto result = imu.readRegister(modm::adis16470::Register::PROD_ID); if (result.has_value()) { MODM_LOG_INFO << "ADIS16470 product id = " << *result << " (should be 16470==0x4056)" << modm::endl; } @@ -75,25 +75,25 @@ main() MODM_LOG_INFO << "Unable to reag PROD_ID register" << modm::endl; } - modm::adis16470::MscCtrl_t mscCtrl = RF_CALL_BLOCKING(imu.readMscCtrl()); + modm::adis16470::MscCtrl_t mscCtrl = imu.readMscCtrl(); MODM_LOG_INFO << "Reading MSC_CTRL register = " << mscCtrl << modm::endl; - RF_CALL_BLOCKING(imu.setDataOutputFrequency<10_Hz>()); + imu.setDataOutputFrequency<10_Hz>(); - RF_CALL_BLOCKING(imu.writeRegister(modm::adis16470::Register::FILT_CTRL, 8)); // N_B = 2^8 = 64 + imu.writeRegister(modm::adis16470::Register::FILT_CTRL, 8); // N_B = 2^8 = 64 mscCtrl = modm::adis16470::MscCtrl::DrPolarity | modm::adis16470::MscCtrl::PointOfPercussionAlign; MODM_LOG_INFO << "Writing MSC_CTRL register = " << mscCtrl << modm::endl; - RF_CALL_BLOCKING(imu.writeMscCtrl(mscCtrl)); + imu.writeMscCtrl(mscCtrl); - diagStat = RF_CALL_BLOCKING(imu.readDiagStat()); + diagStat = imu.readDiagStat(); MODM_LOG_INFO << "Reading DIAG_STAT register = " << diagStat << modm::endl; - mscCtrl = RF_CALL_BLOCKING(imu.readMscCtrl()); + mscCtrl = imu.readMscCtrl(); MODM_LOG_INFO << "Reading MSC_CTRL register = " << mscCtrl << modm::endl; // Writing and reading USER_SCR1 register - std::optional scr1 = RF_CALL_BLOCKING(imu.readRegister(modm::adis16470::Register::USER_SCR1)); + std::optional scr1 = imu.readRegister(modm::adis16470::Register::USER_SCR1); if (scr1.has_value()) { MODM_LOG_INFO << "Reading USER_SCR1 register = " << *scr1 << modm::endl; } @@ -101,8 +101,8 @@ main() MODM_LOG_INFO << "Unable to USER_SCR1 register." << modm::endl; } MODM_LOG_INFO << "Writing USER_SCR1 register = 42" << modm::endl; - RF_CALL_BLOCKING(imu.writeRegister(modm::adis16470::Register::USER_SCR1, 42)); - scr1 = RF_CALL_BLOCKING(imu.readRegister(modm::adis16470::Register::USER_SCR1)); + imu.writeRegister(modm::adis16470::Register::USER_SCR1, 42); + scr1 = imu.readRegister(modm::adis16470::Register::USER_SCR1); if (scr1.has_value()) { MODM_LOG_INFO << "Reading USER_SCR1 register = " << *scr1 << modm::endl; } @@ -119,7 +119,7 @@ main() while (!Dr::read()) {} while (Dr::read()) {} - if( !RF_CALL_BLOCKING(imu.readRegisterBurst(data))) { + if( !imu.readRegisterBurst(data)) { MODM_LOG_INFO.printf("checksum mismatch! "); Board::LedRed::toggle(); } diff --git a/examples/nucleo_f429zi/pat9125el/main.cpp b/examples/nucleo_f429zi/pat9125el/main.cpp index 7a4ea3ea36..999a0e1897 100644 --- a/examples/nucleo_f429zi/pat9125el/main.cpp +++ b/examples/nucleo_f429zi/pat9125el/main.cpp @@ -10,9 +10,7 @@ // ---------------------------------------------------------------------------- #include - -#include -#include +#include #include using I2c = I2cMaster1; @@ -22,58 +20,8 @@ using Sda = GpioB9; // int pin is optional, set to void for polling mode using Int = GpioInputA5; -class Thread : public modm::pt::Protothread -{ -public: - Thread() : sensor{0x75} - { - } - - bool - update() - { - PT_BEGIN(); - - MODM_LOG_INFO << "Ping device" << modm::endl; - // ping the device until it responds - while(true) - { - if (PT_CALL(sensor.ping())) { - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - MODM_LOG_INFO << "Ping successful" << modm::endl; - - // set x and y resolution - PT_CALL(sensor.configure(0x14, 0x14)); - - while (true) - { - PT_CALL(sensor.readData()); - if(sensor.hasMoved()) { - position += sensor.getData(); - - Board::Leds::write(0b111); - MODM_LOG_INFO << "Position: " << position.x << ", " << position.y << modm::endl; - sensor.resetMoved(); - } else { - Board::Leds::write(0b000); - } - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - modm::pat9125el::Motion2D position; - modm::Pat9125el, Int> sensor; -}; - -Thread thread; +modm::pat9125el::Motion2D position; +modm::Pat9125el, Int> sensor(0x75); // ---------------------------------------------------------------------------- int @@ -87,8 +35,26 @@ main() I2c::connect(); I2c::initialize(); - while (true) { - thread.update(); + MODM_LOG_INFO << "Ping device" << modm::endl; + while(not sensor.ping()) modm::delay(100ms); + MODM_LOG_INFO << "Ping successful" << modm::endl; + + // set x and y resolution + sensor.configure(0x14, 0x14); + + while (true) + { + sensor.readData(); + if(sensor.hasMoved()) + { + position += sensor.getData(); + + Board::Leds::write(0b111); + MODM_LOG_INFO << "Position: " << position.x << ", " << position.y << modm::endl; + sensor.resetMoved(); + } + else Board::Leds::write(0b000); + modm::delay(10ms); } return 0; diff --git a/examples/nucleo_f429zi/pat9125el/project.xml b/examples/nucleo_f429zi/pat9125el/project.xml index e0cc9fc9f0..0c5b0ec9fc 100644 --- a/examples/nucleo_f429zi/pat9125el/project.xml +++ b/examples/nucleo_f429zi/pat9125el/project.xml @@ -7,8 +7,6 @@ modm:driver:pat9125el modm:io modm:platform:i2c:1 - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/nucleo_f429zi/rtc_mcp7941x/main.cpp b/examples/nucleo_f429zi/rtc_mcp7941x/main.cpp index adedeeb98d..58081e734d 100644 --- a/examples/nucleo_f429zi/rtc_mcp7941x/main.cpp +++ b/examples/nucleo_f429zi/rtc_mcp7941x/main.cpp @@ -11,116 +11,97 @@ #include #include -#include -#include -#include +#include using MyI2cMaster = modm::platform::I2cMaster1; using I2cScl = modm::platform::GpioB8; using I2cSda = modm::platform::GpioB9; +modm::Mcp7941x rtc{}; -class RtcThread : public modm::pt::Protothread +modm::Fiber fiber_name([] { -public: - bool - update() - { - PT_BEGIN(); + if(rtc.oscillatorRunning()) { + MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + } + else { + MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + } - if(PT_CALL(rtc.oscillatorRunning())) { - MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; - } - else { - MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; - } + MODM_LOG_INFO << "Setting date/time to 01.01.2020 00:00.00h" << modm::endl; + modm::mcp7941x::DateTime dateTime{}; + dateTime.days = 1; + dateTime.months = 1; + dateTime.years = 20; + dateTime.hours = 0; + dateTime.minutes = 0; + dateTime.seconds = 0; + while(not rtc.setDateTime(dateTime)) { + MODM_LOG_ERROR << "Unable to set date/time." << modm::endl; + modm::this_fiber::sleep_for(500ms); + } - MODM_LOG_INFO << "Setting date/time to 01.01.2020 00:00.00h" << modm::endl; - dateTime.days = 1; - dateTime.months = 1; - dateTime.years = 20; - dateTime.hours = 0; - dateTime.minutes = 0; - dateTime.seconds = 0; - while(not PT_CALL(rtc.setDateTime(dateTime))) { - MODM_LOG_ERROR << "Unable to set date/time." << modm::endl; - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + modm::this_fiber::sleep_for(500ms); - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); + if(rtc.oscillatorRunning()) { + MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + } + else { + MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + } - if(PT_CALL(rtc.oscillatorRunning())) { - MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + while (true) + { + auto dateTime2 = rtc.getDateTime(); + if(dateTime2.has_value()) { + MODM_LOG_INFO.printf("%02u.%02u.%02u ", dateTime2->days, dateTime2->months, dateTime2->years); + MODM_LOG_INFO.printf("%02u:%02u.%02uh\n", dateTime2->hours, dateTime2->minutes, dateTime2->seconds); } else { - MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + MODM_LOG_ERROR << "Unable to read from RTC." << modm::endl; } - while (true) - { - dateTime2 = PT_CALL(rtc.getDateTime()); - if(dateTime2.has_value()) { - MODM_LOG_INFO.printf("%02u.%02u.%02u ", dateTime2->days, dateTime2->months, dateTime2->years); - MODM_LOG_INFO.printf("%02u:%02u.%02uh\n", dateTime2->hours, dateTime2->minutes, dateTime2->seconds); - } - else { - MODM_LOG_ERROR << "Unable to read from RTC." << modm::endl; - } - - timeout.restart(2500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); + modm::this_fiber::sleep_for(2.5s); } +}); -private: - modm::Mcp7941x rtc{}; - modm::mcp7941x::DateTime dateTime{}; - std::optional dateTime2{}; - modm::ShortTimeout timeout; -}; - - -using namespace Board; +modm::Fiber fiber_blink([] +{ + Board::LedGreen::setOutput(); + while(true) + { + Board::LedGreen::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() { Board::initialize(); - Leds::setOutput(); MyI2cMaster::connect(); - MyI2cMaster::initialize(); + MyI2cMaster::initialize(); MODM_LOG_INFO << "RTC MCP7941x Example on Nucleo-F429ZI" << modm::endl; modm::Mcp7941xEeprom eeprom{}; - if (auto data = RF_CALL_BLOCKING(eeprom.getUniqueId())) { - MODM_LOG_INFO << "Unique ID (EUI-48/64): "; - MODM_LOG_INFO << modm::hex << (*data)[0] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[1] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[2] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[3] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[4] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[5] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[6] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[7] << modm::ascii << modm::endl; + if (auto data = eeprom.getUniqueId()) { + MODM_LOG_INFO << "Unique ID (EUI-48/64): " << modm::hex; + MODM_LOG_INFO << (*data)[0] << ":"; + MODM_LOG_INFO << (*data)[1] << ":"; + MODM_LOG_INFO << (*data)[2] << ":"; + MODM_LOG_INFO << (*data)[3] << ":"; + MODM_LOG_INFO << (*data)[4] << ":"; + MODM_LOG_INFO << (*data)[5] << ":"; + MODM_LOG_INFO << (*data)[6] << ":"; + MODM_LOG_INFO << (*data)[7] << modm::endl; } else { MODM_LOG_ERROR << "Unable to read unique ID from RTC." << modm::endl; } modm::delay(500ms); - - RtcThread rtcThread; - - while (true) - { - LedGreen::toggle(); - rtcThread.update(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_f429zi/rtc_mcp7941x/project.xml b/examples/nucleo_f429zi/rtc_mcp7941x/project.xml index 7369a82fa4..163da9620d 100644 --- a/examples/nucleo_f429zi/rtc_mcp7941x/project.xml +++ b/examples/nucleo_f429zi/rtc_mcp7941x/project.xml @@ -7,8 +7,7 @@ modm:driver:mcp7941x modm:io modm:platform:i2c:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/nucleo_f429zi/spi_flash/main.cpp b/examples/nucleo_f429zi/spi_flash/main.cpp index d27b231fe2..566654e5d5 100644 --- a/examples/nucleo_f429zi/spi_flash/main.cpp +++ b/examples/nucleo_f429zi/spi_flash/main.cpp @@ -49,13 +49,13 @@ void doMemoryTest() for(uint16_t iteration = 0; iteration < 4; iteration++) { uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; - if(!RF_CALL_BLOCKING(storageDevice.erase(0, TestMemorySize))) { + if(!storageDevice.erase(0, TestMemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; return; } for(uint32_t i = 0; i < TestMemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.program(pattern, i, BlockSize))) { + if(!storageDevice.program(pattern, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; return; } @@ -63,7 +63,7 @@ void doMemoryTest() } for(uint32_t i = 0; i < TestMemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDevice.read(bufferC, i, BlockSize))) { + if(!storageDevice.read(bufferC, i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; return; } @@ -107,10 +107,10 @@ main() std::memset(bufferB, 0x55, BlockSize); bool initializeSuccess = false; - if (RF_CALL_BLOCKING(storageDevice.initialize())) { + if (storageDevice.initialize()) { MODM_LOG_INFO << "Erasing complete flash chip... (This may take a while)" << modm::endl; - if (RF_CALL_BLOCKING(storageDevice.erase(0, MemorySize))) { - RF_CALL_BLOCKING(storageDevice.waitWhileBusy()); + if (storageDevice.erase(0, MemorySize)) { + storageDevice.waitWhileBusy(); initializeSuccess = true; } else { MODM_LOG_INFO << "Error: Unable to erase device."; @@ -120,10 +120,10 @@ main() } if (initializeSuccess) { - auto id = RF_CALL_BLOCKING(storageDevice.readId()); + auto id = storageDevice.readId(); MODM_LOG_INFO << "deviceId=" << id.deviceId << " manufacturerId=" << id.manufacturerId; MODM_LOG_INFO << "deviceType=" << id.deviceType << modm::endl; - MODM_LOG_INFO << "status=" << static_cast(RF_CALL_BLOCKING(storageDevice.readStatus())) << modm::endl; + MODM_LOG_INFO << "status=" << static_cast(storageDevice.readStatus()) << modm::endl; MODM_LOG_INFO << "Press USER button to start the memory test." << modm::endl; } diff --git a/examples/nucleo_f429zi/spi_flash_fatfs/main.cpp b/examples/nucleo_f429zi/spi_flash_fatfs/main.cpp index 46dbe0e108..67466a5862 100644 --- a/examples/nucleo_f429zi/spi_flash_fatfs/main.cpp +++ b/examples/nucleo_f429zi/spi_flash_fatfs/main.cpp @@ -334,7 +334,5 @@ main() /* Check function/compatibility of the physical drive #0 */ modm::fiber::Scheduler::run(); - while (true); - return 0; } diff --git a/examples/nucleo_f429zi/spi_flash_fatfs/project.xml b/examples/nucleo_f429zi/spi_flash_fatfs/project.xml index ba04e1a17d..09f0b93edb 100644 --- a/examples/nucleo_f429zi/spi_flash_fatfs/project.xml +++ b/examples/nucleo_f429zi/spi_flash_fatfs/project.xml @@ -3,7 +3,6 @@ - modm:build:scons @@ -12,6 +11,5 @@ modm:platform:spi:1 modm:platform:gpio modm:processing:fiber - modm:processing:protothread diff --git a/examples/nucleo_f429zi/spistack_flash/main.cpp b/examples/nucleo_f429zi/spistack_flash/main.cpp index 82f0421cfa..af0c32f980 100644 --- a/examples/nucleo_f429zi/spistack_flash/main.cpp +++ b/examples/nucleo_f429zi/spistack_flash/main.cpp @@ -60,13 +60,13 @@ void doMemoryTest() auto dv = std::ldiv(address, DieSize); uint8_t* pattern = (iteration % 2 == dv.quot) ? bufferA : bufferB; - if(!RF_CALL_BLOCKING(storageDeviceStack.erase(address, TestMemorySize))) { + if(!storageDeviceStack.erase(address, TestMemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; return; } for(uint32_t i = 0; i < TestMemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDeviceStack.program(pattern, address + i, BlockSize))) { + if(!storageDeviceStack.program(pattern, address + i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; return; } @@ -79,7 +79,7 @@ void doMemoryTest() auto dv = std::ldiv(address, DieSize); uint8_t* pattern = (iteration % 2 == dv.quot) ? bufferA : bufferB; for(uint32_t i = 0; i < TestMemorySize; i += BlockSize) { - if(!RF_CALL_BLOCKING(storageDeviceStack.read(bufferC, address + i, BlockSize))) { + if(!storageDeviceStack.read(bufferC, address + i, BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; return; } @@ -125,10 +125,10 @@ main() std::memset(bufferB, 0x55, BlockSize); bool initializeSuccess = false; - if (RF_CALL_BLOCKING(storageDeviceStack.initialize())) { + if (storageDeviceStack.initialize()) { MODM_LOG_INFO << "Erasing complete flash chip... (This may take a while)" << modm::endl; - if (RF_CALL_BLOCKING(storageDeviceStack.erase(0, MemorySize))) { - RF_CALL_BLOCKING(storageDeviceStack.waitWhileBusy()); + if (storageDeviceStack.erase(0, MemorySize)) { + storageDeviceStack.waitWhileBusy(); initializeSuccess = true; } else { MODM_LOG_INFO << "Error: Unable to erase device."; @@ -138,10 +138,10 @@ main() } if (initializeSuccess) { - auto id = RF_CALL_BLOCKING(storageDevice.readId()); + auto id = storageDevice.readId(); MODM_LOG_INFO << "deviceId=" << id.deviceId << " manufacturerId=" << id.manufacturerId; MODM_LOG_INFO << "deviceType=" << id.deviceType << modm::endl; - MODM_LOG_INFO << "status=" << static_cast(RF_CALL_BLOCKING(storageDevice.readStatus())) << modm::endl; + MODM_LOG_INFO << "status=" << static_cast(storageDevice.readStatus()) << modm::endl; MODM_LOG_INFO << "Press USER button to start the memory test." << modm::endl; } diff --git a/examples/nucleo_f439zi/spi_dma/main.cpp b/examples/nucleo_f439zi/spi_dma/main.cpp index d548a15c2d..467cd1c6eb 100644 --- a/examples/nucleo_f439zi/spi_dma/main.cpp +++ b/examples/nucleo_f439zi/spi_dma/main.cpp @@ -10,7 +10,6 @@ // ---------------------------------------------------------------------------- #include -#include using Mosi = GpioOutputB5; using Miso = GpioInputB4; @@ -19,64 +18,41 @@ using DmaRx = Dma2::Channel0; using DmaTx = Dma2::Channel3; using Spi = SpiMaster1_Dma; -class SpiThread : public modm::pt::Protothread -{ -public: - - bool - update() - { - PT_BEGIN(); - - // Enable DMA controller - Dma2::enable(); - - // Enable and initialize SPI - Spi::connect(); - Spi::initialize(); +const uint8_t sendBuffer[13] {"data to send"}; +uint8_t receiveBuffer[13]; - while (true) - { - MODM_LOG_INFO << "sendBuffer adress: " << modm::hex << sendBuffer << modm::endl; - MODM_LOG_INFO << "receiveBuffer adress: " << modm::hex << receiveBuffer << modm::endl; - MODM_LOG_INFO << "Info: 0x20000000 is start of SRAM1" << modm::endl; - - MODM_LOG_INFO << "Before first transfer" << modm::endl; - - // send out 12 bytes, don't care about response - PT_CALL(Spi::transfer(sendBuffer, nullptr, 12)); +int main() +{ + Board::initialize(); - MODM_LOG_INFO << "After first transfer" << modm::endl; + MODM_LOG_INFO << "Hello from SPI-DMA example on Nucleo-F439ZI!" << modm::endl; - // send out 12 bytes, read in 12 bytes - PT_CALL(Spi::transfer(sendBuffer, receiveBuffer, 12)); + // Enable DMA controller + Dma2::enable(); - MODM_LOG_INFO << "After second transfer" << modm::endl << modm::endl; + // Enable and initialize SPI + Spi::connect(); + Spi::initialize(); - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + while (true) + { + MODM_LOG_INFO << "sendBuffer adress: " << modm::hex << sendBuffer << modm::endl; + MODM_LOG_INFO << "receiveBuffer adress: " << modm::hex << receiveBuffer << modm::endl; + MODM_LOG_INFO << "Info: 0x20000000 is start of SRAM1" << modm::endl; - PT_END(); - } + MODM_LOG_INFO << "Before first transfer" << modm::endl; -private: - uint8_t sendBuffer[13] { "data to send" }; - uint8_t receiveBuffer[13]; - modm::ShortTimeout timeout; -}; + // send out 12 bytes, don't care about response + Spi::transfer(sendBuffer, nullptr, 12); -SpiThread spiThread; + MODM_LOG_INFO << "After first transfer" << modm::endl; -int main() -{ - Board::initialize(); + // send out 12 bytes, read in 12 bytes + Spi::transfer(sendBuffer, receiveBuffer, 12); - MODM_LOG_INFO << "Hello from SPI-DMA example on Nucleo-F439ZI!" << modm::endl; + MODM_LOG_INFO << "After second transfer" << modm::endl << modm::endl; - while (true) - { - spiThread.update(); + modm::delay(500ms); } return 0; diff --git a/examples/nucleo_f439zi/spi_dma/project.xml b/examples/nucleo_f439zi/spi_dma/project.xml index b8ca489c20..0bc180a4b3 100644 --- a/examples/nucleo_f439zi/spi_dma/project.xml +++ b/examples/nucleo_f439zi/spi_dma/project.xml @@ -7,8 +7,6 @@ modm:platform:gpio modm:platform:dma modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/nucleo_f446re/color/main.cpp b/examples/nucleo_f446re/color/main.cpp index ac80a406ce..50aad8fca5 100644 --- a/examples/nucleo_f446re/color/main.cpp +++ b/examples/nucleo_f446re/color/main.cpp @@ -14,90 +14,56 @@ #include #include -class ThreadOne : public modm::pt::Protothread -{ -public: - bool - update() - { - PT_BEGIN(); - - MODM_LOG_INFO << "Ping the device from ThreadOne" << modm::endl; - - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(sensor.ping())) { break; } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } +modm::tcs3472::Data data; +modm::Tcs3472 sensor{data}; - MODM_LOG_INFO << "Device responded" << modm::endl; - - while (true) - { - if (PT_CALL(sensor.initialize())) { break; } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } +modm::Fiber fiber_sensor([] +{ + MODM_LOG_INFO << "Ping the device from ThreadOne" << modm::endl; - MODM_LOG_INFO << "Device initialized" << modm::endl; + // ping the device until it responds + while (not sensor.ping()) modm::this_fiber::sleep_for(100ms); + MODM_LOG_INFO << "Device responded" << modm::endl; - while (true) - { - if (PT_CALL(sensor.configure(sensor.Gain::X4, sensor.IntegrationTime::MSEC_101))) - { - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + while (not sensor.initialize()) modm::this_fiber::sleep_for(100ms); + MODM_LOG_INFO << "Device initialized" << modm::endl; - MODM_LOG_INFO << "Device configured" << modm::endl; + while (not sensor.configure(sensor.Gain::X4, sensor.IntegrationTime::MSEC_101)) + modm::this_fiber::sleep_for(100ms); + MODM_LOG_INFO << "Device configured" << modm::endl; - while (true) + while (true) + { + if (sensor.readColor()) { - if (PT_CALL(sensor.readColor())) - { - const auto rgb = data.getColor(); - MODM_LOG_INFO << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; - } - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); + const auto rgb = data.getColor(); + MODM_LOG_INFO << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; } - - PT_END(); + modm::this_fiber::sleep_for(500ms); } +}); -private: - modm::ShortTimeout timeout; - modm::tcs3472::Data data; - modm::Tcs3472 sensor{data}; -}; -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedD13::setOutput(); + while(true) + { + Board::LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int main() { Board::initialize(); - Board::LedD13::setOutput(); I2cMaster1::connect(); I2cMaster1::initialize(); MODM_LOG_INFO << "\n\nWelcome to TCS3472 demo!\n\n"; - modm::ShortPeriodicTimer tmr(500ms); - while (true) - { - one.update(); - if (tmr.execute()) Board::LedD13::toggle(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_f446re/color/project.xml b/examples/nucleo_f446re/color/project.xml index b70f66949f..64c3bac354 100644 --- a/examples/nucleo_f446re/color/project.xml +++ b/examples/nucleo_f446re/color/project.xml @@ -6,8 +6,7 @@ modm:driver:tcs3472 modm:platform:i2c:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/nucleo_f767zi/spi_dma/main.cpp b/examples/nucleo_f767zi/spi_dma/main.cpp index fb85e05bd7..1d88334157 100644 --- a/examples/nucleo_f767zi/spi_dma/main.cpp +++ b/examples/nucleo_f767zi/spi_dma/main.cpp @@ -10,7 +10,6 @@ // ---------------------------------------------------------------------------- #include -#include using Mosi = GpioOutputB5; using Miso = GpioInputB4; @@ -19,64 +18,41 @@ using DmaRx = Dma2::Channel0; using DmaTx = Dma2::Channel3; using Spi = SpiMaster1_Dma; -class SpiThread : public modm::pt::Protothread -{ -public: - - bool - update() - { - PT_BEGIN(); - - // Enable DMA controller - Dma2::enable(); - - // Enable and initialize SPI - Spi::connect(); - Spi::initialize(); +const uint8_t sendBuffer[13] {"data to send"}; +uint8_t receiveBuffer[13]; - while (true) - { - MODM_LOG_INFO << "sendBuffer adress: " << modm::hex << sendBuffer << modm::endl; - MODM_LOG_INFO << "receiveBuffer adress: " << modm::hex << receiveBuffer << modm::endl; - MODM_LOG_INFO << "Info: 0x20000000 is start of SRAM1" << modm::endl; - - MODM_LOG_INFO << "Before first transfer" << modm::endl; - - // send out 12 bytes, don't care about response - PT_CALL(Spi::transfer(sendBuffer, nullptr, 12)); +int main() +{ + Board::initialize(); - MODM_LOG_INFO << "After first transfer" << modm::endl; + MODM_LOG_INFO << "Hello from SPI-DMA example on Nucleo-F767ZI!" << modm::endl; - // send out 12 bytes, read in 12 bytes - PT_CALL(Spi::transfer(sendBuffer, receiveBuffer, 12)); + // Enable DMA controller + Dma2::enable(); - MODM_LOG_INFO << "After second transfer" << modm::endl << modm::endl; + // Enable and initialize SPI + Spi::connect(); + Spi::initialize(); - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + while (true) + { + MODM_LOG_INFO << "sendBuffer adress: " << modm::hex << sendBuffer << modm::endl; + MODM_LOG_INFO << "receiveBuffer adress: " << modm::hex << receiveBuffer << modm::endl; + MODM_LOG_INFO << "Info: 0x20000000 is start of SRAM1" << modm::endl; - PT_END(); - } + MODM_LOG_INFO << "Before first transfer" << modm::endl; -private: - uint8_t sendBuffer[13] { "data to send" }; - uint8_t receiveBuffer[13]; - modm::ShortTimeout timeout; -}; + // send out 12 bytes, don't care about response + Spi::transfer(sendBuffer, nullptr, 12); -SpiThread spiThread; + MODM_LOG_INFO << "After first transfer" << modm::endl; -int main() -{ - Board::initialize(); + // send out 12 bytes, read in 12 bytes + Spi::transfer(sendBuffer, receiveBuffer, 12); - MODM_LOG_INFO << "Hello from SPI-DMA example on Nucleo-F767ZI!" << modm::endl; + MODM_LOG_INFO << "After second transfer" << modm::endl << modm::endl; - while (true) - { - spiThread.update(); + modm::delay(500ms); } return 0; diff --git a/examples/nucleo_f767zi/spi_dma/project.xml b/examples/nucleo_f767zi/spi_dma/project.xml index 0f59fd175c..3ac9129878 100644 --- a/examples/nucleo_f767zi/spi_dma/project.xml +++ b/examples/nucleo_f767zi/spi_dma/project.xml @@ -7,8 +7,6 @@ modm:platform:gpio modm:platform:dma modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/nucleo_g071rb/amnb/main.cpp b/examples/nucleo_g071rb/amnb/main.cpp index 588db066e5..37feb5eadf 100644 --- a/examples/nucleo_g071rb/amnb/main.cpp +++ b/examples/nucleo_g071rb/amnb/main.cpp @@ -39,14 +39,14 @@ Action actions[] = {1, []() -> Response { static uint8_t counter{0}; - MODM_LOG_INFO << "Node1 and Node3 received Action 1" << modm::endl; + MODM_LOG_INFO << "Node1 or Node3 received Action 1" << modm::endl; return counter++; } }, {2, [](const uint32_t& data) -> Response { static uint8_t counter{0}; - MODM_LOG_INFO << "Node1 and Node3 received Action 2 with argument: " << data << modm::endl; + MODM_LOG_INFO << "Node1 or Node3 received Action 2 with argument: " << data << modm::endl; return ErrorResponse(counter++); } }, @@ -60,46 +60,48 @@ Node node1(device1, 1, actions); Node node2(device2, 2, listeners); Node node3(device3, 3, actions, listeners); +modm::Fiber<512> fiberNode1t([]{ node1.update_transmit(); }); +modm::Fiber<512> fiberNode1r([]{ node1.update_receive(); }); +modm::Fiber<512> fiberNode2t([]{ node2.update_transmit(); }); +modm::Fiber<512> fiberNode2r([]{ node2.update_receive(); }); +modm::Fiber<512> fiberNode3t([]{ node3.update_transmit(); }); +modm::Fiber<512> fiberNode3r([]{ node3.update_receive(); }); + // You need to connect D1 with D15 and with A0 using PinNode1 = GpioC4; // D1 using PinNode2 = GpioB8; // D15 using PinNode3 = GpioA0; // A0 -class Thread : public modm::pt::Protothread +modm::Fiber fiber_demo([] { - modm::ShortPeriodicTimer tmr{1s}; uint32_t counter{0}; - Result res1; - Result res2; - -public: - bool inline - update() + while(true) { - PT_BEGIN(); - - while(true) - { - PT_WAIT_UNTIL(tmr.execute()); + modm::this_fiber::sleep_for(1s); - node1.broadcast(1, counter++); - node3.broadcast(2); + node1.broadcast(1, counter++); + node3.broadcast(2); - res1 = PT_CALL(node2.request(1, 1)); - MODM_LOG_INFO << "Node1 responded with: " << res1.error(); - if (res1) { MODM_LOG_INFO << " " << *res1 << modm::endl; } + auto res1 = node2.request(1, 1); + MODM_LOG_INFO << "Node1 responded with: " << res1.error(); + if (res1) { MODM_LOG_INFO << " " << *res1 << modm::endl; } - res2 = PT_CALL(node1.request(3, 2, counter)); - MODM_LOG_INFO << "Node3 responded with: " << res2.error(); - if (res2.hasUserError()) { - MODM_LOG_INFO << " " << *res2.userError() << modm::endl; - } + auto res2 = node1.request(3, 2, counter); + MODM_LOG_INFO << "Node3 responded with: " << res2.error(); + if (res2.hasUserError()) { + MODM_LOG_INFO << " " << *res2.userError() << modm::endl; } - PT_END(); + if (counter % 10 == 0) + { + MODM_LOG_INFO << "Node1t stack=" << fiberNode1t.stack_usage() << "\nNode1r stack=" << fiberNode1r.stack_usage() << modm::endl; + MODM_LOG_INFO << "Node2t stack=" << fiberNode2t.stack_usage() << "\nNode2r stack=" << fiberNode2r.stack_usage() << modm::endl; + MODM_LOG_INFO << "Node3t stack=" << fiberNode3t.stack_usage() << "\nNode3r stack=" << fiberNode3r.stack_usage() << modm::endl; + } } -} -thread; +}); + + // ---------------------------------------------------------------------------- int @@ -135,16 +137,14 @@ main() USART4->CR3 = USART_CR3_HDSEL; USART4->CR1 |= USART_CR1_UE; - while (true) - { - node1.update_transmit(); - node1.update_receive(); - node2.update_transmit(); - node2.update_receive(); - node3.update_transmit(); - node3.update_receive(); - thread.update(); - } + fiberNode1t.stack_watermark(); + fiberNode1r.stack_watermark(); + fiberNode2t.stack_watermark(); + fiberNode2r.stack_watermark(); + fiberNode3t.stack_watermark(); + fiberNode3r.stack_watermark(); + + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_g071rb/amnb/project.xml b/examples/nucleo_g071rb/amnb/project.xml index 158808e8a1..a65468a3cc 100644 --- a/examples/nucleo_g071rb/amnb/project.xml +++ b/examples/nucleo_g071rb/amnb/project.xml @@ -2,7 +2,7 @@ modm:nucleo-g071rb - + modm:platform:gpio @@ -11,6 +11,6 @@ modm:platform:uart:3 modm:platform:uart:4 modm:build:scons - modm:processing:protothread + modm:processing:fiber diff --git a/examples/nucleo_g071rb/amnb_fiber/main.cpp b/examples/nucleo_g071rb/amnb_fiber/main.cpp deleted file mode 100644 index 54f598900c..0000000000 --- a/examples/nucleo_g071rb/amnb_fiber/main.cpp +++ /dev/null @@ -1,166 +0,0 @@ -/* - * Copyright (c) 2019, Niklas Hauser - * - * This file is part of the modm project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ - -#include -#include -#include - -using namespace Board; -using namespace std::chrono_literals; -using namespace modm::amnb; -using Usart1 = BufferedUart>; -using Usart3 = BufferedUart>; -using Usart4 = BufferedUart; -// ---------------------------------------------------------------------------- - -Listener listeners[] = -{ - {1, [](uint8_t sender, const uint32_t& data) - { - MODM_LOG_INFO << "Node2 and Node3 received Broadcast 1 from '" << sender; - MODM_LOG_INFO << "': " << data << modm::endl; - } - }, - {2, [](uint8_t sender) - { - MODM_LOG_INFO << "Node2 and Node3 received Broadcast 2 from '" << sender << "'" << modm::endl; - } - }, -}; -Action actions[] = -{ - {1, []() -> Response - { - static uint8_t counter{0}; - MODM_LOG_INFO << "Node1 or Node3 received Action 1" << modm::endl; - return counter++; - } - }, - {2, [](const uint32_t& data) -> Response - { - static uint8_t counter{0}; - MODM_LOG_INFO << "Node1 or Node3 received Action 2 with argument: " << data << modm::endl; - return ErrorResponse(counter++); - } - }, -}; - -// Two nodes on the same device on different UARTs of course! -DeviceWrapper device1; -DeviceWrapper device2; -DeviceWrapper device3; -Node node1(device1, 1, actions); -Node node2(device2, 2, listeners); -Node node3(device3, 3, actions, listeners); - -modm::Fiber fiberNode1t([]{ node1.update_transmit(); }); -modm::Fiber fiberNode1r([]{ node1.update_receive(); }); -modm::Fiber fiberNode2t([]{ node2.update_transmit(); }); -modm::Fiber fiberNode2r([]{ node2.update_receive(); }); -modm::Fiber fiberNode3t([]{ node3.update_transmit(); }); -modm::Fiber fiberNode3r([]{ node3.update_receive(); }); - -// You need to connect D1 with D15 and with A0 -using PinNode1 = GpioC4; // D1 -using PinNode2 = GpioB8; // D15 -using PinNode3 = GpioA0; // A0 - -class Thread : public modm::pt::Protothread -{ - modm::ShortPeriodicTimer tmr{1s}; - uint32_t counter{0}; - Result res1; - Result res2; - -public: - bool inline - update() - { - PT_BEGIN(); - - while(true) - { - PT_WAIT_UNTIL(tmr.execute()); - - node1.broadcast(1, counter++); - node3.broadcast(2); - - res1 = PT_CALL(node2.request(1, 1)); - MODM_LOG_INFO << "Node1 responded with: " << res1.error(); - if (res1) { MODM_LOG_INFO << " " << *res1 << modm::endl; } - - res2 = PT_CALL(node1.request(3, 2, counter)); - MODM_LOG_INFO << "Node3 responded with: " << res2.error(); - if (res2.hasUserError()) { - MODM_LOG_INFO << " " << *res2.userError() << modm::endl; - } - - if (counter % 10 == 0) - { - MODM_LOG_INFO << "Node1t stack=" << fiberNode1t.stack_usage() << "\nNode1r stack=" << fiberNode1r.stack_usage() << modm::endl; - MODM_LOG_INFO << "Node2t stack=" << fiberNode2t.stack_usage() << "\nNode2r stack=" << fiberNode2r.stack_usage() << modm::endl; - MODM_LOG_INFO << "Node3t stack=" << fiberNode3t.stack_usage() << "\nNode3r stack=" << fiberNode3r.stack_usage() << modm::endl; - MODM_LOG_INFO << "Thread stack=" << this->stack_usage() << modm::endl; - } - } - - PT_END(); - } -} -thread; - - - -// ---------------------------------------------------------------------------- -int -main() -{ - Board::initialize(); - LedD13::setOutput(); - - Usart1::connect(); - Usart1::initialize(Usart1::Parity::Even, Usart1::WordLength::Bit9); - // Use Single-Wire Half-Duplex Mode - PinNode1::configure(Gpio::OutputType::OpenDrain); - PinNode1::configure(Gpio::InputType::PullUp); - USART1->CR1 &= ~USART_CR1_UE; - USART1->CR3 = USART_CR3_HDSEL; - USART1->CR1 |= USART_CR1_UE; - - Usart3::connect(); - Usart3::initialize(Usart1::Parity::Even, Usart1::WordLength::Bit9); - // Use Single-Wire Half-Duplex Mode - PinNode2::configure(Gpio::OutputType::OpenDrain); - PinNode2::configure(Gpio::InputType::PullUp); - USART3->CR1 &= ~USART_CR1_UE; - USART3->CR3 = USART_CR3_HDSEL; - USART3->CR1 |= USART_CR1_UE; - - Usart4::connect(); - Usart4::initialize(Usart1::Parity::Even, Usart1::WordLength::Bit9); - // Use Single-Wire Half-Duplex Mode - PinNode3::configure(Gpio::OutputType::OpenDrain); - PinNode3::configure(Gpio::InputType::PullUp); - USART4->CR1 &= ~USART_CR1_UE; - USART4->CR3 = USART_CR3_HDSEL; - USART4->CR1 |= USART_CR1_UE; - - fiberNode1t.stack_watermark(); - fiberNode1r.stack_watermark(); - fiberNode2t.stack_watermark(); - fiberNode2r.stack_watermark(); - fiberNode3t.stack_watermark(); - fiberNode3r.stack_watermark(); - thread.stack_watermark(); - - modm::fiber::Scheduler::run(); - - return 0; -} diff --git a/examples/nucleo_g071rb/amnb_fiber/project.xml b/examples/nucleo_g071rb/amnb_fiber/project.xml deleted file mode 100644 index 0c759874cf..0000000000 --- a/examples/nucleo_g071rb/amnb_fiber/project.xml +++ /dev/null @@ -1,18 +0,0 @@ - - modm:nucleo-g071rb - - - - - - - modm:platform:gpio - modm:communication:amnb - modm:platform:uart:1 - modm:platform:uart:3 - modm:platform:uart:4 - modm:build:scons - modm:processing:protothread - modm:processing:fiber - - diff --git a/examples/nucleo_g071rb/apa102/main.cpp b/examples/nucleo_g071rb/apa102/main.cpp index 76dd75a215..a5f2f83b03 100644 --- a/examples/nucleo_g071rb/apa102/main.cpp +++ b/examples/nucleo_g071rb/apa102/main.cpp @@ -41,7 +41,7 @@ main() if (g++ >= max) g = 0; if (b++ >= max) b = 0; } - RF_CALL_BLOCKING(leds.write()); + leds.write(); while(not tmr.execute()) ; } diff --git a/examples/nucleo_g071rb/matrix/main.cpp b/examples/nucleo_g071rb/matrix/main.cpp index b91f620719..a92a823366 100644 --- a/examples/nucleo_g071rb/matrix/main.cpp +++ b/examples/nucleo_g071rb/matrix/main.cpp @@ -38,12 +38,12 @@ main() I2cInstance::initialize(); I2cInstance::connect(); - RF_CALL_BLOCKING(driver.reset()); - RF_CALL_BLOCKING(driver.clearSoftwareShutdown()); - RF_CALL_BLOCKING(driver.setGlobalCurrent(1)); + driver.reset(); + driver.clearSoftwareShutdown(); + driver.setGlobalCurrent(1); driver.enableAll(); - RF_CALL_BLOCKING(driver.writeOnOff()); + driver.writeOnOff(); uint8_t pwm{0}; while (true) @@ -53,7 +53,7 @@ main() driver.setPwm(x, y, pi++); } } - RF_CALL_BLOCKING(driver.writePwm()); + driver.writePwm(); modm::delay(10ms); pwm++; } diff --git a/examples/nucleo_g474re/ads101x/main.cpp b/examples/nucleo_g474re/ads101x/main.cpp index 74c6111e26..b2619def1f 100644 --- a/examples/nucleo_g474re/ads101x/main.cpp +++ b/examples/nucleo_g474re/ads101x/main.cpp @@ -18,162 +18,115 @@ using Scl = modm::platform::GpioC6; using Sda = modm::platform::GpioC7; using I2cMaster = modm::platform::I2cMaster4; -using namespace Board; +modm::ads101x::Data data; +modm::Ads101x adc{data}; -class AdcThread : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { - -public: - AdcThread() : adc(data) - { - } - - inline bool - run() - { - PT_BEGIN(); - - // test of communication and initialization - while (not PT_CALL(adc.ping())) - { - MODM_LOG_ERROR << "Pinging Ads101x failed" << modm::endl; - - shortTimeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(shortTimeout.isExpired()); - } - - while (not PT_CALL(adc.initialize())) - { - MODM_LOG_ERROR << "Initialising Ads101x failed" << modm::endl; - - shortTimeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(shortTimeout.isExpired()); - } - - MODM_LOG_INFO << "Ads101x successfully initialised" << modm::endl; - - while (true) - { - // Single shot and full scale range test - MODM_LOG_INFO << "Started single conversion test" << modm::endl; - timeout.restart(std::chrono::seconds(10)); - while (not timeout.isExpired()) - { - // Test single shoot mode with full scale range 0.256 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V0_256)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 0.256V: " << data.getVoltage() << modm::endl; - - // Test single shoot mode with full scale range 0.512 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V0_512)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 0.512V: " << data.getVoltage() << modm::endl; - - // Test single shoot mode with full scale range 1.024 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V1_024)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 1.024V: " << data.getVoltage() << modm::endl; - - // Test single shoot mode with full scale range 2.048 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V2_048)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 2.048V: " << data.getVoltage() << modm::endl; - - // Test single shoot mode with full scale range 4.096 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V4_096)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 4.096V: " << data.getVoltage() << modm::endl; - - // Test single shoot mode with full scale range 6.144 - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V6_144)); - PT_CALL(adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4)); - while (PT_CALL(adc.isBusy())) - { - PT_YIELD(); - } - - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Single Conversion result in range 6.144V: " << data.getVoltage() << modm::endl; - - shortTimeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(shortTimeout.isExpired()); - } - - // Continuous mode test - MODM_LOG_INFO << "Started continuous conversion test" << modm::endl; - PT_CALL(adc.setFullScaleRange(modm::ads101x::FullScaleRange::V6_144)); - PT_CALL(adc.startContinuousConversion(modm::ads101x::InputMultiplexer::Input4)); - - timeout.restart(std::chrono::seconds(10)); - while (not timeout.isExpired()) - { - shortTimeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(shortTimeout.isExpired()); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO << "Continuous Conversion result in range 6.144V: " << data.getVoltage() << modm::endl; - } - } - PT_END(); - } - -private: - modm::ads101x::Data data; - modm::Ads101x adc; - - modm::Timeout timeout; - modm::ShortTimeout shortTimeout; - -} adcThread; + // test of communication and initialization + while (not adc.ping()) + { + MODM_LOG_ERROR << "Pinging Ads101x failed" << modm::endl; + modm::this_fiber::sleep_for(1s); + } + + while (not adc.initialize()) + { + MODM_LOG_ERROR << "Initialising Ads101x failed" << modm::endl; + modm::this_fiber::sleep_for(1s); + } + + MODM_LOG_INFO << "Ads101x successfully initialised" << modm::endl; + + while (true) + { + // Single shot and full scale range test + MODM_LOG_INFO << "Started single conversion test" << modm::endl; + + modm::ShortTimeout timeout(10s); + while(not timeout.isExpired()) + { + // Test single shoot mode with full scale range 0.256 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V0_256); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 0.256V: " << data.getVoltage() << modm::endl; + + // Test single shoot mode with full scale range 0.512 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V0_512); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 0.512V: " << data.getVoltage() << modm::endl; + + // Test single shoot mode with full scale range 1.024 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V1_024); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 1.024V: " << data.getVoltage() << modm::endl; + + // Test single shoot mode with full scale range 2.048 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V2_048); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 2.048V: " << data.getVoltage() << modm::endl; + + // Test single shoot mode with full scale range 4.096 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V4_096); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 4.096V: " << data.getVoltage() << modm::endl; + + // Test single shoot mode with full scale range 6.144 + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V6_144); + adc.startSingleShotConversion(modm::ads101x::InputMultiplexer::Input4); + while (adc.isBusy()) modm::this_fiber::yield(); + adc.readConversionResult(); + MODM_LOG_INFO << "Single Conversion result in range 6.144V: " << data.getVoltage() << modm::endl; + + modm::this_fiber::sleep_for(1s); + } + + // Continuous mode test + MODM_LOG_INFO << "Started continuous conversion test" << modm::endl; + adc.setFullScaleRange(modm::ads101x::FullScaleRange::V6_144); + adc.startContinuousConversion(modm::ads101x::InputMultiplexer::Input4); + + timeout.restart(10s); + while (not timeout.isExpired()) + { + modm::this_fiber::sleep_for(1s); + adc.readConversionResult(); + MODM_LOG_INFO << "Continuous Conversion result in range 6.144V: " << data.getVoltage() << modm::endl; + } + } +}); + +modm::Fiber fiber_blink([] +{ + Board::LedD13::setOutput(); + while(true) + { + Board::LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() { - Board::initialize(); + Board::initialize(); - I2cMaster::connect(I2cMaster::PullUps::Internal); - I2cMaster::initialize(); + I2cMaster::connect(I2cMaster::PullUps::Internal); + I2cMaster::initialize(); - MODM_LOG_INFO << "==========ADS101x Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; + MODM_LOG_INFO << "==========ADS101x Test==========" << modm::endl; - while (true) - { - adcThread.run(); - } + modm::fiber::Scheduler::run(); - return 0; -} \ No newline at end of file + return 0; +} diff --git a/examples/nucleo_g474re/ads101x/project.xml b/examples/nucleo_g474re/ads101x/project.xml index 790f897315..74ad5e3114 100644 --- a/examples/nucleo_g474re/ads101x/project.xml +++ b/examples/nucleo_g474re/ads101x/project.xml @@ -7,8 +7,8 @@ modm:driver:ads101x modm:platform:gpio modm:platform:i2c:4 - modm:processing:protothread + modm:processing:fiber modm:processing:timer modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/ads7828/main.cpp b/examples/nucleo_g474re/ads7828/main.cpp index 6cdccd7f6a..cc74240e9a 100644 --- a/examples/nucleo_g474re/ads7828/main.cpp +++ b/examples/nucleo_g474re/ads7828/main.cpp @@ -19,174 +19,154 @@ using Scl = modm::platform::GpioC6; using Sda = modm::platform::GpioC7; using I2cMaster = modm::platform::I2cMaster4; -using namespace Board; +modm::ads7828::Data data; +modm::Ads7828 adc{data, 0x48}; -class AdcThread : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { - -public: - AdcThread() : adc(data, 0x48) - { - } - - inline bool - run() - { - PT_BEGIN(); - - while (PT_CALL(adc.ping()) == false) - { - MODM_LOG_ERROR << "Could not ping Ads7828" << modm::endl; - - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - while (true) - { - MODM_LOG_INFO << "-------------------------------" << modm::endl << modm::endl; - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch0 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch1)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch1 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch2)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch2 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch3)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch3 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch4)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch4 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch5)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch5 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch6)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch6 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch7)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch7 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - MODM_LOG_INFO << "----Diff Inputs-------------" << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0Ch1)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch0 - Ch1 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch2Ch3)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch2 - Ch3 is\t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch4Ch5)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch4 - Ch5 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch6Ch7)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch6 - Ch7 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch1Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch1 - Ch0 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch3Ch2)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch3 - Ch2 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch5Ch4)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch5 - Ch4 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch7Ch6)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Ch7 - Ch6 is \t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - MODM_LOG_INFO << "---Toggling Power Down and Internal Ref----" << modm::endl; - - PT_CALL(adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOffAdcConverterOff)); - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Default: \t\t\t\t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOnAdcConverterOff)); - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Internal ref on: \t\t\t %.4f", (double)data.getVoltage(2.5f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOffAdcConverterOn)); - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("No power down \t\t\t\t %.4f", (double)data.getVoltage(3.3f)); - MODM_LOG_INFO << modm::endl; - - PT_CALL(adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOnAdcConverterOn)); - PT_CALL(adc.startMeasurement(modm::ads7828::InputChannel::Ch0)); - PT_CALL(adc.readConversionResult()); - MODM_LOG_INFO.printf("Internal ref on, no power down: \t %.4f", (double)data.getVoltage(2.5f)); - MODM_LOG_INFO << modm::endl; - - MODM_LOG_INFO << "-------------------------------" << modm::endl << modm::endl; - - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } - PT_END(); - } - -private: - modm::ads7828::Data data; - modm::Ads7828 adc; - - modm::ShortTimeout timeout; -} adcThread; + while (not adc.ping()) + { + MODM_LOG_ERROR << "Could not ping Ads7828" << modm::endl; + modm::this_fiber::sleep_for(1s); + } + + while (true) + { + MODM_LOG_INFO << "-------------------------------" << modm::endl << modm::endl; + adc.startMeasurement(modm::ads7828::InputChannel::Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch0 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch1); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch1 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch2); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch2 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch3); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch3 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch4); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch4 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch5); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch5 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch6); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch6 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch7); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch7 measuremnt is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + MODM_LOG_INFO << "----Diff Inputs-------------" << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch0Ch1); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch0 - Ch1 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch2Ch3); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch2 - Ch3 is\t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch4Ch5); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch4 - Ch5 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch6Ch7); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch6 - Ch7 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch1Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch1 - Ch0 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch3Ch2); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch3 - Ch2 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch5Ch4); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch5 - Ch4 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.startMeasurement(modm::ads7828::InputChannel::Ch7Ch6); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Ch7 - Ch6 is \t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + MODM_LOG_INFO << "---Toggling Power Down and Internal Ref----" << modm::endl; + + adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOffAdcConverterOff); + adc.startMeasurement(modm::ads7828::InputChannel::Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Default: \t\t\t\t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOnAdcConverterOff); + adc.startMeasurement(modm::ads7828::InputChannel::Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Internal ref on: \t\t\t %.4f", (double)data.getVoltage(2.5f)); + MODM_LOG_INFO << modm::endl; + + adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOffAdcConverterOn); + adc.startMeasurement(modm::ads7828::InputChannel::Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("No power down \t\t\t\t %.4f", (double)data.getVoltage(3.3f)); + MODM_LOG_INFO << modm::endl; + + adc.setPowerDownSelection(modm::ads7828::PowerDown::InternalReferenceOnAdcConverterOn); + adc.startMeasurement(modm::ads7828::InputChannel::Ch0); + adc.readConversionResult(); + MODM_LOG_INFO.printf("Internal ref on, no power down: \t %.4f", (double)data.getVoltage(2.5f)); + MODM_LOG_INFO << modm::endl; + + MODM_LOG_INFO << "-------------------------------" << modm::endl << modm::endl; + + modm::this_fiber::sleep_for(1s); + } +}); + +modm::Fiber fiber_blink([] +{ + Board::LedD13::setOutput(); + while(true) + { + Board::LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() { - Board::initialize(); - - I2cMaster::connect(I2cMaster::PullUps::Internal); - I2cMaster::initialize(); + Board::initialize(); + I2cMaster::connect(I2cMaster::PullUps::Internal); + I2cMaster::initialize(); - MODM_LOG_INFO << "==========Ads7828 Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; + MODM_LOG_INFO << "==========Ads7828 Test==========" << modm::endl; - while (true) - { - adcThread.run(); - } - return 0; + modm::fiber::Scheduler::run(); + return 0; } diff --git a/examples/nucleo_g474re/ads7828/project.xml b/examples/nucleo_g474re/ads7828/project.xml index d35e31bff8..297a2fdc31 100644 --- a/examples/nucleo_g474re/ads7828/project.xml +++ b/examples/nucleo_g474re/ads7828/project.xml @@ -7,8 +7,7 @@ modm:driver:ads7828 modm:platform:gpio modm:platform:i2c:4 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/as5047/main.cpp b/examples/nucleo_g474re/as5047/main.cpp index e56c038f0e..4ef7ab39b2 100644 --- a/examples/nucleo_g474re/as5047/main.cpp +++ b/examples/nucleo_g474re/as5047/main.cpp @@ -11,7 +11,6 @@ #include #include -#include using SpiMaster = SpiMaster1; @@ -20,41 +19,8 @@ using Mosi = modm::platform::GpioB5; using Miso = modm::platform::GpioB4; using Sck = modm::platform::GpioB3; -using namespace Board; -using namespace modm::literals; - -class EncoderThread : public modm::pt::Protothread -{ -public: - EncoderThread() : encoder(data) {} - - bool - run() - { - PT_BEGIN(); - - while (true) - { - PT_CALL(encoder.read()); - - MODM_LOG_INFO << "\nNew readout:" << modm::endl; - MODM_LOG_INFO << " angle degree: " << data.toDegree() << " degrees" << modm::endl; - MODM_LOG_INFO << " angle rad: " << data.toRadian() << " radians" << modm::endl; - MODM_LOG_INFO << " angle raw: " << data.data << modm::endl; - - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::as5047::Data data{0}; - modm::As5047 encoder; - - modm::ShortTimeout timeout; -} encoderThread; +modm::as5047::Data data{0}; +modm::As5047 encoder{data}; int main() @@ -73,7 +39,17 @@ main() MODM_LOG_ERROR << "Error logging here" << modm::endl; MODM_LOG_INFO << "===============================" << modm::endl; - while (true) { encoderThread.run(); } + while (true) + { + encoder.read(); + + MODM_LOG_INFO << "\nNew readout:" << modm::endl; + MODM_LOG_INFO << " angle degree: " << data.toDegree() << " degrees" << modm::endl; + MODM_LOG_INFO << " angle rad: " << data.toRadian() << " radians" << modm::endl; + MODM_LOG_INFO << " angle raw: " << data.data << modm::endl; + + modm::delay(500ms); + } return 0; -} \ No newline at end of file +} diff --git a/examples/nucleo_g474re/as5047/project.xml b/examples/nucleo_g474re/as5047/project.xml index 4b86fa2b25..75689e5fc0 100644 --- a/examples/nucleo_g474re/as5047/project.xml +++ b/examples/nucleo_g474re/as5047/project.xml @@ -7,8 +7,6 @@ modm:driver:as5047 modm:platform:gpio modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/imu_lsm6dso/main.cpp b/examples/nucleo_g474re/imu_lsm6dso/main.cpp index e4f80e360c..4bbb87a5f2 100644 --- a/examples/nucleo_g474re/imu_lsm6dso/main.cpp +++ b/examples/nucleo_g474re/imu_lsm6dso/main.cpp @@ -56,24 +56,24 @@ main() MODM_LOG_INFO << "Resetting and rebooting imu (BOOT | SW_RESET)..." << modm::endl; // Write bits BOOT | SW_RESET (and IF_INC, because it default to 1) to reboot imu - if(!RF_CALL_BLOCKING(imu.writeRegister(modm::lsm6dso::Register::CTRL3_C, 0b1000'0101))) { + if(!imu.writeRegister(modm::lsm6dso::Register::CTRL3_C, 0b1000'0101)) { MODM_LOG_INFO.printf(" ... failed."); Board::Leds::set(); } MODM_LOG_INFO << "Initializing IMU..." << modm::endl; - RF_CALL_BLOCKING(imu.initialize()); + imu.initialize(); MODM_LOG_INFO << "Enable IMU by configuring data rate and range" << modm::endl; - if(!RF_CALL_BLOCKING(imu.setOutputDataRateAndRange<12_Hz, 5_pct>( + if(!imu.setOutputDataRateAndRange<12_Hz, 5_pct>( modm::lsm6dso::LinearRange::G2, - modm::lsm6dso::AngularRange::dps125))) { + modm::lsm6dso::AngularRange::dps125)) { MODM_LOG_INFO.printf(" ... failed."); Board::Leds::set(); } // Reading CTRL1_XL register - std::optional reg = RF_CALL_BLOCKING(imu.readRegister(modm::lsm6dso::Register::CTRL1_XL)); + std::optional reg = imu.readRegister(modm::lsm6dso::Register::CTRL1_XL); if (reg.has_value()) { MODM_LOG_INFO << "Reading CTRL1_XL register = " << *reg << modm::endl; } @@ -82,7 +82,7 @@ main() } MODM_LOG_INFO << "Enable accelerometer and gyroscope data-ready interrupts on INT1 pin" << modm::endl; - if(!RF_CALL_BLOCKING(imu.writeRegister(modm::lsm6dso::Register::INT1_CTRL, 0b0000'0011))) { + if(!imu.writeRegister(modm::lsm6dso::Register::INT1_CTRL, 0b0000'0011)) { MODM_LOG_INFO.printf(" ... failed."); Board::Leds::set(); } @@ -97,7 +97,7 @@ main() while (Int1::read()) {} while (!Int1::read()) {} - if(!RF_CALL_BLOCKING(imu.readRegisters(modm::lsm6dso::Register::OUT_TEMP_L, data))) { + if(!imu.readRegisters(modm::lsm6dso::Register::OUT_TEMP_L, data)) { MODM_LOG_INFO.printf("failed. "); Board::Leds::set(); } diff --git a/examples/nucleo_g474re/ixm42xxx/main.cpp b/examples/nucleo_g474re/ixm42xxx/main.cpp index 823410c239..a3163c9632 100644 --- a/examples/nucleo_g474re/ixm42xxx/main.cpp +++ b/examples/nucleo_g474re/ixm42xxx/main.cpp @@ -21,59 +21,57 @@ using Mosi = GpioA7; using Miso = GpioA6; using Sck = GpioA5; using Cs = GpioC5; +using Transport = modm::Ixm42xxxTransportSpi< SpiMaster, Cs >; -class ImuThread : public modm::pt::Protothread, public modm::ixm42xxx -{ - using Transport = modm::Ixm42xxxTransportSpi< SpiMaster, Cs >; - -public: - ImuThread() : imu(data), timer(std::chrono::milliseconds(500)) {} +modm::ixm42xxxdata::Data data; +modm::Ixm42xxx< Transport > imu{data}; - bool - run() +modm::Fiber fiber_sensor([] +{ + /// Initialize the IMU and verify that it is connected + imu.initialize(); + while (not imu.ping()) { - PT_BEGIN(); - - /// Initialize the IMU and verify that it is connected - PT_CALL(imu.initialize()); - while (not PT_CALL(imu.ping())) - { - MODM_LOG_ERROR << "Cannot ping IXM42xxx" << modm::endl; - PT_WAIT_UNTIL(timer.execute()); - } - - /// Configure data sensors - PT_CALL(imu.updateRegister(Register::GYRO_CONFIG0, GyroFs_t(GyroFs::dps2000) | GyroOdr_t(GyroOdr::kHz1))); - PT_CALL(imu.updateRegister(Register::ACCEL_CONFIG0, AccelFs_t(AccelFs::g16) | AccelOdr_t(AccelOdr::kHz1))); - PT_CALL(imu.updateRegister(Register::PWR_MGMT0, GyroMode_t(GyroMode::LowNoise) | AccelMode_t(AccelMode::LowNoise))); - - while (true) - { - PT_WAIT_UNTIL(timer.execute()); - PT_CALL(imu.readSensorData()); - - data.getTemp(&temp); - data.getAccel(&accel); - data.getGyro(&gyro); - - MODM_LOG_INFO.printf("Temp: %.3f\n", temp); - MODM_LOG_INFO.printf("Accel: (%.3f, %.3f, %.3f)\n", accel.x, accel.y, accel.z); - MODM_LOG_INFO.printf("Gyro: (%.3f, %.3f, %.3f)\n", gyro.x, gyro.y, gyro.z); - } - PT_END(); + MODM_LOG_ERROR << "Cannot ping IXM42xxx" << modm::endl; + modm::this_fiber::sleep_for(100ms); } + using ixm = modm::ixm42xxx; -private: - float temp; - modm::Vector3f accel; - modm::Vector3f gyro; - - modm::ixm42xxxdata::Data data; - modm::Ixm42xxx< Transport > imu; + /// Configure data sensors + imu.updateRegister(ixm::Register::GYRO_CONFIG0, + ixm::GyroFs_t(ixm::GyroFs::dps2000) | ixm::GyroOdr_t(ixm::GyroOdr::kHz1)); + imu.updateRegister(ixm::Register::ACCEL_CONFIG0, + ixm::AccelFs_t(ixm::AccelFs::g16) | ixm::AccelOdr_t(ixm::AccelOdr::kHz1)); + imu.updateRegister(ixm::Register::PWR_MGMT0, + ixm::GyroMode_t(ixm::GyroMode::LowNoise) | ixm::AccelMode_t(ixm::AccelMode::LowNoise)); - modm::PeriodicTimer timer; + while (true) + { + modm::this_fiber::sleep_for(500ms); + imu.readSensorData(); + + float temp; + modm::Vector3f accel; + modm::Vector3f gyro; + data.getTemp(&temp); + data.getAccel(&accel); + data.getGyro(&gyro); + + MODM_LOG_INFO.printf("Temp: %.3f\n", temp); + MODM_LOG_INFO.printf("Accel: (%.3f, %.3f, %.3f)\n", accel.x, accel.y, accel.z); + MODM_LOG_INFO.printf("Gyro: (%.3f, %.3f, %.3f)\n", gyro.x, gyro.y, gyro.z); + } +}); -} imuThread; +modm::Fiber fiber_blink([] +{ + Board::LedD13::setOutput(); + while(true) + { + Board::LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() @@ -85,16 +83,8 @@ main() SpiMaster::initialize(); MODM_LOG_INFO << "==========IXM-42xxx Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "==================================" << modm::endl; - while (true) - { - imuThread.run(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_g474re/ixm42xxx/project.xml b/examples/nucleo_g474re/ixm42xxx/project.xml index 5262c37935..757a5a2efc 100644 --- a/examples/nucleo_g474re/ixm42xxx/project.xml +++ b/examples/nucleo_g474re/ixm42xxx/project.xml @@ -8,8 +8,7 @@ modm:math:geometry modm:platform:gpio modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/ixm42xxx_fifo/main.cpp b/examples/nucleo_g474re/ixm42xxx_fifo/main.cpp index 2f9b46bb8d..2fafb7316e 100644 --- a/examples/nucleo_g474re/ixm42xxx_fifo/main.cpp +++ b/examples/nucleo_g474re/ixm42xxx_fifo/main.cpp @@ -12,13 +12,10 @@ #include #include -#include #include +#include -namespace -{ - volatile bool interrupt = false; -} +std::atomic_bool interrupt{}; using SpiMaster = modm::platform::SpiMaster1; using Mosi = GpioA7; @@ -28,61 +25,57 @@ using Cs = GpioC5; using Int1 = GpioC3; -class ImuThread : public modm::pt::Protothread, public modm::ixm42xxx +class ImuThread : public modm::Fiber<>, public modm::ixm42xxx { using Transport = modm::Ixm42xxxTransportSpi< SpiMaster, Cs >; public: - ImuThread() : imu(fifoData), timer(std::chrono::milliseconds(500)) {} + ImuThread() : Fiber([this]{ run(); }) {} - bool +private: + void run() { - PT_BEGIN(); - Int1::setInput(modm::platform::Gpio::InputType::PullDown); Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { interrupt = true; }); - /// Initialize the IMU and verify that it is connected - PT_CALL(imu.initialize()); - while (not PT_CALL(imu.ping())) + while (not imu.ping()) { MODM_LOG_ERROR << "Cannot ping IXM-42xxx" << modm::endl; - PT_WAIT_UNTIL(timer.execute()); + modm::this_fiber::sleep_for(0.5s); } + /// Initialize the IMU and verify that it is connected + imu.initialize(); MODM_LOG_INFO << "IXM-42xxx Initialized" << modm::endl; MODM_LOG_INFO << "Fifo Buffer Size: " << fifoData.getFifoBufferSize() << modm::endl; /// Configure FIFO - PT_CALL(imu.updateRegister(Register::FIFO_CONFIG, FifoMode_t(FifoMode::StopOnFull))); - PT_CALL(imu.updateRegister(Register::FIFO_CONFIG1, FifoConfig1::FIFO_HIRES_EN | FifoConfig1::FIFO_TEMP_EN | FifoConfig1::FIFO_GYRO_EN | FifoConfig1::FIFO_ACCEL_EN)); - PT_CALL(imu.writeFifoWatermark(1024)); + imu.updateRegister(Register::FIFO_CONFIG, FifoMode_t(FifoMode::StopOnFull)); + imu.updateRegister(Register::FIFO_CONFIG1, FifoConfig1::FIFO_HIRES_EN | FifoConfig1::FIFO_TEMP_EN | FifoConfig1::FIFO_GYRO_EN | FifoConfig1::FIFO_ACCEL_EN); + imu.writeFifoWatermark(1024); /// Configure interrupt - PT_CALL(imu.updateRegister(Register::INT_CONFIG, IntConfig::INT1_MODE | IntConfig::INT1_DRIVE_CIRCUIT | IntConfig::INT1_POLARITY)); - PT_CALL(imu.updateRegister(Register::INT_CONFIG1, IntConfig1::INT_ASYNC_RESET)); - PT_CALL(imu.updateRegister(Register::INT_SOURCE0, IntSource0::FIFO_THS_INT1_EN | IntSource0::FIFO_FULL_INT1_EN, IntSource0::UI_DRDY_INT1_EN)); + imu.updateRegister(Register::INT_CONFIG, IntConfig::INT1_MODE | IntConfig::INT1_DRIVE_CIRCUIT | IntConfig::INT1_POLARITY); + imu.updateRegister(Register::INT_CONFIG1, IntConfig1::INT_ASYNC_RESET); + imu.updateRegister(Register::INT_SOURCE0, IntSource0::FIFO_THS_INT1_EN | IntSource0::FIFO_FULL_INT1_EN, IntSource0::UI_DRDY_INT1_EN); /// Configure data sensors - PT_CALL(imu.updateRegister(Register::GYRO_CONFIG0, GyroFs_t(GyroFs::dps2000) | GyroOdr_t(GyroOdr::kHz1))); - PT_CALL(imu.updateRegister(Register::ACCEL_CONFIG0, AccelFs_t(AccelFs::g16) | AccelOdr_t(AccelOdr::kHz1))); - PT_CALL(imu.updateRegister(Register::PWR_MGMT0, GyroMode_t(GyroMode::LowNoise) | AccelMode_t(AccelMode::LowNoise))); + imu.updateRegister(Register::GYRO_CONFIG0, GyroFs_t(GyroFs::dps2000) | GyroOdr_t(GyroOdr::kHz1)); + imu.updateRegister(Register::ACCEL_CONFIG0, AccelFs_t(AccelFs::g16) | AccelOdr_t(AccelOdr::kHz1)); + imu.updateRegister(Register::PWR_MGMT0, GyroMode_t(GyroMode::LowNoise) | AccelMode_t(AccelMode::LowNoise)); while (true) { - if (interrupt) - { - PT_CALL(imu.readRegister(Register::INT_STATUS, &intStatus.value)); - interrupt = false; - } + if (interrupt.exchange(false)) + imu.readRegister(Register::INT_STATUS, &intStatus.value); if (intStatus.any(IntStatus::FIFO_FULL_INT | IntStatus::FIFO_THS_INT)) { - if (PT_CALL(imu.readFifoData())) + if (imu.readFifoData()) { // Count packets in FIFO buffer and print contents of last packet uint16_t count = 0; @@ -108,21 +101,27 @@ class ImuThread : public modm::pt::Protothread, public modm::ixm42xxx } intStatus.reset(IntStatus::FIFO_FULL_INT | IntStatus::FIFO_THS_INT); } + modm::this_fiber::yield(); } - PT_END(); - } -private: + } /// Due to the non-deterministic nature of system operation, driver memory allocation should always be the largest size of 2080 bytes. modm::ixm42xxxdata::FifoData<2080> fifoData; modm::ixm42xxx::IntStatus_t intStatus; - modm::Ixm42xxx< Transport > imu; - - modm::PeriodicTimer timer; - + modm::Ixm42xxx< Transport > imu{fifoData}; } imuThread; +modm::Fiber fiber_blink([] +{ + Board::LedD13::setOutput(); + while(true) + { + Board::LedD13::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); + int main() { @@ -139,10 +138,6 @@ main() MODM_LOG_ERROR << "Error logging here" << modm::endl; MODM_LOG_INFO << "==================================" << modm::endl; - while (true) - { - imuThread.run(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/nucleo_g474re/ixm42xxx_fifo/project.xml b/examples/nucleo_g474re/ixm42xxx_fifo/project.xml index fcf707cd29..fd45570bc6 100644 --- a/examples/nucleo_g474re/ixm42xxx_fifo/project.xml +++ b/examples/nucleo_g474re/ixm42xxx_fifo/project.xml @@ -9,8 +9,7 @@ modm:platform:exti modm:platform:gpio modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/max31855/main.cpp b/examples/nucleo_g474re/max31855/main.cpp index f365e03b71..0f8568bd55 100644 --- a/examples/nucleo_g474re/max31855/main.cpp +++ b/examples/nucleo_g474re/max31855/main.cpp @@ -11,7 +11,6 @@ */ #include -#include #include using SpiMaster = modm::platform::SpiMaster2; @@ -20,80 +19,49 @@ using Cs = modm::platform::GpioA10; using Miso = modm::platform::GpioB14; using Sck = modm::platform::GpioB13; -using namespace Board; +modm::max31855::Data data; +modm::Max31855 thermocouple{data}; -class ThermocoupleThread : public modm::pt::Protothread +int +main() { -public: - ThermocoupleThread() : thermocouple(data) {} - - bool - run() - { - PT_BEGIN(); - - thermocouple.initialize(); - - MODM_LOG_INFO << "Max38155 initialized succeded" << modm::endl; - - while (true) - { - PT_CALL(thermocouple.readout()); + Board::initialize(); + Cs::setOutput(modm::Gpio::High); - switch (data.getFault()) - { - case modm::max31855::Fault::ShortCircuitVcc: - MODM_LOG_ERROR << "Thermocouple error short circuit vcc" << modm::endl; - break; + SpiMaster::connect(); + SpiMaster::initialize(); - case modm::max31855::Fault::ShortCircuitGnd: - MODM_LOG_ERROR << "Thermocouple error short circuit gnd" << modm::endl; - break; + MODM_LOG_INFO << "==========MAX 31855 Test==========" << modm::endl; - case modm::max31855::Fault::OpenCircuit: - MODM_LOG_ERROR << "Thermocouple error open circuit" << modm::endl; - break; + thermocouple.initialize(); + MODM_LOG_INFO << "Max38155 initialized succeded" << modm::endl; - default: - MODM_LOG_INFO << "Thermocouple Temperature: " << data.getThermocoupleTemperature() << " degrees Centigrade" << modm::endl; - MODM_LOG_INFO << "Internal Temperature: " << data.getReferenceJunctionTemperature() << " degrees Centigrade" << modm::endl; - break; - } + while (true) + { + thermocouple.readout(); - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } + switch (data.getFault()) + { + case modm::max31855::Fault::ShortCircuitVcc: + MODM_LOG_ERROR << "Thermocouple error short circuit vcc" << modm::endl; + break; - PT_END(); - } - -private: - modm::max31855::Data data; - modm::Max31855 thermocouple; - - modm::ShortTimeout timeout; -} thermocoupleThread; - -int -main() -{ - Board::initialize(); - Cs::setOutput(modm::Gpio::High); + case modm::max31855::Fault::ShortCircuitGnd: + MODM_LOG_ERROR << "Thermocouple error short circuit gnd" << modm::endl; + break; - SpiMaster::connect(); - SpiMaster::initialize(); + case modm::max31855::Fault::OpenCircuit: + MODM_LOG_ERROR << "Thermocouple error open circuit" << modm::endl; + break; - MODM_LOG_INFO << "==========MAX 31855 Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; + default: + MODM_LOG_INFO << "Thermocouple Temperature: " << data.getThermocoupleTemperature() << " degrees Centigrade" << modm::endl; + MODM_LOG_INFO << "Internal Temperature: " << data.getReferenceJunctionTemperature() << " degrees Centigrade" << modm::endl; + break; + } - while (true) - { - thermocoupleThread.run(); - } + modm::delay(1s); + } - return 0; -} \ No newline at end of file + return 0; +} diff --git a/examples/nucleo_g474re/max31855/project.xml b/examples/nucleo_g474re/max31855/project.xml index 506a31d432..42b215af3a 100644 --- a/examples/nucleo_g474re/max31855/project.xml +++ b/examples/nucleo_g474re/max31855/project.xml @@ -5,10 +5,7 @@ modm:driver:max31855 - modm:platform:gpio modm:platform:spi:2 - modm:processing:protothread - modm:processing:timer modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/ms5611/main.cpp b/examples/nucleo_g474re/ms5611/main.cpp index ff0b33d321..d708522ebe 100644 --- a/examples/nucleo_g474re/ms5611/main.cpp +++ b/examples/nucleo_g474re/ms5611/main.cpp @@ -10,11 +10,8 @@ */ #include -#include #include -using namespace Board; - using Cs = modm::platform::GpioC13; using Mosi = modm::platform::GpioA7; using Miso = modm::platform::GpioA6; @@ -22,84 +19,54 @@ using Sck = modm::platform::GpioA5; using SpiMaster = modm::platform::SpiMaster1; -class BarometerThread : public modm::pt::Protothread -{ -public: - BarometerThread() : barometer(data) {} - - bool - run() - { - PT_BEGIN(); - - while (PT_CALL(barometer.initialize()) == false) - { - MODM_LOG_ERROR << "Ms5611 PROM CRC failed" << modm::endl; - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - MODM_LOG_INFO << "Ms5611 initialized and PROM CRC succeded" << modm::endl; - - prom = data.getProm(); - MODM_LOG_INFO << "MS5611 PROM Contents" << modm::endl; - MODM_LOG_INFO << "C0: " << prom.data[0] << modm::endl; - MODM_LOG_INFO << "C1: " << prom.data[1] << modm::endl; - MODM_LOG_INFO << "C2: " << prom.data[2] << modm::endl; - MODM_LOG_INFO << "C3: " << prom.data[3] << modm::endl; - MODM_LOG_INFO << "C4: " << prom.data[4] << modm::endl; - MODM_LOG_INFO << "C5: " << prom.data[5] << modm::endl; - MODM_LOG_INFO << "C6: " << prom.data[6] << modm::endl; - MODM_LOG_INFO << "C7: " << prom.data[7] << modm::endl; - - while (true) - { - PT_CALL(barometer.readout()); - - data.getPressure(pressure); - MODM_LOG_INFO << "Pressure: " << pressure << " mbar" << modm::endl; - - data.getTemperature(temperature); - MODM_LOG_INFO << "Temperature: " << temperature << " degrees Centigrade" << modm::endl; - - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ms5611data::Data data; - modm::ms5611data::Prom prom; - modm::Ms5611 barometer; - - float pressure; - float temperature; - - modm::ShortTimeout timeout; -} barometerThread; +modm::ms5611data::Data data; +modm::ms5611data::Prom prom; +modm::Ms5611 barometer{data}; int main() { - Board::initialize(); - Cs::setOutput(modm::Gpio::High); - - SpiMaster::connect(); - SpiMaster::initialize(); - - MODM_LOG_INFO << "==========MS5611 Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; - - while (true) - { - barometerThread.run(); - } - - return 0; -} \ No newline at end of file + Board::initialize(); + Cs::setOutput(modm::Gpio::High); + + SpiMaster::connect(); + SpiMaster::initialize(); + + MODM_LOG_INFO << "==========MS5611 Test==========" << modm::endl; + + while (not barometer.initialize()) + { + MODM_LOG_ERROR << "Ms5611 PROM CRC failed" << modm::endl; + modm::delay(1s); + } + + MODM_LOG_INFO << "Ms5611 initialized and PROM CRC succeded" << modm::endl; + + prom = data.getProm(); + MODM_LOG_INFO << "MS5611 PROM Contents" << modm::endl; + MODM_LOG_INFO << "C0: " << prom.data[0] << modm::endl; + MODM_LOG_INFO << "C1: " << prom.data[1] << modm::endl; + MODM_LOG_INFO << "C2: " << prom.data[2] << modm::endl; + MODM_LOG_INFO << "C3: " << prom.data[3] << modm::endl; + MODM_LOG_INFO << "C4: " << prom.data[4] << modm::endl; + MODM_LOG_INFO << "C5: " << prom.data[5] << modm::endl; + MODM_LOG_INFO << "C6: " << prom.data[6] << modm::endl; + MODM_LOG_INFO << "C7: " << prom.data[7] << modm::endl; + + while (true) + { + barometer.readout(); + + float pressure; + data.getPressure(pressure); + MODM_LOG_INFO << "Pressure: " << pressure << " mbar" << modm::endl; + + float temperature; + data.getTemperature(temperature); + MODM_LOG_INFO << "Temperature: " << temperature << " degrees Centigrade" << modm::endl; + + modm::delay(1s); + } + + return 0; +} diff --git a/examples/nucleo_g474re/ms5611/project.xml b/examples/nucleo_g474re/ms5611/project.xml index d2af13d728..d95a395819 100644 --- a/examples/nucleo_g474re/ms5611/project.xml +++ b/examples/nucleo_g474re/ms5611/project.xml @@ -5,10 +5,7 @@ modm:driver:ms5611 - modm:platform:gpio modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_g474re/sx128x_lora/main.cpp b/examples/nucleo_g474re/sx128x_lora/main.cpp index 54b0282ed2..2d11f3d662 100644 --- a/examples/nucleo_g474re/sx128x_lora/main.cpp +++ b/examples/nucleo_g474re/sx128x_lora/main.cpp @@ -16,7 +16,6 @@ #include #include #include -#include #include using Sck = GpioA5; @@ -29,250 +28,231 @@ namespace namespace rx { - std::atomic_bool dio1 = false; - std::atomic_bool dio2 = false; - std::atomic_bool dio3 = false; + std::atomic_bool dio1 = false; + std::atomic_bool dio2 = false; + std::atomic_bool dio3 = false; } namespace tx { - std::atomic_bool dio1 = false; - std::atomic_bool dio2 = false; - std::atomic_bool dio3 = false; + std::atomic_bool dio1 = false; + std::atomic_bool dio2 = false; + std::atomic_bool dio3 = false; } static constexpr modm::sx128x::LoRa::ModulationParams modulationParams = { - .spreadingFactor = modm::sx128x::LoRa::ModulationParams::SpreadingFactor::Sf9, - .bandwidth = modm::sx128x::LoRa::ModulationParams::Bandwidth::Bw400, - .codingRate = modm::sx128x::LoRa::ModulationParams::CodingRate::Cr_Li_4_7 + .spreadingFactor = modm::sx128x::LoRa::ModulationParams::SpreadingFactor::Sf9, + .bandwidth = modm::sx128x::LoRa::ModulationParams::Bandwidth::Bw400, + .codingRate = modm::sx128x::LoRa::ModulationParams::CodingRate::Cr_Li_4_7 }; static constexpr modm::sx128x::LoRa::PacketParams packetParams = { - .preambleLength = 12, - .headerType = modm::sx128x::LoRa::PacketParams::HeaderType::Explicit, - .payloadLength = 4, - .crc = modm::sx128x::LoRa::PacketParams::Crc::Enable, - .invertIq = modm::sx128x::LoRa::PacketParams::InvertIq::Standard + .preambleLength = 12, + .headerType = modm::sx128x::LoRa::PacketParams::HeaderType::Explicit, + .payloadLength = 4, + .crc = modm::sx128x::LoRa::PacketParams::Crc::Enable, + .invertIq = modm::sx128x::LoRa::PacketParams::InvertIq::Standard }; } -class RxThread : public modm::sx128x, public modm::pt::Protothread +class RxThread : public modm::sx128x, public modm::Fiber<> { - using Reset = GpioB3; - using Busy = GpioB4; - using Dio1 = GpioB5; - using Dio2 = GpioB6; - using Dio3 = GpioB7; + using Reset = GpioB3; + using Busy = GpioB4; + using Dio1 = GpioB5; + using Dio2 = GpioB6; + using Dio3 = GpioB7; - using Nss = GpioD2; - using Transport = modm::Sx128xTransportSpi; + using Nss = GpioD2; + using Transport = modm::Sx128xTransportSpi; public: - RxThread() {} - - inline bool - run() - { - PT_BEGIN(); - - Nss::setOutput(modm::Gpio::High); - Reset::setOutput(modm::Gpio::Low); - Busy::setInput(modm::platform::Gpio::InputType::PullDown); - - Dio1::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio1 = true; }); - - Dio2::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio2 = true; }); - - Dio3::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio3 = true; }); - - PT_CALL(radio.reset()); - PT_CALL(radio.setStandby()); - - // Initialize the sx128x - PT_CALL(radio.setPacketType(PacketType::LoRa)); - PT_CALL(radio.setRfFrequency(2457_MHz / radio.frequencyLsb)); - PT_CALL(radio.setRegulatorMode(RegulatorMode::Ldo)); - PT_CALL(radio.setBufferBaseAddress(0, 0)); - PT_CALL(radio.setModulationParams(modulationParams)); - PT_CALL(radio.writeRegister(Register::SfAdditionalConfiguration, 0x32)); - PT_CALL(radio.writeRegister(Register::FrequencyErrorCorrection, 0x01)); - PT_CALL(radio.setPacketParams(packetParams)); - PT_CALL(radio.setDioIrqParams(Irq::RxDone | Irq::RxTxTimeout, Irq::RxDone, Irq::RxTxTimeout)); - PT_CALL(radio.setRx(sx128x::PeriodBase::ms1, 1000)); - - MODM_LOG_DEBUG << "Sx128x initialization complete!" << modm::endl; - - while (true) - { - if (rx::dio1.exchange(false)) - { - PT_CALL(radio.getIrqStatus(&irqStatus)); - if (irqStatus.any(Irq::RxDone)) - { - PT_CALL(radio.clearIrqStatus(Irq::RxDone | Irq::RxTxTimeout)); - PT_CALL(radio.setRx(sx128x::PeriodBase::ms1, 1000)); - - PT_CALL(radio.getRxBufferStatus(&rxBufferStatus)); - PT_CALL(radio.getPacketStatus(&packetStatus)); - PT_CALL(radio.readBuffer(rxBufferStatus.rxStartBufferPointer, std::span{buffer, rxBufferStatus.rxPayloadLength})); - - if (rxBufferStatus.rxPayloadLength > 0) - { - uint32_t counter; - std::memcpy((uint8_t *) &counter, buffer, sizeof(counter)); - MODM_LOG_DEBUG << "Received Message" << modm::endl; - MODM_LOG_DEBUG << "Counter: " << counter << modm::endl; - } - } - } - - if (rx::dio2.exchange(false)) - { - PT_CALL(radio.getIrqStatus(&irqStatus)); - if (irqStatus.any(Irq::RxTxTimeout)) - { - // RxTxTimeout Interrupt received! - // Clear irq and set to rx again. - PT_CALL(radio.clearIrqStatus(Irq::RxTxTimeout)); - PT_CALL(radio.setRx(sx128x::PeriodBase::ms1, 1000)); - MODM_LOG_DEBUG << "RxTxTimeout Interrupt!" << modm::endl; - } - } - PT_YIELD(); - } - PT_END(); - } + RxThread() : Fiber([this]{ run(); }) {} private: - Irq_t irqStatus; - PacketStatus packetStatus; - RxBufferStatus rxBufferStatus; - - modm::Sx128x< Transport, Reset, Busy > radio; - -private: - static constexpr size_t bufferSize = 256; - uint8_t buffer[bufferSize]; -} rxThread; - -class TxThread : public modm::sx128x, public modm::pt::Protothread + bool + run() + { + Nss::setOutput(modm::Gpio::High); + Reset::setOutput(modm::Gpio::Low); + Busy::setInput(modm::platform::Gpio::InputType::PullDown); + + Dio1::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio1 = true; }); + + Dio2::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio2 = true; }); + + Dio3::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { rx::dio3 = true; }); + + radio.reset(); + radio.setStandby(); + + // Initialize the sx128x + radio.setPacketType(PacketType::LoRa); + radio.setRfFrequency(2457_MHz / radio.frequencyLsb); + radio.setRegulatorMode(RegulatorMode::Ldo); + radio.setBufferBaseAddress(0, 0); + radio.setModulationParams(modulationParams); + radio.writeRegister(Register::SfAdditionalConfiguration, 0x32); + radio.writeRegister(Register::FrequencyErrorCorrection, 0x01); + radio.setPacketParams(packetParams); + radio.setDioIrqParams(Irq::RxDone | Irq::RxTxTimeout, Irq::RxDone, Irq::RxTxTimeout); + radio.setRx(sx128x::PeriodBase::ms1, 1000); + + MODM_LOG_DEBUG << "Sx128x initialization complete!" << modm::endl; + + while (true) + { + if (rx::dio1.exchange(false)) + { + radio.getIrqStatus(&irqStatus); + if (irqStatus.any(Irq::RxDone)) + { + radio.clearIrqStatus(Irq::RxDone | Irq::RxTxTimeout); + radio.setRx(sx128x::PeriodBase::ms1, 1000); + + PacketStatus packetStatus; + RxBufferStatus rxBufferStatus; + radio.getRxBufferStatus(&rxBufferStatus); + radio.getPacketStatus(&packetStatus); + radio.readBuffer(rxBufferStatus.rxStartBufferPointer, std::span{buffer, rxBufferStatus.rxPayloadLength}); + + if (rxBufferStatus.rxPayloadLength > 0) + { + uint32_t counter; + std::memcpy((uint8_t *) &counter, buffer, sizeof(counter)); + MODM_LOG_DEBUG << "Received Message" << modm::endl; + MODM_LOG_DEBUG << "Counter: " << counter << modm::endl; + } + } + } + + if (rx::dio2.exchange(false)) + { + radio.getIrqStatus(&irqStatus); + if (irqStatus.any(Irq::RxTxTimeout)) + { + // RxTxTimeout Interrupt received! + // Clear irq and set to rx again. + radio.clearIrqStatus(Irq::RxTxTimeout); + radio.setRx(sx128x::PeriodBase::ms1, 1000); + MODM_LOG_DEBUG << "RxTxTimeout Interrupt!" << modm::endl; + } + } + modm::this_fiber::yield(); + } + } + + modm::Sx128x< Transport, Reset, Busy > radio; + static constexpr size_t bufferSize = 256; + uint8_t buffer[bufferSize]; + Irq_t irqStatus; +} txFiber; + +class TxThread : public modm::sx128x, public modm::Fiber<> { - using Reset = modm::platform::GpioC2; - using Busy = modm::platform::GpioC3; - using Dio1 = modm::platform::GpioA0; - using Dio2 = modm::platform::GpioA1; - using Dio3 = modm::platform::GpioA2; + using Reset = modm::platform::GpioC2; + using Busy = modm::platform::GpioC3; + using Dio1 = modm::platform::GpioA0; + using Dio2 = modm::platform::GpioA1; + using Dio3 = modm::platform::GpioA2; - using Nss = modm::platform::GpioC1; - using Transport = modm::Sx128xTransportSpi; + using Nss = modm::platform::GpioC1; + using Transport = modm::Sx128xTransportSpi; public: - TxThread() : timer(std::chrono::milliseconds(500)) {} - - inline bool - run() - { - PT_BEGIN(); - - Nss::setOutput(modm::Gpio::High); - Reset::setOutput(modm::Gpio::Low); - Busy::setInput(modm::platform::Gpio::InputType::PullDown); - - Dio1::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio1 = true; }); - - Dio2::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio2 = true; }); - - Dio3::setInput(modm::platform::Gpio::InputType::PullDown); - Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio3 = true; }); - - - PT_CALL(radio.reset()); - PT_CALL(radio.setStandby()); - - // Initialize the sx128x - PT_CALL(radio.setPacketType(PacketType::LoRa)); - PT_CALL(radio.setRfFrequency(2457_MHz / radio.frequencyLsb)); - PT_CALL(radio.setRegulatorMode(RegulatorMode::Ldo)); - PT_CALL(radio.setBufferBaseAddress(0, 0)); - PT_CALL(radio.setModulationParams(modulationParams)); - PT_CALL(radio.writeRegister(Register::SfAdditionalConfiguration, 0x32)); - PT_CALL(radio.writeRegister(Register::FrequencyErrorCorrection, 0x01)); - PT_CALL(radio.setPacketParams(packetParams)); - PT_CALL(radio.setDioIrqParams(Irq::TxDone | Irq::RxTxTimeout, Irq::TxDone, Irq::RxTxTimeout)); - - MODM_LOG_DEBUG << "Sx128x initialization complete!" << modm::endl; - - while (true) - { - if (tx::dio1.exchange(false)) - { - PT_CALL(radio.getIrqStatus(&irqStatus)); - if (irqStatus.any(Irq::TxDone)) - { - PT_CALL(radio.clearIrqStatus(Irq::TxDone)); - irqStatus.reset(Irq::TxDone); - - MODM_LOG_DEBUG << "Message sent" << modm::endl; - MODM_LOG_DEBUG << "Counter: " << counter << modm::endl; - counter++; - } - } - - if (tx::dio2.exchange(false)) - { - PT_CALL(radio.getIrqStatus(&irqStatus)); - if (irqStatus.any(Irq::RxTxTimeout)) - { - PT_CALL(radio.clearIrqStatus(Irq::RxTxTimeout)); - irqStatus.reset(Irq::RxTxTimeout); - MODM_LOG_DEBUG << "Received a timeout" << modm::endl; - } - } - - if (timer.execute()) - { - PT_CALL(radio.writeBuffer(0, std::span{(uint8_t *) &counter, sizeof(counter)})); - PT_CALL(radio.setTx(PeriodBase::ms1, 100)); - } - PT_YIELD(); - } - - PT_END(); - } + TxThread() : Fiber([this]{ run(); }) {} private: - Irq_t irqStatus; - modm::Sx128x< Transport, Reset, Busy > radio; + bool + run() + { + Nss::setOutput(modm::Gpio::High); + Reset::setOutput(modm::Gpio::Low); + Busy::setInput(modm::platform::Gpio::InputType::PullDown); + + Dio1::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio1 = true; }); + + Dio2::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio2 = true; }); + + Dio3::setInput(modm::platform::Gpio::InputType::PullDown); + Exti::connect(Exti::Trigger::RisingEdge, [](uint8_t) { tx::dio3 = true; }); + + + radio.reset(); + radio.setStandby(); + + // Initialize the sx128x + radio.setPacketType(PacketType::LoRa); + radio.setRfFrequency(2457_MHz / radio.frequencyLsb); + radio.setRegulatorMode(RegulatorMode::Ldo); + radio.setBufferBaseAddress(0, 0); + radio.setModulationParams(modulationParams); + radio.writeRegister(Register::SfAdditionalConfiguration, 0x32); + radio.writeRegister(Register::FrequencyErrorCorrection, 0x01); + radio.setPacketParams(packetParams); + radio.setDioIrqParams(Irq::TxDone | Irq::RxTxTimeout, Irq::TxDone, Irq::RxTxTimeout); + + MODM_LOG_DEBUG << "Sx128x initialization complete!" << modm::endl; + + modm::PeriodicTimer timer{500ms}; + uint32_t counter{}; + while (true) + { + if (tx::dio1.exchange(false)) + { + radio.getIrqStatus(&irqStatus); + if (irqStatus.any(Irq::TxDone)) + { + radio.clearIrqStatus(Irq::TxDone); + irqStatus.reset(Irq::TxDone); + + MODM_LOG_DEBUG << "Message sent" << modm::endl; + MODM_LOG_DEBUG << "Counter: " << counter << modm::endl; + counter++; + } + } + + if (tx::dio2.exchange(false)) + { + radio.getIrqStatus(&irqStatus); + if (irqStatus.any(Irq::RxTxTimeout)) + { + radio.clearIrqStatus(Irq::RxTxTimeout); + irqStatus.reset(Irq::RxTxTimeout); + MODM_LOG_DEBUG << "Received a timeout" << modm::endl; + } + } + + if (timer.execute()) + { + radio.writeBuffer(0, std::span{(uint8_t *) &counter, sizeof(counter)}); + radio.setTx(PeriodBase::ms1, 100); + } + modm::this_fiber::yield(); + } + } - uint32_t counter = 0; - modm::PeriodicTimer timer; -}; +private: + Irq_t irqStatus; + modm::Sx128x< Transport, Reset, Busy > radio; +} txFiber; int main() { - Board::initialize(); + Board::initialize(); - SpiMaster::connect(); - SpiMaster::initialize(); + SpiMaster::connect(); + SpiMaster::initialize(); - MODM_LOG_INFO << "==========SX128x Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; + MODM_LOG_INFO << "==========SX128x Test==========" << modm::endl; - while (true) - { - rxThread.run(); - } - - return 0; -} \ No newline at end of file + modm::fiber::Scheduler::run(); + return 0; +} diff --git a/examples/nucleo_g474re/sx128x_lora/project.xml b/examples/nucleo_g474re/sx128x_lora/project.xml index 544f5d2171..1fe7ec0a43 100644 --- a/examples/nucleo_g474re/sx128x_lora/project.xml +++ b/examples/nucleo_g474re/sx128x_lora/project.xml @@ -6,10 +6,8 @@ modm:driver:sx128x modm:platform:exti - modm:platform:gpio modm:platform:spi:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons - \ No newline at end of file + diff --git a/examples/nucleo_h723zg/bmi088/i2c/project.xml b/examples/nucleo_h723zg/bmi088/i2c/project.xml index 797c04a836..2050231053 100644 --- a/examples/nucleo_h723zg/bmi088/i2c/project.xml +++ b/examples/nucleo_h723zg/bmi088/i2c/project.xml @@ -2,11 +2,9 @@ modm:nucleo-h723zg - modm:build:scons - modm:processing:fiber modm:platform:exti modm:platform:i2c:1 modm:driver:bmi088 diff --git a/examples/nucleo_h723zg/bmi088/spi/project.xml b/examples/nucleo_h723zg/bmi088/spi/project.xml index 0ee7b8a80b..4c941b592e 100644 --- a/examples/nucleo_h723zg/bmi088/spi/project.xml +++ b/examples/nucleo_h723zg/bmi088/spi/project.xml @@ -2,11 +2,9 @@ modm:nucleo-h723zg - modm:build:scons - modm:processing:fiber modm:platform:dma modm:platform:exti modm:platform:spi:2 diff --git a/examples/nucleo_l432kc/gyroscope/main.cpp b/examples/nucleo_l432kc/gyroscope/main.cpp index f9fb23cb13..dfbd803a3a 100644 --- a/examples/nucleo_l432kc/gyroscope/main.cpp +++ b/examples/nucleo_l432kc/gyroscope/main.cpp @@ -14,7 +14,6 @@ #include #include -#include #include // Example for L3gd20 gyroscope connected to SPI USART interface @@ -31,63 +30,13 @@ struct UartSpi using Transport = modm::Lis3TransportSpi; -namespace -{ - modm::l3gd20::Data data; - modm::L3gd20 gyro{data}; -} - -class ReaderThread : public modm::pt::Protothread -{ -public: - bool - update() - { - PT_BEGIN(); - - // ping the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(gyro.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - Board::LedD13::set(); - PT_WAIT_UNTIL(timeout.isExpired()); - Board::LedD13::reset(); - } - - PT_CALL(gyro.configure(gyro.Scale::Dps250, gyro.MeasurementRate::Hz380)); - - while (true) - { - PT_CALL(gyro.readRotation()); - - averageX.update(gyro.getData().getX()); - averageY.update(gyro.getData().getY()); - averageZ.update(gyro.getData().getZ()); - - MODM_LOG_INFO.printf("x: %.2f, y: %.2f, z: %.2f \n", - double(averageX.getValue()), - double(averageY.getValue()), - double(averageZ.getValue())); - - timeout.restart(50ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } +modm::l3gd20::Data data; +modm::L3gd20 gyro{data}; -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageX; - modm::filter::MovingAverage averageY; - modm::filter::MovingAverage averageZ; -}; -ReaderThread reader; +modm::filter::MovingAverage averageX; +modm::filter::MovingAverage averageY; +modm::filter::MovingAverage averageZ; int main() @@ -97,8 +46,30 @@ main() UartSpi::Master::connect(); UartSpi::Master::initialize(); - while (true) { - reader.update(); + // ping the device until it responds + while(not gyro.ping()) + { + Board::LedD13::set(); + modm::delay(100ms); + Board::LedD13::reset(); + } + + gyro.configure(gyro.Scale::Dps250, gyro.MeasurementRate::Hz380); + + while (true) + { + gyro.readRotation(); + + averageX.update(gyro.getData().getX()); + averageY.update(gyro.getData().getY()); + averageZ.update(gyro.getData().getZ()); + + MODM_LOG_INFO.printf("x: %.2f, y: %.2f, z: %.2f \n", + double(averageX.getValue()), + double(averageY.getValue()), + double(averageZ.getValue())); + + modm::delay(50ms); } return 0; diff --git a/examples/nucleo_l432kc/gyroscope/project.xml b/examples/nucleo_l432kc/gyroscope/project.xml index 8fd87a3f22..917406267d 100644 --- a/examples/nucleo_l432kc/gyroscope/project.xml +++ b/examples/nucleo_l432kc/gyroscope/project.xml @@ -7,8 +7,6 @@ modm:driver:l3gd20 modm:math:filter modm:platform:uart.spi:1 - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/nucleo_l452re/graphics_touch/main.cpp b/examples/nucleo_l452re/graphics_touch/main.cpp index f71ed9b5d5..a7e9b72588 100644 --- a/examples/nucleo_l452re/graphics_touch/main.cpp +++ b/examples/nucleo_l452re/graphics_touch/main.cpp @@ -113,7 +113,7 @@ main() { LedGreen::set(); - std::tie(X, Y, Z) = RF_CALL_BLOCKING(touchController.getRawValues()); + std::tie(X, Y, Z) = touchController.getRawValues(); tftController.setColor(Red); tftController.fillRectangle({30, 50}, 90, 115); tftController.setColor(Black); @@ -127,8 +127,8 @@ main() tftController.setColor(Red); tftController.fillRectangle({30, 220}, 120, 35); tftController.setColor(Black); - if(RF_CALL_BLOCKING(touchController.isTouched())) { - std::tie(X, Y) = RF_CALL_BLOCKING(touchController.getTouchPosition()); + if(touchController.isTouched()) { + std::tie(X, Y) = touchController.getTouchPosition(); tftController.setCursor(5, 220); tftController << "> (" << X << "," << Y << ")"; } diff --git a/examples/nucleo_l452re/lvgl/main.cpp b/examples/nucleo_l452re/lvgl/main.cpp index 0b05535cba..6f9843489a 100644 --- a/examples/nucleo_l452re/lvgl/main.cpp +++ b/examples/nucleo_l452re/lvgl/main.cpp @@ -67,9 +67,9 @@ static modm_aligned(4) lv_color_t buf[buf_size]; void my_touchpad_read(lv_indev_t*, lv_indev_data_t* data) { - data->state = RF_CALL_BLOCKING(touchController.isTouched()) ? LV_INDEV_STATE_PRESSED : LV_INDEV_STATE_RELEASED; + data->state = touchController.isTouched() ? LV_INDEV_STATE_PRESSED : LV_INDEV_STATE_RELEASED; if(data->state == LV_INDEV_STATE_PRESSED) { - auto xy = RF_CALL_BLOCKING(touchController.getTouchPosition()); + auto xy = touchController.getTouchPosition(); data->point.x = std::get<0>(xy); data->point.y = std::get<1>(xy); } diff --git a/examples/nucleo_l476rg/i2c_test/main.cpp b/examples/nucleo_l476rg/i2c_test/main.cpp index 916217be29..5fb8b16400 100644 --- a/examples/nucleo_l476rg/i2c_test/main.cpp +++ b/examples/nucleo_l476rg/i2c_test/main.cpp @@ -9,10 +9,7 @@ */ #include -#include - -#include -#include +#include #include /* @@ -37,14 +34,14 @@ class I2cTestDevice : public modm::I2cDevice public: I2cTestDevice(uint8_t address = 0x3C); - modm::ResumableResult - write(uint16_t len); + bool + write(size_t len); - modm::ResumableResult - read(uint16_t len); + bool + read(size_t len); - modm::ResumableResult - writeRead(uint16_t write_len, uint16_t read_len); + bool + writeRead(size_t write_len, size_t read_len); private: uint8_t buffer[1024]; @@ -57,72 +54,45 @@ I2cTestDevice::I2cTestDevice(uint8_t address) : } template < typename I2cMaster > -modm::ResumableResult -I2cTestDevice::write(uint16_t len) +bool +I2cTestDevice::write(size_t len) { - RF_BEGIN(); - - buffer[0] = 0xaa; - buffer[1] = 0x55; - buffer[2] = 0x82; - buffer[3] = 0x11; - buffer[4] = 0x22; - - for (uint16_t ii = 0; ii < 1024; ++ii) { + for (size_t ii = 0; ii < 1024; ++ii) { buffer[ii] = ii + 1; } buffer[255] = 0x82; - this->transaction.configureWrite(buffer, len); - - if (not RF_CALL( this->runTransaction() )) { - RF_RETURN(false); - } - - RF_END_RETURN(true); + return modm::I2cDevice::write(buffer, len); } template < typename I2cMaster > -modm::ResumableResult -I2cTestDevice::read(uint16_t len) +bool +I2cTestDevice::read(size_t len) { - RF_BEGIN(); + if (not modm::I2cDevice::read(buffer, len)) return false; - this->transaction.configureRead(buffer, len); - - if (not RF_CALL( this->runTransaction() )) { - RF_RETURN(false); - } - for (uint16_t ii = 0; ii < len; ++ii) { + for (size_t ii = 0; ii < len; ++ii) { MODM_LOG_DEBUG.printf("%02x ", buffer[ii]); } MODM_LOG_DEBUG << modm::endl; - - RF_END_RETURN(true); + return true; } template < typename I2cMaster > -modm::ResumableResult -I2cTestDevice::writeRead(uint16_t write_len, uint16_t read_len) +bool +I2cTestDevice::writeRead(size_t write_len, size_t read_len) { - RF_BEGIN(); - - for (uint16_t ii = 0; ii < 1024; ++ii) { + for (size_t ii = 0; ii < 1024; ++ii) { buffer[ii] = ii + 1; } buffer[255] = 0x82; + if (not modm::I2cDevice::writeRead(buffer, write_len, buffer, read_len)) + return false; - this->transaction.configureWriteRead(buffer, write_len, buffer, read_len); - - if (not RF_CALL( this->runTransaction() )) { - RF_RETURN(false); - } - - for (uint16_t ii = 0; ii < read_len; ++ii) { + for (size_t ii = 0; ii < read_len; ++ii) { MODM_LOG_DEBUG.printf("%02x ", buffer[ii]); } MODM_LOG_DEBUG << modm::endl; - - RF_END_RETURN(true); + return true; } I2cTestDevice< MyI2cMaster > i2c; @@ -138,32 +108,33 @@ main() LedGreen::set(); - RF_CALL_BLOCKING(i2c.ping()); + i2c.ping(); modm::delay(25us); - RF_CALL_BLOCKING(i2c.write(0)); + i2c.write(0); modm::delay(25us); - RF_CALL_BLOCKING(i2c.write(1)); + i2c.write(1); modm::delay(25us); - RF_CALL_BLOCKING(i2c.write(2)); + i2c.write(2); modm::delay(25us); - RF_CALL_BLOCKING(i2c.writeRead(0, 5)); + i2c.writeRead(0, 5); modm::delay(25us); - RF_CALL_BLOCKING(i2c.writeRead(1, 5)); + i2c.writeRead(1, 5); modm::delay(25us); - RF_CALL_BLOCKING(i2c.writeRead(2, 5)); + i2c.writeRead(2, 5); modm::delay(25us); // Blink if run without hanging. - while(true) { + while(true) + { LedGreen::toggle(); modm::delay(500ms); - }; + } return 0; } diff --git a/examples/nucleo_l476rg/i2c_test/project.xml b/examples/nucleo_l476rg/i2c_test/project.xml index aa169b452c..ed2434fbf1 100644 --- a/examples/nucleo_l476rg/i2c_test/project.xml +++ b/examples/nucleo_l476rg/i2c_test/project.xml @@ -6,9 +6,7 @@ modm:architecture:i2c.device modm:platform:i2c:1 - modm:processing:protothread - modm:processing:resumable - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/rp_pico/logger/main.cpp b/examples/rp_pico/logger/main.cpp index 21f840fab6..33ec8b8e3d 100644 --- a/examples/rp_pico/logger/main.cpp +++ b/examples/rp_pico/logger/main.cpp @@ -15,8 +15,6 @@ #include #include -#include -#include // ---------------------------------------------------------------------------- // Set the log level @@ -32,41 +30,6 @@ modm::log::Logger modm::log::info(loggerDevice); modm::log::Logger modm::log::warning(loggerDevice); modm::log::Logger modm::log::error(loggerDevice); -class BlinkThread : public modm::pt::Protothread -{ -public: - BlinkThread() { timeout.restart(100ms); } - - bool - update() - { - PT_BEGIN(); - - while (true) - { - Board::LedGreen::reset(); - - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(100ms); - - Board::LedGreen::set(); - - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(900ms); - - MODM_LOG_INFO << "Seconds since reboot: " << ++uptime << modm::endl; - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - uint32_t uptime; -}; - -BlinkThread blinkThread; - // ---------------------------------------------------------------------------- int main() @@ -84,7 +47,17 @@ main() MODM_LOG_WARNING << "warning" << modm::endl; MODM_LOG_ERROR << "error" << modm::endl; - while (true) { blinkThread.update(); } + uint32_t uptime{}; + while (true) + { + Board::LedGreen::reset(); + modm::delay(100ms); + + Board::LedGreen::set(); + modm::delay(900ms); + + MODM_LOG_INFO << "Seconds since reboot: " << ++uptime << modm::endl; + } return 0; } diff --git a/examples/rp_pico/logger/project.xml b/examples/rp_pico/logger/project.xml index 82492276ab..4acdae5497 100644 --- a/examples/rp_pico/logger/project.xml +++ b/examples/rp_pico/logger/project.xml @@ -5,10 +5,7 @@ modm:debug - modm:platform:gpio modm:platform:uart:0 - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/rp_pico/mclogger/main.cpp b/examples/rp_pico/mclogger/main.cpp index 17fec27ffa..8d5b34fcd7 100644 --- a/examples/rp_pico/mclogger/main.cpp +++ b/examples/rp_pico/mclogger/main.cpp @@ -11,8 +11,7 @@ #include #include -#include -#include +#include #include // ---------------------------------------------------------------------------- @@ -45,21 +44,20 @@ static multicore::Mutex log_mutex; #endif template -class Thread : public modm::pt::Protothread +class Thread : public modm::Fiber<> { static constexpr auto delay = 10ms + 1ms * Instance; public: - Thread() { timeout.restart(delay); } + Thread() : Fiber([this]{ run(); }, Core == 0 ? modm::fiber::Start::Now : modm::fiber::Start::Later) {} - bool - update() + void + run() { - PT_BEGIN(); + uint32_t uptime{}; while (true) { - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(delay); + modm::this_fiber::sleep_for(delay); { // try without this line for intermixed output LOG_GUARD(); @@ -67,42 +65,27 @@ class Thread : public modm::pt::Protothread << " thread: " << Instance << " uptime: " << ++uptime << modm::endl; } } - - PT_END(); } - -private: - modm::ShortTimeout timeout; - uint32_t uptime; }; -template -class Threads -{ -private: - Thread t0; - Thread t1; - Thread t2; - Thread t3; - -public: - void - update() - { - t0.update(); - t1.update(); - t2.update(); - t3.update(); - } -}; +Thread<0, 0> t00; +Thread<0, 1> t01; +Thread<0, 2> t02; +Thread<0, 3> t03; -Threads<0> core0; -Threads<1> core1; +Thread<1, 0> t10; +Thread<1, 1> t11; +Thread<1, 2> t12; +Thread<1, 3> t13; void core1_main() { - while (true) { core1.update(); } + t10.start(); + t11.start(); + t12.start(); + t13.start(); + modm::fiber::Scheduler::run(); } // ---------------------------------------------------------------------------- @@ -125,8 +108,6 @@ main() INIT_GUARD(); multicore::Core1::run(core1_main); - - while (true) { core0.update(); } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/rp_pico/mclogger/project.xml b/examples/rp_pico/mclogger/project.xml index 8f05615fd8..eaab88f459 100644 --- a/examples/rp_pico/mclogger/project.xml +++ b/examples/rp_pico/mclogger/project.xml @@ -8,8 +8,7 @@ modm:platform:gpio modm:platform:uart:0 modm:platform:multicore - modm:processing:timer - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/rp_pico/rtc_mcp7941x/main.cpp b/examples/rp_pico/rtc_mcp7941x/main.cpp index 5a2a280f48..e7bd3600a0 100644 --- a/examples/rp_pico/rtc_mcp7941x/main.cpp +++ b/examples/rp_pico/rtc_mcp7941x/main.cpp @@ -12,8 +12,7 @@ #include #include #include -#include -#include +#include #include @@ -35,72 +34,65 @@ using MyI2cMaster = modm::platform::I2cMaster0; using I2cScl = modm::platform::Gpio1; using I2cSda = modm::platform::Gpio0; +modm::Mcp7941x rtc{}; -class RtcThread : public modm::pt::Protothread +modm::Fiber fiber_rtc([] { -public: - bool - update() - { - PT_BEGIN(); + if(rtc.oscillatorRunning()) { + MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + } + else { + MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + } - if(PT_CALL(rtc.oscillatorRunning())) { - MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; - } - else { - MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; - } + MODM_LOG_INFO << "Setting date/time to 01.01.2020 00:00.00h" << modm::endl; + modm::mcp7941x::DateTime dateTime{}; + dateTime.days = 1; + dateTime.months = 1; + dateTime.years = 20; + dateTime.hours = 0; + dateTime.minutes = 0; + dateTime.seconds = 0; + while(not rtc.setDateTime(dateTime)) { + MODM_LOG_ERROR << "Unable to set date/time." << modm::endl; + modm::this_fiber::sleep_for(500ms); + } - MODM_LOG_INFO << "Setting date/time to 01.01.2020 00:00.00h" << modm::endl; - dateTime.days = 1; - dateTime.months = 1; - dateTime.years = 20; - dateTime.hours = 0; - dateTime.minutes = 0; - dateTime.seconds = 0; - while(not PT_CALL(rtc.setDateTime(dateTime))) { - MODM_LOG_ERROR << "Unable to set date/time." << modm::endl; - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + modm::this_fiber::sleep_for(500ms); - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); + if(rtc.oscillatorRunning()) { + MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + } + else { + MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + } - if(PT_CALL(rtc.oscillatorRunning())) { - MODM_LOG_ERROR << "RTC oscillator is running." << modm::endl; + while (true) + { + auto dateTime2 = rtc.getDateTime(); + if(dateTime2.has_value()) { + MODM_LOG_INFO.printf("%02u.%02u.%02u ", dateTime2->days, dateTime2->months, dateTime2->years); + MODM_LOG_INFO.printf("%02u:%02u.%02uh\n", dateTime2->hours, dateTime2->minutes, dateTime2->seconds); } else { - MODM_LOG_ERROR << "RTC oscillator is NOT running." << modm::endl; + MODM_LOG_ERROR << "Unable to read from RTC." << modm::endl; } - while (true) - { - dateTime2 = PT_CALL(rtc.getDateTime()); - if(dateTime2.has_value()) { - MODM_LOG_INFO.printf("%02u.%02u.%02u ", dateTime2->days, dateTime2->months, dateTime2->years); - MODM_LOG_INFO.printf("%02u:%02u.%02uh\n", dateTime2->hours, dateTime2->minutes, dateTime2->seconds); - } - else { - MODM_LOG_ERROR << "Unable to read from RTC." << modm::endl; - } - - timeout.restart(2500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); + modm::this_fiber::sleep_for(2.5s); } +}); -private: - modm::Mcp7941x rtc{}; - modm::mcp7941x::DateTime dateTime{}; - std::optional dateTime2{}; - modm::ShortTimeout timeout; -}; - +modm::Fiber fiber_blink([] +{ + Board::LedGreen::setOutput(); + while(true) + { + Board::LedGreen::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); -using namespace Board; +modm::Mcp7941xEeprom eeprom{}; int main() @@ -111,37 +103,28 @@ main() Uart0::connect(); Uart0::initialize(); - Leds::setOutput(); - MyI2cMaster::connect(); - MyI2cMaster::initialize(); + MyI2cMaster::initialize(); MODM_LOG_INFO << "RTC MCP7941x Example on Raspberry Pico" << modm::endl; - modm::Mcp7941xEeprom eeprom{}; - if (auto data = RF_CALL_BLOCKING(eeprom.getUniqueId())) { - MODM_LOG_INFO << "Unique ID (EUI-48/64): "; - MODM_LOG_INFO << modm::hex << (*data)[0] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[1] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[2] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[3] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[4] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[5] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[6] << modm::ascii << ":"; - MODM_LOG_INFO << modm::hex << (*data)[7] << modm::ascii << modm::endl; + + if (auto data = eeprom.getUniqueId()) { + MODM_LOG_INFO << "Unique ID (EUI-48/64): " << modm::hex; + MODM_LOG_INFO << (*data)[0] << ":"; + MODM_LOG_INFO << (*data)[1] << ":"; + MODM_LOG_INFO << (*data)[2] << ":"; + MODM_LOG_INFO << (*data)[3] << ":"; + MODM_LOG_INFO << (*data)[4] << ":"; + MODM_LOG_INFO << (*data)[5] << ":"; + MODM_LOG_INFO << (*data)[6] << ":"; + MODM_LOG_INFO << (*data)[7] << modm::endl; } else { MODM_LOG_ERROR << "Unable to read unique ID from RTC." << modm::endl; } modm::delay(500ms); - RtcThread rtcThread; - - while (true) - { - LedGreen::toggle(); - rtcThread.update(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/rp_pico/rtc_mcp7941x/project.xml b/examples/rp_pico/rtc_mcp7941x/project.xml index b24d0343e3..ce4f0f63d1 100644 --- a/examples/rp_pico/rtc_mcp7941x/project.xml +++ b/examples/rp_pico/rtc_mcp7941x/project.xml @@ -10,8 +10,7 @@ modm:io modm:platform:i2c:0 modm:platform:uart:0 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/samv71_xplained_ultra/i2c-eeprom/at24mac402/main.cpp b/examples/samv71_xplained_ultra/i2c-eeprom/at24mac402/main.cpp index d4413f455f..aaa8824095 100644 --- a/examples/samv71_xplained_ultra/i2c-eeprom/at24mac402/main.cpp +++ b/examples/samv71_xplained_ultra/i2c-eeprom/at24mac402/main.cpp @@ -35,12 +35,12 @@ int main() // with A0 = A1 = A2 = 1 connected to 3.3V modm::At24Mac402 eeprom{0x57}; - MODM_LOG_INFO << "EEPROM detected: " << RF_CALL_BLOCKING(eeprom.ping()) << "\n\n"; + MODM_LOG_INFO << "EEPROM detected: " << eeprom.ping() << "\n\n"; std::array buffer{}; // Read pre-programmed MAC address - bool readSuccess = RF_CALL_BLOCKING(eeprom.readMac(buffer)); + bool readSuccess = eeprom.readMac(buffer); if (readSuccess) { MODM_LOG_INFO.printf("MAC: %02x:%02x:%02x:%02x:%02x:%02x\n\n", @@ -55,7 +55,7 @@ int main() // Write 4 data bytes to address 0x80 /*constexpr std::array data = {0xAA, 0xBB, 0xCC, 0xDD}; - const bool writeSuccess = RF_CALL_BLOCKING(eeprom.write(0x80, data.data(), 4)); + const bool writeSuccess = eeprom.write(0x80, data.data(), 4); MODM_LOG_INFO << "write successful: " << writeSuccess << "\n\n";*/ // Read 4 data bytes from address 0x80 @@ -63,7 +63,7 @@ int main() readSuccess = false; while (!readSuccess) { - readSuccess = RF_CALL_BLOCKING(eeprom.read(0x80, buffer.data(), buffer.size())); + readSuccess = eeprom.read(0x80, buffer.data(), buffer.size()); } MODM_LOG_INFO.printf("data: 0x%02x 0x%02x 0x%02x 0x%02x\n\n", buffer[0], buffer[1], buffer[2], buffer[3]); diff --git a/examples/samv71_xplained_ultra/i2c-eeprom/generic/main.cpp b/examples/samv71_xplained_ultra/i2c-eeprom/generic/main.cpp index 01f890df21..02c946a0a3 100644 --- a/examples/samv71_xplained_ultra/i2c-eeprom/generic/main.cpp +++ b/examples/samv71_xplained_ultra/i2c-eeprom/generic/main.cpp @@ -38,11 +38,11 @@ int main() constexpr auto AddressWidth = 1; // use 2 for 16 bit address EEPROMs modm::I2cEeprom eeprom{0x57}; - MODM_LOG_INFO << "EEPROM detected: " << RF_CALL_BLOCKING(eeprom.ping()) << "\n\n"; + MODM_LOG_INFO << "EEPROM detected: " << eeprom.ping() << "\n\n"; // Write 4 data bytes to address 0x80 /*constexpr std::array data = {0xAA, 0xBB, 0xCC, 0xDD}; - const bool writeSuccess = RF_CALL_BLOCKING(eeprom.write(0x80, data.data(), 4)); + const bool writeSuccess = eeprom.write(0x80, data.data(), 4); MODM_LOG_INFO << "write successful: " << writeSuccess << "\n\n";*/ // Read 4 data bytes from address 0x80 @@ -51,7 +51,7 @@ int main() // retry read until device responds after finishing previous write while (!readSuccess) { - readSuccess = RF_CALL_BLOCKING(eeprom.read(0x80, buffer.data(), buffer.size())); + readSuccess = eeprom.read(0x80, buffer.data(), buffer.size()); } MODM_LOG_INFO << "read successful: " << readSuccess << "\n"; MODM_LOG_INFO.printf("data: 0x%02x 0x%02x 0x%02x 0x%02x\n\n", buffer[0], buffer[1], buffer[2], buffer[3]); diff --git a/examples/samv71_xplained_ultra/mcp3008/main.cpp b/examples/samv71_xplained_ultra/mcp3008/main.cpp index b2ad1d2c16..3600e948c4 100644 --- a/examples/samv71_xplained_ultra/mcp3008/main.cpp +++ b/examples/samv71_xplained_ultra/mcp3008/main.cpp @@ -45,7 +45,7 @@ int main() while (true) { for (auto [i, ch] : channels) { - const auto value = RF_CALL_BLOCKING(adc.read(ch)); + const auto value = adc.read(ch); MODM_LOG_INFO << "channel " << i << ": " << value << '\n'; } diff --git a/examples/stm32_f4ve/flash/main.cpp b/examples/stm32_f4ve/flash/main.cpp index aecbc806b8..1b0d132cd3 100644 --- a/examples/stm32_f4ve/flash/main.cpp +++ b/examples/stm32_f4ve/flash/main.cpp @@ -45,13 +45,13 @@ void doMemoryTest() for (uint16_t iteration = 0; iteration < 4; iteration++) { uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; - if (not RF_CALL_BLOCKING(storageDevice.erase(0, TestMemorySize))) { + if (not storageDevice.erase(0, TestMemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; return; } for (uint32_t ii = 0; ii < TestMemorySize; ii += Board::w25q16::BlockSize) { - if (not RF_CALL_BLOCKING(storageDevice.program(pattern, ii, Board::w25q16::BlockSize))) { + if (not storageDevice.program(pattern, ii, Board::w25q16::BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; return; } @@ -59,7 +59,7 @@ void doMemoryTest() } for (uint32_t ii = 0; ii < TestMemorySize; ii += Board::w25q16::BlockSize) { - if (not RF_CALL_BLOCKING(storageDevice.read(bufferC, ii, Board::w25q16::BlockSize))) { + if (not storageDevice.read(bufferC, ii, Board::w25q16::BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; return; } @@ -101,18 +101,18 @@ main() MODM_LOG_INFO << "Erasing complete flash chip... (This may take a while)" << modm::endl; - if (not RF_CALL_BLOCKING(storageDevice.initialize())) { + if (not storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; } - else if (not RF_CALL_BLOCKING(storageDevice.erase(0, Board::w25q16::MemorySize))) { + else if (not storageDevice.erase(0, Board::w25q16::MemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; } else { - auto id = RF_CALL_BLOCKING(storageDevice.readId()); + auto id = storageDevice.readId(); MODM_LOG_INFO << "deviceId=" << id.deviceId << " manufacturerId=" << id.manufacturerId; MODM_LOG_INFO << " deviceType=" << id.deviceType << modm::endl; - MODM_LOG_INFO << "status=" << static_cast(RF_CALL_BLOCKING(storageDevice.readStatus())) << modm::endl; + MODM_LOG_INFO << "status=" << static_cast(storageDevice.readStatus()) << modm::endl; MODM_LOG_INFO << "Press USER button to start the memory test." << modm::endl; initializeSuccess = true; diff --git a/examples/stm32f072_discovery/rotation/main.cpp b/examples/stm32f072_discovery/rotation/main.cpp index a7b7a6905a..8acc7e94ff 100644 --- a/examples/stm32f072_discovery/rotation/main.cpp +++ b/examples/stm32f072_discovery/rotation/main.cpp @@ -11,8 +11,6 @@ // ---------------------------------------------------------------------------- #include -#include -#include #include using namespace Board; @@ -29,51 +27,7 @@ using LedRing = SoftwareGpioPort< Board::l3g::Gyroscope::Data data; // and hand it to the sensor driver Board::l3g::Gyroscope gyro(data); - - -class ReaderThread : public modm::pt::Protothread -{ -public: - bool - update() - { - PT_BEGIN(); - - // initialize with limited range of 250 degrees per second - PT_CALL(gyro.configure(gyro.Scale::Dps250)); - - while (true) - { - // read out the sensor - PT_CALL(gyro.readRotation()); - - // update the moving average - averageZ.update(gyro.getData().getZ()); - - { - float value = averageZ.getValue(); - // normalize rotation and scale by 5 leds - uint16_t leds = abs(value / 200 * 5); - leds = (1ul << leds) - 1; - - LedRing::write(leds); - } - - // repeat every 5 ms - timeout.restart(5ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageZ; -}; - -ReaderThread reader; - +modm::filter::MovingAverage averageZ; int main() @@ -81,10 +35,27 @@ main() Board::initialize(); Board::initializeL3g(); + // initialize with limited range of 250 degrees per second + gyro.configure(gyro.Scale::Dps250); + while (true) { - reader.update(); + // read out the sensor + gyro.readRotation(); + + // update the moving average + averageZ.update(gyro.getData().getZ()); + + float value = averageZ.getValue(); + // normalize rotation and scale by 5 leds + uint16_t leds = abs(value / 200 * 5); + leds = (1ul << leds) - 1; + LedRing::write(leds); + + // repeat every 5 ms + modm::delay(5ms); } + return 0; } diff --git a/examples/stm32f072_discovery/rotation/project.xml b/examples/stm32f072_discovery/rotation/project.xml index a734c89d24..075d94032b 100644 --- a/examples/stm32f072_discovery/rotation/project.xml +++ b/examples/stm32f072_discovery/rotation/project.xml @@ -5,9 +5,6 @@ modm:math:filter - modm:platform:gpio - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/stm32f072_discovery/stusb4500/main.cpp b/examples/stm32f072_discovery/stusb4500/main.cpp index 13732ff389..d1fa019156 100644 --- a/examples/stm32f072_discovery/stusb4500/main.cpp +++ b/examples/stm32f072_discovery/stusb4500/main.cpp @@ -44,16 +44,16 @@ main() Board::LedUp::set(); - RF_CALL_BLOCKING(usb.configurePdo(1, 5000, 500)); // must be set to 5V according to USB standard - RF_CALL_BLOCKING(usb.configurePdo(2, 20000, 1500)); // 20V, 1.5A -> 30W - RF_CALL_BLOCKING(usb.configurePdo(3, 20000, 4000)); // 20V, 4A -> 80W + usb.configurePdo(1, 5000, 500); // must be set to 5V according to USB standard + usb.configurePdo(2, 20000, 1500); // 20V, 1.5A -> 30W + usb.configurePdo(3, 20000, 4000); // 20V, 4A -> 80W - RF_CALL_BLOCKING(usb.setValidPdo(3)); // we prefer PDO 3 (more current) + usb.setValidPdo(3)); // we prefer PDO 3 (more current modm::delay(200ms); // check results - modm::stusb4500::RdoRegStatusData status = RF_CALL_BLOCKING(usb.getRdoRegStatus()); + modm::stusb4500::RdoRegStatusData status = usb.getRdoRegStatus(); MODM_LOG_INFO << "Maximum current: " << status.MaxCurrent << " mA" << modm::endl; diff --git a/examples/stm32f072_discovery/tmp102/main.cpp b/examples/stm32f072_discovery/tmp102/main.cpp index 8007858c66..2fa2b1531e 100644 --- a/examples/stm32f072_discovery/tmp102/main.cpp +++ b/examples/stm32f072_discovery/tmp102/main.cpp @@ -11,9 +11,7 @@ // ---------------------------------------------------------------------------- #include - -#include -#include +#include #include #include @@ -24,83 +22,60 @@ modm::IOStream stream(device); typedef I2cMaster1 MyI2cMaster; +modm::tmp102::Data temperatureData; +modm::Tmp102 temp(temperatureData, 0x48); -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - ThreadOne() - : temp(temperatureData, 0x48) - { - } + // ping the device until it responds + while(not temp.ping()) modm::delay(100ms); - bool - update() - { - temp.update(); + temp.setUpdateRate(200); + temp.enableExtendedMode(); - PT_BEGIN(); + temp.configureAlertMode( + modm::tmp102::ThermostatMode::Comparator, + modm::tmp102::AlertPolarity::ActiveLow, + modm::tmp102::FaultQueue::Faults6); + temp.setLowerLimit(28.f); + temp.setUpperLimit(30.f); - // ping the device until it responds - while(true) + while (true) + { + bool result{}; + temp.readComparatorMode(result); + float temperature = temperatureData.getTemperature(); + uint8_t tI = (int) temperature; + uint16_t tP = (temperature - tI) * 10000; + stream << "T= " << tI << "."; + if (tP == 0) { - // we wait until the task started - if (PT_CALL(temp.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + stream << "0000 C"; } - - - PT_CALL(temp.setUpdateRate(200)); - PT_CALL(temp.enableExtendedMode()); - - PT_CALL(temp.configureAlertMode( - modm::tmp102::ThermostatMode::Comparator, - modm::tmp102::AlertPolarity::ActiveLow, - modm::tmp102::FaultQueue::Faults6)); - PT_CALL(temp.setLowerLimit(28.f)); - PT_CALL(temp.setUpperLimit(30.f)); - - while (true) + else if (tP == 625) { - { - PT_CALL(temp.readComparatorMode(result)); - float temperature = temperatureData.getTemperature(); - uint8_t tI = (int) temperature; - uint16_t tP = (temperature - tI) * 10000; - stream << "T= " << tI << "."; - if (tP == 0) - { - stream << "0000 C"; - } - else if (tP == 625) - { - stream << "0" << tP << " C"; - } - else - { - stream << tP << " C"; - } - stream << modm::endl; - if (result) stream << "Heat me up!" << modm::endl; - } - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - Board::LedDown::toggle(); + stream << "0" << tP << " C"; } - - PT_END(); + else + { + stream << tP << " C"; + } + stream << modm::endl; + if (result) stream << "Heat me up!" << modm::endl; + modm::this_fiber::sleep_for(200ms); + Board::LedDown::toggle(); } +}); -private: - bool result; - modm::ShortTimeout timeout; - modm::tmp102::Data temperatureData; - modm::Tmp102 temp; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedUp::setOutput(); + while(true) + { + Board::LedUp::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int @@ -116,11 +91,7 @@ main() stream << "\n\nRESTART\n\n"; - while (true) - { - one.update(); - Board::LedUp::toggle(); - } + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f072_discovery/tmp102/project.xml b/examples/stm32f072_discovery/tmp102/project.xml index 93f529b3e6..6a30838e6a 100644 --- a/examples/stm32f072_discovery/tmp102/project.xml +++ b/examples/stm32f072_discovery/tmp102/project.xml @@ -9,8 +9,7 @@ modm:platform:gpio modm:platform:i2c:1 modm:platform:uart:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f3_discovery/accelerometer/main.cpp b/examples/stm32f3_discovery/accelerometer/main.cpp index 21658e0dd5..c3f992f692 100644 --- a/examples/stm32f3_discovery/accelerometer/main.cpp +++ b/examples/stm32f3_discovery/accelerometer/main.cpp @@ -14,75 +14,50 @@ #include #include -using namespace Board; - // create the data object Board::lsm3::Accelerometer::Data data; // and hand it to the sensor driver Board::lsm3::Accelerometer accelerometer(data); +modm::filter::MovingAverage averageX; +modm::filter::MovingAverage averageY; -class ReaderThread : public modm::pt::Protothread +int +main() { -public: - bool - update() - { - PT_BEGIN(); - - // initialize with limited range of ±2g - PT_CALL(accelerometer.configure(accelerometer.Scale::G2)); + Board::initialize(); + Board::initializeLsm3(); - while (true) - { - // read out the sensor - PT_CALL(accelerometer.readAcceleration()); + // initialize with limited range of ±2g + accelerometer.configure(accelerometer.Scale::G2); - averageX.update(accelerometer.getData().getX()); - averageY.update(accelerometer.getData().getY()); + while (true) + { + // read out the sensor + accelerometer.readAcceleration(); - { - bool xs = averageX.getValue() < -0.2f; - bool xn = averageX.getValue() > 0.2f; + averageX.update(accelerometer.getData().getX()); + averageY.update(accelerometer.getData().getY()); - bool xe = averageY.getValue() < -0.2f; - bool xw = averageY.getValue() > 0.2f; + const bool xs = averageX.getValue() < -0.2f; + const bool xn = averageX.getValue() > 0.2f; - Board::LedNorth::set(xn and not (xe or xw)); - Board::LedNorthEast::set(xn and xe); - Board::LedNorthWest::set(xn and xw); + const bool xe = averageY.getValue() < -0.2f; + const bool xw = averageY.getValue() > 0.2f; - Board::LedEast::set(xe and not (xs or xn)); - Board::LedWest::set(xw and not (xs or xn)); + Board::LedNorth::set(xn and not (xe or xw)); + Board::LedNorthEast::set(xn and xe); + Board::LedNorthWest::set(xn and xw); - Board::LedSouthEast::set(xs and xe); - Board::LedSouthWest::set(xs and xw); - Board::LedSouth::set(xs and not (xe or xw)); - } + Board::LedEast::set(xe and not (xs or xn)); + Board::LedWest::set(xw and not (xs or xn)); - // repeat every 5 ms - timeout.restart(5ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + Board::LedSouthEast::set(xs and xe); + Board::LedSouthWest::set(xs and xw); + Board::LedSouth::set(xs and not (xe or xw)); - PT_END(); + // repeat every 5 ms + modm::delay(5ms); } - -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageX; - modm::filter::MovingAverage averageY; -}; - -ReaderThread reader; - -int -main() -{ - Board::initialize(); - Board::initializeLsm3(); - - modm::fiber::Scheduler::run(); - return 0; } diff --git a/examples/stm32f3_discovery/accelerometer/project.xml b/examples/stm32f3_discovery/accelerometer/project.xml index 4b6ec7cbf5..b13bc4a1ac 100644 --- a/examples/stm32f3_discovery/accelerometer/project.xml +++ b/examples/stm32f3_discovery/accelerometer/project.xml @@ -2,12 +2,9 @@ modm:disco-f303vc - modm:math:filter - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/stm32f3_discovery/rotation/main.cpp b/examples/stm32f3_discovery/rotation/main.cpp index d1aad754f0..ad97c0de77 100644 --- a/examples/stm32f3_discovery/rotation/main.cpp +++ b/examples/stm32f3_discovery/rotation/main.cpp @@ -37,14 +37,13 @@ using LedRingRight = SoftwareGpioPort< Board::l3g::Gyroscope::Data data; // and hand it to the sensor driver Board::l3g::Gyroscope gyro(data); +modm::filter::MovingAverage averageZ; - -modm_faststack modm::Fiber<> fiber_gyro([]() +modm_faststack modm::Fiber fiber_gyro([] { // initialize with limited range of 250 degrees per second gyro.configure(gyro.Scale::Dps250); - modm::filter::MovingAverage averageZ; while (true) { // read out the sensor @@ -73,7 +72,7 @@ modm_faststack modm::Fiber<> fiber_gyro([]() } }); -modm_faststack modm::Fiber<> fiber_blinky([]() +modm_faststack modm::Fiber fiber_blinky([] { while (true) { @@ -89,6 +88,5 @@ main() Board::initializeL3g(); modm::fiber::Scheduler::run(); - return 0; } diff --git a/examples/stm32f3_discovery/rotation/project.xml b/examples/stm32f3_discovery/rotation/project.xml index 706008df20..1e2533c5a7 100644 --- a/examples/stm32f3_discovery/rotation/project.xml +++ b/examples/stm32f3_discovery/rotation/project.xml @@ -2,13 +2,10 @@ modm:disco-f303vc - modm:math:filter - modm:platform:gpio - modm:processing:timer - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f401_discovery/accelerometer/main.cpp b/examples/stm32f401_discovery/accelerometer/main.cpp index 7260dc6124..7e7241ad59 100644 --- a/examples/stm32f401_discovery/accelerometer/main.cpp +++ b/examples/stm32f401_discovery/accelerometer/main.cpp @@ -12,7 +12,6 @@ // ---------------------------------------------------------------------------- #include -#include #include using namespace Board; @@ -21,67 +20,46 @@ using namespace Board; Board::lsm3::Accelerometer::Data data; // and hand it to the sensor driver Board::lsm3::Accelerometer accelerometer(data); +modm::filter::MovingAverage averageX; +modm::filter::MovingAverage averageY; - -class ReaderThread : public modm::pt::Protothread +int +main() { -public: - bool - update() - { - PT_BEGIN(); + Board::initialize(); + Board::initializeLsm3(); - // initialize with limited range of ±2g - PT_CALL(accelerometer.configure(accelerometer.Scale::G2)); + Leds::set(); + modm::delay(42ms); - while (true) - { - // read out the sensor - PT_CALL(accelerometer.readAcceleration()); + // initialize with limited range of ±2g + accelerometer.configure(accelerometer.Scale::G2); - averageX.update(accelerometer.getData().getX()); - averageY.update(accelerometer.getData().getY()); + while (true) + { + // read out the sensor + accelerometer.readAcceleration(); - { - bool xs = averageX.getValue() < -0.2f; - bool xn = averageX.getValue() > 0.2f; + averageX.update(accelerometer.getData().getX()); + averageY.update(accelerometer.getData().getY()); - bool xe = averageY.getValue() < -0.2f; - bool xw = averageY.getValue() > 0.2f; + { + bool xs = averageX.getValue() < -0.2f; + bool xn = averageX.getValue() > 0.2f; + bool xe = averageY.getValue() < -0.2f; + bool xw = averageY.getValue() > 0.2f; - LedBlue::set(xs); // South - LedGreen::set(xw); //West - LedOrange::set(xn); // North - LedRed::set(xe); // East - } - // repeat every 5 ms - timeout.restart(5ms); - PT_WAIT_UNTIL(timeout.isExpired()); + LedBlue::set(xs); // South + LedGreen::set(xw); //West + LedOrange::set(xn); // North + LedRed::set(xe); // East } - PT_END(); + // repeat every 5 ms + modm::delay(5ms); } -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageX; - modm::filter::MovingAverage averageY; -}; - -ReaderThread reader; - -int -main() -{ - Board::initialize(); - Board::initializeLsm3(); - - Leds::set(); - modm::delay(42ms); - - modm::fiber::Scheduler::run(); - return 0; } diff --git a/examples/stm32f401_discovery/accelerometer/project.xml b/examples/stm32f401_discovery/accelerometer/project.xml index bd149df959..406710b036 100644 --- a/examples/stm32f401_discovery/accelerometer/project.xml +++ b/examples/stm32f401_discovery/accelerometer/project.xml @@ -2,16 +2,9 @@ modm:disco-f401vc - - modm:driver:lsm303a modm:math:filter - modm:platform:gpio - modm:platform:i2c - modm:platform:i2c.bitbang - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/stm32f401_discovery/gyroscope/main.cpp b/examples/stm32f401_discovery/gyroscope/main.cpp index 233aaa42df..c4e9481b2b 100644 --- a/examples/stm32f401_discovery/gyroscope/main.cpp +++ b/examples/stm32f401_discovery/gyroscope/main.cpp @@ -14,8 +14,6 @@ // ---------------------------------------------------------------------------- #include -#include -#include #include // maps arbitrary gpios to a bit @@ -30,51 +28,7 @@ using LedRing = SoftwareGpioPort< Board::l3g::Gyroscope::Data data; // and hand it to the sensor driver Board::l3g::Gyroscope gyro(data); - - -class ReaderThread : public modm::pt::Protothread -{ -public: - bool - update() - { - PT_BEGIN(); - - // initialize with limited range of 250 degrees per second - PT_CALL(gyro.configure(gyro.Scale::Dps250)); - - while (true) - { - // read out the sensor - PT_CALL(gyro.readRotation()); - - // update the moving average - averageZ.update(gyro.getData().getZ()); - - { - float value = averageZ.getValue(); - // normalize rotation and scale by 5 leds - uint16_t leds = abs(value / 200 * 5); - leds = (1ul << leds) - 1; - - LedRing::write(leds); - } - - // repeat every 5 ms - timeout.restart(5ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageZ; -}; - -ReaderThread reader; - +modm::filter::MovingAverage averageZ; int main() @@ -82,9 +36,28 @@ main() Board::initialize(); Board::initializeL3g(); + // initialize with limited range of 250 degrees per second + gyro.configure(gyro.Scale::Dps250); + while (true) { - reader.update(); + // read out the sensor + gyro.readRotation(); + + // update the moving average + averageZ.update(gyro.getData().getZ()); + + { + float value = averageZ.getValue(); + // normalize rotation and scale by 5 leds + uint16_t leds = abs(value / 200 * 5); + leds = (1ul << leds) - 1; + + LedRing::write(leds); + } + + // repeat every 5 ms + modm::delay(5ms); } return 0; diff --git a/examples/stm32f401_discovery/gyroscope/project.xml b/examples/stm32f401_discovery/gyroscope/project.xml index f175575740..6e59ed8f0f 100644 --- a/examples/stm32f401_discovery/gyroscope/project.xml +++ b/examples/stm32f401_discovery/gyroscope/project.xml @@ -4,11 +4,7 @@ - modm:driver:l3gd20 modm:math:filter - modm:platform:spi:1 - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/stm32f407vet6_devebox/flash/main.cpp b/examples/stm32f407vet6_devebox/flash/main.cpp index 2ea3a1aeb2..22d67e0939 100644 --- a/examples/stm32f407vet6_devebox/flash/main.cpp +++ b/examples/stm32f407vet6_devebox/flash/main.cpp @@ -52,13 +52,13 @@ void doMemoryTest() for (uint16_t iteration = 0; iteration < 4; iteration++) { uint8_t* pattern = (iteration % 2 == 0) ? bufferA : bufferB; - if (not RF_CALL_BLOCKING(storageDevice.erase(0, TestMemorySize))) { + if (not storageDevice.erase(0, TestMemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; return; } for (uint32_t ii = 0; ii < TestMemorySize; ii += Board::w25q16::BlockSize) { - if (not RF_CALL_BLOCKING(storageDevice.program(pattern, ii, Board::w25q16::BlockSize))) { + if (not storageDevice.program(pattern, ii, Board::w25q16::BlockSize)) { MODM_LOG_INFO << "Error: Unable to write data."; return; } @@ -66,7 +66,7 @@ void doMemoryTest() } for (uint32_t ii = 0; ii < TestMemorySize; ii += Board::w25q16::BlockSize) { - if (not RF_CALL_BLOCKING(storageDevice.read(bufferC, ii, Board::w25q16::BlockSize))) { + if (not storageDevice.read(bufferC, ii, Board::w25q16::BlockSize)) { MODM_LOG_INFO << "Error: Unable to read data."; return; } @@ -108,18 +108,18 @@ main() MODM_LOG_INFO << "Erasing complete flash chip... (This may take a while)" << modm::endl; - if (not RF_CALL_BLOCKING(storageDevice.initialize())) { + if (not storageDevice.initialize()) { MODM_LOG_INFO << "Error: Unable to initialize device."; } - else if (not RF_CALL_BLOCKING(storageDevice.erase(0, Board::w25q16::MemorySize))) { + else if (not storageDevice.erase(0, Board::w25q16::MemorySize)) { MODM_LOG_INFO << "Error: Unable to erase device."; } else { - auto id = RF_CALL_BLOCKING(storageDevice.readId()); + auto id = storageDevice.readId(); MODM_LOG_INFO << "deviceId=" << id.deviceId << " manufacturerId=" << id.manufacturerId; MODM_LOG_INFO << " deviceType=" << id.deviceType << modm::endl; - MODM_LOG_INFO << "status=" << static_cast(RF_CALL_BLOCKING(storageDevice.readStatus())) << modm::endl; + MODM_LOG_INFO << "status=" << static_cast(storageDevice.readStatus()) << modm::endl; MODM_LOG_INFO << "Press USER button to start the memory test." << modm::endl; initializeSuccess = true; diff --git a/examples/stm32f469_discovery/game_of_life/main.cpp b/examples/stm32f469_discovery/game_of_life/main.cpp index 1b65cf0366..c04ac70911 100644 --- a/examples/stm32f469_discovery/game_of_life/main.cpp +++ b/examples/stm32f469_discovery/game_of_life/main.cpp @@ -39,12 +39,13 @@ void read_touch() static Touch touchSensor(touchData, TouchAddress); static bool initialized = false; if (not initialized) { + if (not touchSensor.ping()) touchSensor.setAddress(TouchAddressOld); // Configure the touchscreen to sample with 60Hz in active and monitor mode. - RF_CALL_BLOCKING(touchSensor.configure(Touch::InterruptMode::Polling, 60, 60)); + touchSensor.configure(Touch::InterruptMode::Polling, 60, 60); initialized = true; } - RF_CALL_BLOCKING(touchSensor.readTouches()); + touchSensor.readTouches(); for_i(0, ii, 2) { diff --git a/examples/stm32f469_discovery/game_of_life/project.xml b/examples/stm32f469_discovery/game_of_life/project.xml index 4d73e97fc8..9ffcd60d49 100644 --- a/examples/stm32f469_discovery/game_of_life/project.xml +++ b/examples/stm32f469_discovery/game_of_life/project.xml @@ -6,7 +6,6 @@ modm:architecture:memory modm:processing:timer - modm:processing:resumable modm:platform:random modm:build:scons diff --git a/examples/stm32f469_discovery/lvgl/main.cpp b/examples/stm32f469_discovery/lvgl/main.cpp index 9a365cecb3..f770f3a0f7 100644 --- a/examples/stm32f469_discovery/lvgl/main.cpp +++ b/examples/stm32f469_discovery/lvgl/main.cpp @@ -31,7 +31,7 @@ Touch touch{touchData, TouchAddress}; void my_touchpad_read(lv_indev_t*, lv_indev_data_t* data) { - RF_CALL_BLOCKING(touch.readTouches()); + touch.readTouches(); Touch::touch_t tp; touch.getData().getTouch(&tp, 0); // mirror and rotate correctly @@ -62,7 +62,7 @@ main() MODM_LOG_INFO << "modm LVGL example on STM32F469-Discovery board!\n\n"; - RF_CALL_BLOCKING(touch.configure(Touch::InterruptMode::Trigger, 60, 60)); + touch.configure(Touch::InterruptMode::Trigger, 60, 60); // Initialize the display: lv_display_t *disp = lv_display_create(LV_HOR_RES_MAX, LV_VER_RES_MAX); diff --git a/examples/stm32f469_discovery/max31865/main.cpp b/examples/stm32f469_discovery/max31865/main.cpp index af655aeeea..9aca485831 100644 --- a/examples/stm32f469_discovery/max31865/main.cpp +++ b/examples/stm32f469_discovery/max31865/main.cpp @@ -22,45 +22,39 @@ using Mosi = D11; using Miso = D12; using Sck = D13; -class ThermocoupleThread : public modm::pt::Protothread +using Max31865 = modm::Max31865; +Max31865::Data data; +Max31865 pt100{data}; + +modm::Fiber fiber_sensor([] { -public: - ThermocoupleThread() : data{}, pt100(data) {} + pt100.initialize(); - bool - run() + while (true) { - PT_BEGIN(); - PT_CALL(pt100.initialize()); - - while (true) - { - MODM_LOG_INFO << "\nNew readout:" << modm::endl; - PT_CALL(pt100.readout()); - - MODM_LOG_INFO << " resistance : " << data.getResistance() << " Ohm" - << modm::endl; - MODM_LOG_INFO << " temperature fast: " << data.getTemperatureFast() << " degrees" - << modm::endl; - MODM_LOG_INFO << " temperature precise: " << data.getTemperaturePrecise() << " degrees" - << modm::endl; + MODM_LOG_INFO << "\nNew readout:" << modm::endl; + pt100.readout(); - timeout.restart(std::chrono::milliseconds(1000)); - PT_WAIT_UNTIL(timeout.isExpired()); - } + MODM_LOG_INFO << " resistance : " << data.getResistance() << " Ohm" + << modm::endl; + MODM_LOG_INFO << " temperature fast: " << data.getTemperatureFast() << " degrees" + << modm::endl; + MODM_LOG_INFO << " temperature precise: " << data.getTemperaturePrecise() << " degrees" + << modm::endl; - PT_END(); + modm::this_fiber::sleep_for(1s); } +}); -private: - using Max31865 = modm::Max31865; - Max31865::Data data; - Max31865 pt100; - - modm::ShortTimeout timeout; -}; - -ThermocoupleThread pt100Thread{}; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() @@ -72,17 +66,7 @@ main() SpiMaster::initialize(); MODM_LOG_INFO << "==========MAX 31865 Test==========" << modm::endl; - MODM_LOG_DEBUG << "Debug logging here" << modm::endl; - MODM_LOG_INFO << "Info logging here" << modm::endl; - MODM_LOG_WARNING << "Warning logging here" << modm::endl; - MODM_LOG_ERROR << "Error logging here" << modm::endl; - MODM_LOG_INFO << "===============================" << modm::endl; - - while (true) - { - pt100Thread.run(); - Board::LedOrange::toggle(); - } + modm::fiber::Scheduler::run(); return 0; -} \ No newline at end of file +} diff --git a/examples/stm32f469_discovery/max31865/project.xml b/examples/stm32f469_discovery/max31865/project.xml index 8c5e189536..d99a2b0d84 100644 --- a/examples/stm32f469_discovery/max31865/project.xml +++ b/examples/stm32f469_discovery/max31865/project.xml @@ -5,10 +5,8 @@ modm:driver:max31865 - modm:platform:gpio modm:platform:spi:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons - \ No newline at end of file + diff --git a/examples/stm32f469_discovery/touchscreen/main.cpp b/examples/stm32f469_discovery/touchscreen/main.cpp index ad23a7f1a5..b74bb9e4aa 100644 --- a/examples/stm32f469_discovery/touchscreen/main.cpp +++ b/examples/stm32f469_discovery/touchscreen/main.cpp @@ -10,41 +10,39 @@ // ---------------------------------------------------------------------------- #include -#include +#include using namespace Board; using namespace modm::glcd; using namespace Board::ft6; -class LineDrawer : public modm::pt::Protothread +class LineDrawer : public modm::Fiber<> { public: LineDrawer() : - touch(touchData, TouchAddress), - display{Board::getDisplay()}, - px{-1, -1}, py{-1, -1}, - c{modm::color::html::White, modm::color::html::White} + Fiber([this]{ update(); }), + display{Board::getDisplay()} {} - bool + void update() { - PT_BEGIN(); + if (not touch.ping()) touch.setAddress(TouchAddressOld); // Configure the touchscreen to sample with 60Hz in active and monitor mode. - PT_CALL(touch.configure(Touch::InterruptMode::Trigger, 60, 60)); + touch.configure(Touch::InterruptMode::Trigger, 60, 60); while (true) { do { // Wait for either touchscreen interrupt or clear screen button - PT_WAIT_UNTIL(Int::read() or Button::read()); + modm::this_fiber::poll([&]{ return Int::read() or Button::read(); }); if (Button::read()) display.clear(); } while (not Int::read()); LedRed::set(); - PT_CALL(touch.readTouches()); + touch.readTouches(); for (int ii=0; ii < 2; ii++) { @@ -76,21 +74,17 @@ class LineDrawer : public modm::pt::Protothread } LedRed::reset(); } - - PT_END(); } private: Touch::Data touchData; - Touch touch; + Touch touch{touchData, TouchAddress}; modm::ColorGraphicDisplay& display; - int16_t px[2], py[2]; - modm::color::Rgb565 c[2]; -}; - -LineDrawer drawer; + int16_t px[2]{-1, -1}, py[2]{-1, -1}; + modm::color::Rgb565 c[2]{modm::color::html::White, modm::color::html::White}; +} drawer; -modm_faststack modm::Fiber<> fiber_blinky([]() +modm_faststack modm::Fiber fiber_blinky([] { Board::LedGreen::setOutput(); while(true) @@ -109,6 +103,5 @@ main() Board::initializeTouchscreen(); modm::fiber::Scheduler::run(); - return 0; } diff --git a/examples/stm32f469_discovery/touchscreen/project.xml b/examples/stm32f469_discovery/touchscreen/project.xml index d3432655d0..3b8f502801 100644 --- a/examples/stm32f469_discovery/touchscreen/project.xml +++ b/examples/stm32f469_discovery/touchscreen/project.xml @@ -2,10 +2,9 @@ modm:disco-f469ni - - modm:processing:protothread + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/accelerometer/main.cpp b/examples/stm32f4_discovery/accelerometer/main.cpp index 098b8fbab9..36121a5d62 100644 --- a/examples/stm32f4_discovery/accelerometer/main.cpp +++ b/examples/stm32f4_discovery/accelerometer/main.cpp @@ -49,63 +49,8 @@ modm::Lis3dsh< lis::Transport > accel(data); modm::lis302dl::Data data; modm::Lis302dl< lis::Transport > accel(data); #endif - - -class ReaderThread : public modm::pt::Protothread -{ -public: - bool - update() - { - PT_BEGIN(); - - // ping the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(accel.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - Board::LedOrange::set(); - PT_WAIT_UNTIL(timeout.isExpired()); - Board::LedOrange::reset(); - } - - // initialize with limited range of ~2.3G - PT_CALL(accel.configure(accel.Scale::G2, accel.MeasurementRate::Hz400)); - - while (true) - { - PT_CALL(accel.readAcceleration()); - -#if REVISION_C - averageX.update(-accel.getData().getY()); - averageY.update(accel.getData().getX()); -#else - averageX.update(accel.getData().getX()); - averageY.update(accel.getData().getY()); -#endif - - Board::LedOrange::set(averageX.getValue() < -0.2f); - Board::LedBlue::set(averageX.getValue() > 0.2f); - Board::LedGreen::set(averageY.getValue() < -0.2f); - Board::LedRed::set(averageY.getValue() > 0.2f); - - timeout.restart(5ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - modm::filter::MovingAverage averageX; - modm::filter::MovingAverage averageY; -}; - -ReaderThread reader; +modm::filter::MovingAverage averageX; +modm::filter::MovingAverage averageY; int main() @@ -122,9 +67,34 @@ main() Board::initializeLis3(); #endif + while(not accel.ping()) + { + Board::LedOrange::set(); + modm::delay(100ms); + Board::LedOrange::reset(); + } + + // initialize with limited range of ~2.3G + accel.configure(accel.Scale::G2, accel.MeasurementRate::Hz400); + while (true) { - reader.update(); + accel.readAcceleration(); + +#if REVISION_C + averageX.update(-accel.getData().getY()); + averageY.update(accel.getData().getX()); +#else + averageX.update(accel.getData().getX()); + averageY.update(accel.getData().getY()); +#endif + + Board::LedOrange::set(averageX.getValue() < -0.2f); + Board::LedBlue::set(averageX.getValue() > 0.2f); + Board::LedGreen::set(averageY.getValue() < -0.2f); + Board::LedRed::set(averageY.getValue() > 0.2f); + + modm::delay(5ms); } return 0; diff --git a/examples/stm32f4_discovery/accelerometer/project.xml b/examples/stm32f4_discovery/accelerometer/project.xml index 01bd492dce..c82fd07537 100644 --- a/examples/stm32f4_discovery/accelerometer/project.xml +++ b/examples/stm32f4_discovery/accelerometer/project.xml @@ -6,11 +6,7 @@ modm:driver:lis302dl modm:math:filter - modm:platform:gpio - modm:platform:i2c modm:platform:i2c.bitbang - modm:processing:timer - modm:processing:protothread modm:build:scons diff --git a/examples/stm32f4_discovery/barometer_bmp085_bmp180/main.cpp b/examples/stm32f4_discovery/barometer_bmp085_bmp180/main.cpp index 3243925b3d..f7d52e3ea5 100644 --- a/examples/stm32f4_discovery/barometer_bmp085_bmp180/main.cpp +++ b/examples/stm32f4_discovery/barometer_bmp085_bmp180/main.cpp @@ -12,9 +12,7 @@ #include #include -#include -#include -#include +#include #include using Usart2 = BufferedUart; @@ -34,92 +32,8 @@ modm::IOStream stream(device); typedef I2cMaster1 MyI2cMaster; -class ThreadOne : public modm::pt::Protothread -{ -public: - ThreadOne() : - barometer(data, 0x77) - { - } - - bool - update() - { - PT_BEGIN() - - stream << "Ping the device from ThreadOne" << modm::endl; - - // ping the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(barometer.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - stream << "Device responded" << modm::endl; - - // Configure the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(barometer.initialize())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - stream << "Device configured" << modm::endl; - - static modm::bmp085::Calibration &cal = data.getCalibration(); - - stream << "Calibration data is: "; - stream.printf(" ac1 %d\n", cal.ac1); - stream.printf(" ac2 %d\n", cal.ac2); - stream.printf(" ac3 %d\n", cal.ac3); - stream.printf(" ac4 %d\n", cal.ac4); - stream.printf(" ac5 %d\n", cal.ac5); - stream.printf(" ac6 %d\n", cal.ac6); - stream.printf(" b1 %d\n", cal.b1); - stream.printf(" b2 %d\n", cal.b2); - stream.printf(" mb %d\n", cal.mb); - stream.printf(" mc %d\n", cal.mc); - stream.printf(" md %d\n", cal.md); - - while (true) - { - static modm::ShortPeriodicTimer timer(250ms); - - PT_WAIT_UNTIL(timer.execute()); - - // Returns when new data was read from the sensor - PT_CALL(barometer.readout()); - - { - int16_t temp = data.getTemperature(); - int32_t press = data.getPressure(); - - stream.printf("Calibrated temperature in 0.1 degree Celsius is: %" PRId16 "\n", temp ); - stream.printf("Calibrated pressure in Pa is : %" PRId32 "\n\n", press ); - } - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - - modm::bmp085::Data data; - modm::Bmp085 barometer; -}; - - -ThreadOne one; +modm::bmp085::Data data; +modm::Bmp085 barometer{data, 0x77}; // ---------------------------------------------------------------------------- int @@ -135,10 +49,43 @@ main() stream << "\n\nWelcome to BMP085 demo!\n\n"; + // ping the device until it responds + while(not barometer.ping()) modm::delay(100ms); + stream << "Device responded" << modm::endl; + + // Configure the device until it responds + while(not barometer.initialize()) modm::delay(100ms); + stream << "Device configured" << modm::endl; + + modm::bmp085::Calibration &cal = data.getCalibration(); + + stream << "Calibration data is: "; + stream.printf(" ac1 %d\n", cal.ac1); + stream.printf(" ac2 %d\n", cal.ac2); + stream.printf(" ac3 %d\n", cal.ac3); + stream.printf(" ac4 %d\n", cal.ac4); + stream.printf(" ac5 %d\n", cal.ac5); + stream.printf(" ac6 %d\n", cal.ac6); + stream.printf(" b1 %d\n", cal.b1); + stream.printf(" b2 %d\n", cal.b2); + stream.printf(" mb %d\n", cal.mb); + stream.printf(" mc %d\n", cal.mc); + stream.printf(" md %d\n", cal.md); + while (true) { - one.update(); - Board::LedOrange::toggle(); + modm::delay(250ms); + + // Returns when new data was read from the sensor + barometer.readout(); + + { + int16_t temp = data.getTemperature(); + int32_t press = data.getPressure(); + + stream.printf("Calibrated temperature in 0.1 degree Celsius is: %" PRId16 "\n", temp ); + stream.printf("Calibrated pressure in Pa is : %" PRId32 "\n\n", press ); + } } return 0; diff --git a/examples/stm32f4_discovery/barometer_bmp085_bmp180/project.xml b/examples/stm32f4_discovery/barometer_bmp085_bmp180/project.xml index 77b145f867..38bdd0581f 100644 --- a/examples/stm32f4_discovery/barometer_bmp085_bmp180/project.xml +++ b/examples/stm32f4_discovery/barometer_bmp085_bmp180/project.xml @@ -6,11 +6,8 @@ modm:driver:bmp085 modm:io - modm:platform:gpio modm:platform:i2c:1 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/stm32f4_discovery/colour_tcs3414/main.cpp b/examples/stm32f4_discovery/colour_tcs3414/main.cpp index 00c804a98c..fc5146bd11 100644 --- a/examples/stm32f4_discovery/colour_tcs3414/main.cpp +++ b/examples/stm32f4_discovery/colour_tcs3414/main.cpp @@ -11,13 +11,9 @@ // ---------------------------------------------------------------------------- #include - #include #include - -#include - -#include +#include using Usart2 = BufferedUart; modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; @@ -37,85 +33,42 @@ modm::IOStream stream(device); // typedef I2cMaster1 MyI2cMaster; typedef I2cMaster2 MyI2cMaster; -// typedef BitBangI2cMaster MyI2cMaster; +modm::tcs3414::Data data; +modm::Tcs3414 sensor{data}; -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - bool - update() - { - PT_BEGIN(); + stream << "Ping the device from ThreadOne" << modm::endl; + while (not sensor.ping()) modm::this_fiber::sleep_for(100ms); + stream << "Device responded" << modm::endl; - stream << "Ping the device from ThreadOne" << modm::endl; + sensor.initialize(); + stream << "Device initialized" << modm::endl; - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(sensor.ping())) { - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - stream << "Device responded" << modm::endl; + sensor.configure(modm::tcs3414::Gain::X16, modm::tcs3414::Prescaler::D1); + sensor.setIntegrationTime(modm::tcs3414::IntegrationMode::INTERNAL, + modm::tcs3414::NominalIntegrationTime::MSEC_100); + stream << "Device configured" << modm::endl; - while (true) - { - if (PT_CALL(sensor.initialize())) { - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - stream << "Device initialized" << modm::endl; - - while (true) - { - if (PT_CALL(sensor.configure( - modm::tcs3414::Gain::X16, - modm::tcs3414::Prescaler::D1))) - { - if (PT_CALL(sensor.setIntegrationTime( - modm::tcs3414::IntegrationMode::INTERNAL, - modm::tcs3414::NominalIntegrationTime::MSEC_100))) - { - break; - } - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - stream << "Device configured" << modm::endl; - - while (true) - { - if (PT_CALL(sensor.readColor())) { - const auto rgb = data.getColor(); - stream << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; - } - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); + while (true) + { + if (sensor.readColor()) { + const auto rgb = data.getColor(); + stream << "RGB: " << rgb << "\tHSV: " << modm::color::Hsv(rgb) << modm::endl; } - - PT_END(); + modm::this_fiber::sleep_for(500ms); } +}); -private: - modm::ShortTimeout timeout; - modm::tcs3414::Data data; - modm::Tcs3414 sensor{data}; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int @@ -131,15 +84,6 @@ main() stream << "\n\nWelcome to TCS3414 demo!\n\n"; - modm::ShortPeriodicTimer tmr(500ms); - - while (true) - { - one.update(); - if (tmr.execute()) { - Board::LedOrange::toggle(); - } - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f4_discovery/colour_tcs3414/project.xml b/examples/stm32f4_discovery/colour_tcs3414/project.xml index be24211661..4ed507f392 100644 --- a/examples/stm32f4_discovery/colour_tcs3414/project.xml +++ b/examples/stm32f4_discovery/colour_tcs3414/project.xml @@ -6,12 +6,9 @@ modm:driver:tcs3414 modm:io - modm:platform:gpio - modm:platform:i2c.bitbang modm:platform:i2c:2 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/display/hd44780/main.cpp b/examples/stm32f4_discovery/display/hd44780/main.cpp index 332ba2a369..af3400016d 100644 --- a/examples/stm32f4_discovery/display/hd44780/main.cpp +++ b/examples/stm32f4_discovery/display/hd44780/main.cpp @@ -23,14 +23,12 @@ * */ -#include -#include -#include +#include +#include +#include #include #include -#include - using Usart2 = BufferedUart; modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; modm::IOStream stream(device); @@ -48,7 +46,6 @@ modm::log::Logger modm::log::error(device); using namespace Board; typedef I2cMaster2 MyI2cMaster; -// typedef BitBangI2cMaster MyI2cMaster; // define the pins used by the LCD when not using a port expander namespace lcd @@ -99,92 +96,70 @@ namespace expander // create a LCD object with an 4bit data port at a I2C Gpio port expander modm::Hd44780< expander::Data4BitGpio, expander::Rw, expander::Rs, expander::E > display(20, 4); +const uint8_t cgA[8] = {0, 0b00100, 0b01110, 0b11111, 0b11111, 0b01110, 0b00100, 0}; +const uint8_t cgB[8] = {0xaa, 0x55, 0xaa, 0x55, 0xaa, 0x55, 0xaa, 0x55}; -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - ThreadOne() - { - } + MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - bool - update() + // ping the device until it responds + while (not gpioExpander.ping()) { - PT_BEGIN(); - MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(gpioExpander.ping())) { - break; - } - MODM_LOG_DEBUG << "Device did not respond" << modm::endl; - - // otherwise, try again in 100ms - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - MODM_LOG_DEBUG << "Device responded" << modm::endl; - - // Actually, this is not needed because of hardware defaults, but this is better style. - expander::Backlight::setOutput(); - expander::Data4BitGpio::setOutput(); - - // Actually, this is not needed because of initialze of display driver. - expander::Rs::setOutput(); - expander::Rw::setOutput(); - expander::E::setOutput(); - - // Actually, this is not needed because of hardware defaults. - expander::Backlight::set(); + MODM_LOG_DEBUG << "Device did not respond" << modm::endl; + modm::this_fiber::sleep_for(1s); + } + MODM_LOG_DEBUG << "Device responded" << modm::endl; - // Initialize twice as some display are not initialised after first try. - display.initialize(); - display.initialize(); + // Actually, this is not needed because of hardware defaults, but this is better style. + expander::Backlight::setOutput(); + expander::Data4BitGpio::setOutput(); - // Fill CGRAM - display.writeCGRAM(0, cgA); - display.writeCGRAM(1, cgB); + // Actually, this is not needed because of initialze of display driver. + expander::Rs::setOutput(); + expander::Rw::setOutput(); + expander::E::setOutput(); - display.setCursor(0, 0); + // Actually, this is not needed because of hardware defaults. + expander::Backlight::set(); - // Write the standard welcome message ;-) - display << "Hello modm.io **\n"; + // Initialize twice as some display are not initialised after first try. + display.initialize(); + display.initialize(); - // Write two special characters in second row - display.setCursor(0, 1); - display.write(0); - display.write(1); + // Fill CGRAM + display.writeCGRAM(0, cgA); + display.writeCGRAM(1, cgB); - counter = 0; + display.setCursor(0, 0); - while (true) - { - display.setCursor(3, 1); - display << counter << " "; + // Write the standard welcome message ;-) + display << "Hello modm.io **\n"; - counter++; + // Write two special characters in second row + display.setCursor(0, 1); + display.write(0); + display.write(1); - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); - } + uint8_t counter{}; + while (true) + { + display.setCursor(3, 1); + display << counter++ << " "; - PT_END(); + modm::this_fiber::sleep_for(1s); } +}); -private: - modm::ShortTimeout timeout; - uint8_t counter; - - // Bitmaps for special characters - uint8_t cgA[8] = {0, 0b00100, 0b01110, 0b11111, 0b11111, 0b01110, 0b00100, 0}; - uint8_t cgB[8] = {0xaa, 0x55, 0xaa, 0x55, 0xaa, 0x55, 0xaa, 0x55}; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() @@ -199,13 +174,6 @@ main() MyI2cMaster::connect(MyI2cMaster::PullUps::Internal); MyI2cMaster::initialize(); - modm::ShortPeriodicTimer tmr(500ms); - - while(true) - { - one.update(); - if (tmr.execute()) { - Board::LedOrange::toggle(); - } - } + modm::fiber::Scheduler::run(); + return 0; } diff --git a/examples/stm32f4_discovery/display/hd44780/project.xml b/examples/stm32f4_discovery/display/hd44780/project.xml index 0f6eb522c7..cd955deb89 100644 --- a/examples/stm32f4_discovery/display/hd44780/project.xml +++ b/examples/stm32f4_discovery/display/hd44780/project.xml @@ -7,12 +7,9 @@ modm:debug modm:driver:pca8574 modm:driver:hd44780 - modm:platform:gpio - modm:platform:i2c.bitbang modm:platform:i2c:2 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/display/nokia_5110/main.cpp b/examples/stm32f4_discovery/display/nokia_5110/main.cpp index 3024268520..16696a75b5 100644 --- a/examples/stm32f4_discovery/display/nokia_5110/main.cpp +++ b/examples/stm32f4_discovery/display/nokia_5110/main.cpp @@ -19,12 +19,10 @@ * */ -#include -#include -#include -#include - #include +#include +#include +#include using Usart2 = BufferedUart; modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; @@ -53,61 +51,45 @@ namespace lcd using Backlight = GpioOutputE5; } -// Select if hardware or software SPI Master shall be used -// typedef BitBangSpiMaster< lcd::Clk, lcd::Din> mySpiMaster; -typedef SpiMaster2 mySpiMaster; +using SpiMaster = SpiMaster2; // create a LCD object -modm::Nokia5110< mySpiMaster, lcd::Ce, lcd::Dc, lcd::Reset > display; +modm::Nokia5110< SpiMaster, lcd::Ce, lcd::Dc, lcd::Reset > display; -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - ThreadOne() - { - } - - bool - update() - { - PT_BEGIN(); - - lcd::Reset::setOutput(modm::Gpio::Low); - lcd::Ce::setOutput(modm::Gpio::High); - lcd::Dc::setOutput(modm::Gpio::Low); - lcd::Backlight::setOutput(modm::Gpio::High); - - // Initialize - display.initialize(); - - display.setCursor(0, 0); - - // Write the standard welcome message ;-) - display << "Hello modm.io"; - - counter = 0; + lcd::Reset::setOutput(modm::Gpio::Low); + lcd::Ce::setOutput(modm::Gpio::High); + lcd::Dc::setOutput(modm::Gpio::Low); + lcd::Backlight::setOutput(modm::Gpio::High); - while (true) - { - display.setCursor(0, 10); - display << counter << " "; - display.update(); + // Initialize + display.initialize(); + display.setCursor(0, 0); - counter++; + // Write the standard welcome message ;-) + display << "Hello modm.io\n"; - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); - } + uint8_t counter{}; + while (true) + { + display.setCursor(0, 10); + display << counter++ << " "; + display.update(); - PT_END(); + modm::this_fiber::sleep_for(1s); } +}); -private: - modm::ShortTimeout timeout; - uint8_t counter; -}; - -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); int main() @@ -119,21 +101,10 @@ main() MODM_LOG_INFO << "\n\nWelcome to Nokia 5110 display demo!\n\n"; - // Software SPI Master - // GpioOutputB15::setOutput(); - // GpioOutputB13::setOutput(); - // Hardware SPI Master - SpiMaster2::connect(); - mySpiMaster::initialize(); - - modm::ShortPeriodicTimer tmr(500ms); + SpiMaster::connect(); + SpiMaster::initialize(); - while(true) - { - one.update(); - if (tmr.execute()) { - Board::LedOrange::toggle(); - } - } + modm::fiber::Scheduler::run(); + return 0; } diff --git a/examples/stm32f4_discovery/display/nokia_5110/project.xml b/examples/stm32f4_discovery/display/nokia_5110/project.xml index 5c3e8b4be0..651d08f4cf 100644 --- a/examples/stm32f4_discovery/display/nokia_5110/project.xml +++ b/examples/stm32f4_discovery/display/nokia_5110/project.xml @@ -6,12 +6,9 @@ modm:debug modm:driver:nokia5110 - modm:platform:gpio - modm:platform:spi.bitbang modm:platform:spi:2 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/distance_vl6180/main.cpp b/examples/stm32f4_discovery/distance_vl6180/main.cpp index c525add543..e39f4abe53 100644 --- a/examples/stm32f4_discovery/distance_vl6180/main.cpp +++ b/examples/stm32f4_discovery/distance_vl6180/main.cpp @@ -11,11 +11,9 @@ // ---------------------------------------------------------------------------- #include - #include #include -#include -#include +#include using Usart2 = BufferedUart; modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; @@ -47,98 +45,71 @@ typedef I2cMaster2 MyI2cMaster; modm::vl6180::Data data; modm::Vl6180 distance(data); -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - bool - update() - { - PT_BEGIN(); + MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; + while (not distance.ping()) modm::this_fiber::sleep_for(100ms); + MODM_LOG_DEBUG << "Device responded" << modm::endl; - MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; + distance.initialize(); + MODM_LOG_DEBUG << "Device initialized" << modm::endl; - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(distance.ping())) { - break; - } - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } + distance.setIntegrationTime(10); - MODM_LOG_DEBUG << "Device responded" << modm::endl; + while (true) + { + auto stamp = modm::Clock::now(); - while (true) + if (distance.readDistance()) { - if (PT_CALL(distance.initialize())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + const auto error = distance.getRangeError(); + if (error == distance.RangeErrorCode::NoError) + { + const uint8_t mm = distance.getData().getDistance(); + MODM_LOG_DEBUG << "mm: " << mm; + Board::LedGreen::set(mm > 160); + Board::LedBlue::set(mm > 110); + Board::LedRed::set(mm > 25); + } + else { + MODM_LOG_DEBUG << "Error: " << (uint8_t(error) >> 4); + Board::LedGreen::set(); + Board::LedBlue::set(); + Board::LedRed::set(); + } } - MODM_LOG_DEBUG << "Device initialized" << modm::endl; - timeout.restart(1ms); - - PT_CALL(distance.setIntegrationTime(10)); + MODM_LOG_DEBUG << "\tt=" << (modm::Clock::now() - stamp); + stamp = modm::Clock::now(); - while (true) + if (distance.readAmbientLight()) { - stamp = modm::Clock::now(); - - if (PT_CALL(distance.readDistance())) + modm::vl6180::ALS_ErrorCode error = distance.getALS_Error(); + if (error == distance.ALS_ErrorCode::NoError) { - modm::vl6180::RangeErrorCode error = distance.getRangeError(); - if (error == distance.RangeErrorCode::NoError) - { - uint8_t mm = distance.getData().getDistance(); - MODM_LOG_DEBUG << "mm: " << mm; - Board::LedGreen::set(mm > 160); - Board::LedBlue::set(mm > 110); - Board::LedRed::set(mm > 25); - } - else { - MODM_LOG_DEBUG << "Error: " << (uint8_t(error) >> 4); - Board::LedGreen::set(); - Board::LedBlue::set(); - Board::LedRed::set(); - } + uint32_t lux = distance.getData().getAmbientLight(); + MODM_LOG_DEBUG << "\tLux: " << lux; } - - MODM_LOG_DEBUG << "\tt=" << (modm::Clock::now() - stamp); - stamp = modm::Clock::now(); - - if (PT_CALL(distance.readAmbientLight())) - { - modm::vl6180::ALS_ErrorCode error = distance.getALS_Error(); - if (error == distance.ALS_ErrorCode::NoError) - { - uint32_t lux = distance.getData().getAmbientLight(); - MODM_LOG_DEBUG << "\tLux: " << lux; - } - else { - MODM_LOG_DEBUG << "\tError: " << (uint8_t(error) >> 4); - } + else { + MODM_LOG_DEBUG << "\tError: " << (uint8_t(error) >> 4); } - - MODM_LOG_DEBUG << " \tt=" << (modm::Clock::now() - stamp) << modm::endl; - - PT_WAIT_UNTIL(timeout.isExpired()); - timeout.restart(40ms); } - PT_END(); - } + MODM_LOG_DEBUG << " \tt=" << (modm::Clock::now() - stamp) << modm::endl; -private: - modm::Timeout timeout; - modm::Timestamp stamp; -}; + modm::this_fiber::sleep_for(40ms); + } +}); -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int @@ -154,15 +125,6 @@ main() MODM_LOG_INFO << "\n\nWelcome to VL6180X demo!\n\n"; - modm::ShortPeriodicTimer tmr(500ms); - - while (true) - { - one.update(); - if (tmr.execute()) { - Board::LedOrange::toggle(); - } - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f4_discovery/distance_vl6180/project.xml b/examples/stm32f4_discovery/distance_vl6180/project.xml index f449ec012f..a6344515a7 100644 --- a/examples/stm32f4_discovery/distance_vl6180/project.xml +++ b/examples/stm32f4_discovery/distance_vl6180/project.xml @@ -11,7 +11,7 @@ modm:platform:i2c.bitbang modm:platform:i2c:2 modm:platform:uart:2 - modm:processing + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/pressure_ams5915/main.cpp b/examples/stm32f4_discovery/pressure_ams5915/main.cpp index f341ba5e6b..5db0499b82 100644 --- a/examples/stm32f4_discovery/pressure_ams5915/main.cpp +++ b/examples/stm32f4_discovery/pressure_ams5915/main.cpp @@ -14,8 +14,7 @@ #include #include -#include -#include +#include using Usart2 = BufferedUart>; modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; @@ -42,57 +41,35 @@ modm::log::Logger modm::log::error(device); */ typedef I2cMaster2 MyI2cMaster; -// typedef modm::SoftwareI2cMaster MyI2cMaster; modm::ams5915::Data data; modm::Ams5915 pressureSensor(data); -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - bool - update() + MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; + while (not pressureSensor.ping()) modm::this_fiber::sleep_for(100ms); + MODM_LOG_DEBUG << "Device responded" << modm::endl; + + while (true) + { + pressureSensor.readPressure(); + MODM_LOG_INFO << "Pressure [0..1]: " << data.getPressure() << modm::endl; + MODM_LOG_INFO << "Temperature [degree centigrade]: " << data.getTemperature() << modm::endl; + modm::this_fiber::sleep_for(1ms); + } +}); + +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) { - PT_BEGIN(); - - MODM_LOG_DEBUG << "Ping the device from ThreadOne" << modm::endl; - - // ping the device until it responds - while (true) - { - // we wait until the task started - if (PT_CALL(pressureSensor.ping())) { - break; - } - // otherwise, try again in 10ms - timeout.restart(10ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - MODM_LOG_DEBUG << "Device responded" << modm::endl; - - while (true) - { - while (! PT_CALL(pressureSensor.readPressure())) - { - PT_YIELD(); - } - - MODM_LOG_INFO << "Pressure [0..1]: " << data.getPressure() << modm::endl; - MODM_LOG_INFO << "Temperature [degree centigrade]: " << data.getTemperature() << modm::endl; - - // read next pressure measurement in 1ms - timeout.restart(1ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); } -private: - modm::ShortTimeout timeout; -}; +}); -ThreadOne one; // ---------------------------------------------------------------------------- int @@ -108,15 +85,6 @@ main() MODM_LOG_INFO << "\n\nWelcome to AMSYS 5915 pressure sensor demo!\n\n"; - modm::ShortPeriodicTimer tmr(500ms); - - while (true) - { - one.update(); - if (tmr.execute()) { - Board::LedOrange::toggle(); - } - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f4_discovery/pressure_ams5915/project.xml b/examples/stm32f4_discovery/pressure_ams5915/project.xml index 4d8bee99e9..8e4fb7d4a2 100644 --- a/examples/stm32f4_discovery/pressure_ams5915/project.xml +++ b/examples/stm32f4_discovery/pressure_ams5915/project.xml @@ -5,14 +5,10 @@ modm:driver:ams5915 - modm:io modm:debug - modm:platform:gpio - modm:platform:i2c.bitbang modm:platform:i2c:2 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/protothreads/main.cpp b/examples/stm32f4_discovery/protothreads/main.cpp deleted file mode 100644 index 876c1362ae..0000000000 --- a/examples/stm32f4_discovery/protothreads/main.cpp +++ /dev/null @@ -1,126 +0,0 @@ -/* - * Copyright (c) 2014, Sascha Schade - * Copyright (c) 2014-2017, Niklas Hauser - * - * This file is part of the modm project. - * - * This Source Code Form is subject to the terms of the Mozilla Public - * License, v. 2.0. If a copy of the MPL was not distributed with this - * file, You can obtain one at http://mozilla.org/MPL/2.0/. - */ -// ---------------------------------------------------------------------------- - -#include - -#include -#include -#include - -#include - -using Usart2 = BufferedUart; -modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; -modm::IOStream stream(device); - -typedef I2cMaster1 MyI2cMaster; - - -class ThreadOne : public modm::pt::Protothread -{ -public: - ThreadOne() - : temp(temperatureData, 0x48) - { - } - - bool - update() - { - temp.update(); - - PT_BEGIN(); - - // ping the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(temp.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - - PT_CALL(temp.setUpdateRate(200)); - PT_CALL(temp.enableExtendedMode()); - - PT_CALL(temp.configureAlertMode( - modm::tmp102::ThermostatMode::Comparator, - modm::tmp102::AlertPolarity::ActiveLow, - modm::tmp102::FaultQueue::Faults6)); - PT_CALL(temp.setLowerLimit(28.f)); - PT_CALL(temp.setUpperLimit(30.f)); - - while (true) - { - { - PT_CALL(temp.readComparatorMode(result)); - float temperature = temperatureData.getTemperature(); - uint8_t tI = (int) temperature; - uint16_t tP = (temperature - tI) * 10000; - stream << "T= " << tI << "."; - if (tP == 0) - { - stream << "0000 C"; - } - else if (tP == 625) - { - stream << "0" << tP << " C"; - } - else - { - stream << tP << " C"; - } - stream << modm::endl; - if (result) stream << "Heat me up!" << modm::endl; - } - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - Board::LedRed::toggle(); - } - - PT_END(); - } - -private: - bool result; - modm::ShortTimeout timeout; - modm::tmp102::Data temperatureData; - modm::Tmp102 temp; -}; - -ThreadOne one; - -// ---------------------------------------------------------------------------- -int -main() -{ - Board::initialize(); - - Usart2::connect(); - Usart2::initialize(); - - MyI2cMaster::connect(MyI2cMaster::PullUps::Internal); - MyI2cMaster::initialize(); - - stream << "\n\nRESTART\n\n"; - - while (true) - { - one.update(); - Board::LedOrange::toggle(); - } - - return 0; -} diff --git a/examples/stm32f4_discovery/temperature_ltc2984/main.cpp b/examples/stm32f4_discovery/temperature_ltc2984/main.cpp index 25579682fb..6d5f7674b1 100644 --- a/examples/stm32f4_discovery/temperature_ltc2984/main.cpp +++ b/examples/stm32f4_discovery/temperature_ltc2984/main.cpp @@ -11,10 +11,8 @@ // ---------------------------------------------------------------------------- #include - #include #include -#include #include using Usart2 = BufferedUart>; @@ -67,77 +65,65 @@ using Mosi = GpioOutputB15; using Miso = GpioInputB14; using SpiMaster = SpiMaster2; -class ThreadOne : public modm::pt::Protothread +modm::Ltc2984 tempSensor; + +modm::Fiber fiber_sensor([] { -public: - ThreadOne() : - tempSensor() + while(not tempSensor.ping()) { + logger << "Device not reachable" << modm::endl; + modm::this_fiber::sleep_for(100ms); } - bool - update() - { - PT_BEGIN(); - - while(!PT_CALL(tempSensor.ping())) { - logger << "Device not reachable" << modm::endl; - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - - // Configure the device - PT_CALL(tempSensor.configureChannel(modm::ltc2984::Channel::Ch2, modm::ltc2984::Configuration::rsense( - modm::ltc2984::Configuration::Rsense::Resistance_t(2000*1024) - ))); - PT_CALL(tempSensor.configureChannel(modm::ltc2984::Channel::Ch4, modm::ltc2984::Configuration::rtd( - modm::ltc2984::Configuration::SensorType::Pt100, - modm::ltc2984::Configuration::Rtd::RsenseChannel::Ch2_Ch1, - modm::ltc2984::Configuration::Rtd::Wires::Wire4, - modm::ltc2984::Configuration::Rtd::ExcitationMode::Rotation_Sharing, - modm::ltc2984::Configuration::Rtd::ExcitationCurrent::Current_500uA, - modm::ltc2984::Configuration::Rtd::RtdCurve::European - ))); - tempSensor.enableChannel(modm::ltc2984::Configuration::MuxChannel::Ch4); - PT_CALL(tempSensor.setChannels()); - - logger << "Device configured" << modm::endl; + // Configure the device + tempSensor.configureChannel( + modm::ltc2984::Channel::Ch2, + modm::ltc2984::Configuration::rsense( + modm::ltc2984::Configuration::Rsense::Resistance_t(2000*1024))); + tempSensor.configureChannel(modm::ltc2984::Channel::Ch4, modm::ltc2984::Configuration::rtd( + modm::ltc2984::Configuration::SensorType::Pt100, + modm::ltc2984::Configuration::Rtd::RsenseChannel::Ch2_Ch1, + modm::ltc2984::Configuration::Rtd::Wires::Wire4, + modm::ltc2984::Configuration::Rtd::ExcitationMode::Rotation_Sharing, + modm::ltc2984::Configuration::Rtd::ExcitationCurrent::Current_500uA, + modm::ltc2984::Configuration::Rtd::RtdCurve::European + )); + tempSensor.enableChannel(modm::ltc2984::Configuration::MuxChannel::Ch4); + tempSensor.setChannels(); + + logger << "Device configured" << modm::endl; + while (true) + { + //tempSensor.initiateMeasurements(); + tempSensor.initiateSingleMeasurement(modm::ltc2984::Channel::Ch4); + const auto stamp = modm::Clock::now(); - while (true) + // we wait until the conversations are done + while (tempSensor.isBusy()) { - //PT_CALL(tempSensor.initiateMeasurements()); - PT_CALL(tempSensor.initiateSingleMeasurement(modm::ltc2984::Channel::Ch4)); - stamp = modm::Clock::now(); - - // we wait until the conversations are done - while (PT_CALL(tempSensor.isBusy())) - { - } - logger << "Temperature measurement finished." << modm::endl; - - PT_CALL(tempSensor.readChannel(modm::ltc2984::Channel::Ch4, temp)); - logger << "Temperature: " << temp << modm::endl; - - logger << "Time: " << (modm::Clock::now() - stamp) << modm::endl; - - timeout.restart(1s); - PT_WAIT_UNTIL(timeout.isExpired()); } + logger << "Temperature measurement finished." << modm::endl; - PT_END(); - } + modm::ltc2984::Data temp; + tempSensor.readChannel(modm::ltc2984::Channel::Ch4, temp); + logger << "Temperature: " << temp << modm::endl; -private: - modm::Ltc2984 tempSensor; - modm::Timeout timeout; - modm::ltc2984::Data temp; - modm::Timestamp stamp; -}; + logger << "Time: " << (modm::Clock::now() - stamp) << modm::endl; + modm::this_fiber::sleep_for(1s); + } +}); -ThreadOne one; +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); // ---------------------------------------------------------------------------- int @@ -155,11 +141,6 @@ main() logger << "\n\nWelcome to LTC2983/LTC2984 demo!\n\n"; - while (true) - { - one.update(); - Board::LedOrange::toggle(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f4_discovery/temperature_ltc2984/project.xml b/examples/stm32f4_discovery/temperature_ltc2984/project.xml index ac02eb6171..8f0d6c2a24 100644 --- a/examples/stm32f4_discovery/temperature_ltc2984/project.xml +++ b/examples/stm32f4_discovery/temperature_ltc2984/project.xml @@ -6,11 +6,9 @@ modm:driver:ltc2984 modm:io - modm:platform:gpio modm:platform:uart:2 modm:platform:spi:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f4_discovery/tmp102/main.cpp b/examples/stm32f4_discovery/tmp102/main.cpp new file mode 100644 index 0000000000..729f5fb580 --- /dev/null +++ b/examples/stm32f4_discovery/tmp102/main.cpp @@ -0,0 +1,86 @@ +/* + * Copyright (c) 2014, Sascha Schade + * Copyright (c) 2014-2017, Niklas Hauser + * + * This file is part of the modm project. + * + * This Source Code Form is subject to the terms of the Mozilla Public + * License, v. 2.0. If a copy of the MPL was not distributed with this + * file, You can obtain one at http://mozilla.org/MPL/2.0/. + */ +// ---------------------------------------------------------------------------- + +#include +#include +#include +#include + +using Usart2 = BufferedUart; +modm::IODeviceWrapper< Usart2, modm::IOBuffer::BlockIfFull > device; +modm::IOStream stream(device); + +typedef I2cMaster1 MyI2cMaster; +modm::tmp102::Data temperatureData; +modm::Tmp102 temp(temperatureData, 0x48); + +modm::Fiber fiber_sensor([] +{ + while(not temp.ping()) modm::this_fiber::sleep_for(100ms); + + temp.setUpdateRate(200); + temp.enableExtendedMode(); + + temp.configureAlertMode( + modm::tmp102::ThermostatMode::Comparator, + modm::tmp102::AlertPolarity::ActiveLow, + modm::tmp102::FaultQueue::Faults6); + temp.setLowerLimit(28.f); + temp.setUpperLimit(30.f); + + bool result{}; + while (true) + { + temp.readComparatorMode(result); + float temperature = temperatureData.getTemperature(); + uint8_t tI = (int) temperature; + uint16_t tP = (temperature - tI) * 10000; + + stream << "T= " << tI << "."; + if (tP == 0) stream << "0000 C"; + else if (tP == 625) stream << "0" << tP << " C"; + else stream << tP << " C"; + stream << modm::endl; + if (result) stream << "Heat me up!" << modm::endl; + + modm::this_fiber::sleep_for(200ms); + Board::LedRed::toggle(); + } +}); + +modm::Fiber fiber_blink([] +{ + Board::LedOrange::setOutput(); + while(true) + { + Board::LedOrange::toggle(); + modm::this_fiber::sleep_for(0.5s); + } +}); + +// ---------------------------------------------------------------------------- +int +main() +{ + Board::initialize(); + + Usart2::connect(); + Usart2::initialize(); + + MyI2cMaster::connect(MyI2cMaster::PullUps::Internal); + MyI2cMaster::initialize(); + + stream << "\n\nRESTART\n\n"; + + modm::fiber::Scheduler::run(); + return 0; +} diff --git a/examples/stm32f4_discovery/protothreads/project.xml b/examples/stm32f4_discovery/tmp102/project.xml similarity index 68% rename from examples/stm32f4_discovery/protothreads/project.xml rename to examples/stm32f4_discovery/tmp102/project.xml index 6a2aa88f46..17951d4c63 100644 --- a/examples/stm32f4_discovery/protothreads/project.xml +++ b/examples/stm32f4_discovery/tmp102/project.xml @@ -1,16 +1,14 @@ modm:disco-f407vg - + modm:driver:tmp102 modm:io - modm:platform:gpio modm:platform:i2c:1 modm:platform:uart:2 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons diff --git a/examples/stm32f746g_discovery/adc_ad7928/main.cpp b/examples/stm32f746g_discovery/adc_ad7928/main.cpp index 85c1a754db..7c65a1970f 100644 --- a/examples/stm32f746g_discovery/adc_ad7928/main.cpp +++ b/examples/stm32f746g_discovery/adc_ad7928/main.cpp @@ -12,7 +12,6 @@ // ---------------------------------------------------------------------------- #include -#include #include /** @@ -34,70 +33,17 @@ using Miso = GpioInputB14; using Cs = GpioOutputA8; using SpiMaster = SpiMaster2; -using namespace Board; - using modm::ad7928; +modm::Ad7928 adc; -class ThreadOne : public modm::pt::Protothread -{ -public: - static constexpr ad7928::SequenceChannels_t sequence1 = - ad7928::SequenceChannels::Ch0 | - ad7928::SequenceChannels::Ch1 | - ad7928::SequenceChannels::Ch2; - - static constexpr ad7928::SequenceChannels_t sequence2 = - ad7928::SequenceChannels::Ch0 | - ad7928::SequenceChannels::Ch4 | - ad7928::SequenceChannels::Ch5; - - bool - update() - { - PT_BEGIN(); - - MODM_LOG_INFO << "Initialize device" << modm::endl; - PT_CALL(adc.initialize()); - - MODM_LOG_INFO << "Test single conversions (Ch 0-2):" << modm::endl; - - // Initiate first conversion, result will be output during the next conversion - PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch0)); - - MODM_LOG_INFO << PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch1)) << modm::endl; - MODM_LOG_INFO << PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch2)) << modm::endl; - - // Enable auto-shutdown - adc.setAutoShutdownEnabled(true); - - MODM_LOG_INFO << PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch2)) << modm::endl; - - MODM_LOG_INFO << "Test single conversion with auto-shutdown (Ch 5):" << modm::endl; - PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch5)); - MODM_LOG_INFO << PT_CALL(adc.singleConversion(ad7928::InputChannel::Ch0)) << modm::endl; - - adc.setAutoShutdownEnabled(false); - - MODM_LOG_INFO << "Test sequence mode" << modm::endl; - MODM_LOG_INFO << "Program sequence Ch0,Ch1,Ch5, Ch0,Ch4,Ch5" << modm::endl; - PT_CALL(adc.startSequence(sequence1, sequence2)); - - // Run forever - while (true) - { - MODM_LOG_INFO << PT_CALL(adc.nextSequenceConversion()) << modm::endl; - - timeout.restart(500ms); - PT_WAIT_UNTIL(timeout.isExpired()); - } - - PT_END(); - } - -private: - modm::ShortTimeout timeout; - modm::Ad7928 adc; -} thread; +static constexpr ad7928::SequenceChannels_t sequence1 = + ad7928::SequenceChannels::Ch0 | + ad7928::SequenceChannels::Ch1 | + ad7928::SequenceChannels::Ch2; +static constexpr ad7928::SequenceChannels_t sequence2 = + ad7928::SequenceChannels::Ch0 | + ad7928::SequenceChannels::Ch4 | + ad7928::SequenceChannels::Ch5; // ---------------------------------------------------------------------------- int @@ -112,8 +58,32 @@ main() MODM_LOG_INFO << "AD7928/AD7918/AD7908 Example" << modm::endl; - while (true) { - thread.update(); + MODM_LOG_INFO << "Initialize device" << modm::endl; + adc.initialize(); + + MODM_LOG_INFO << "Test single conversions (Ch 0-2):" << modm::endl; + // Initiate first conversion, result will be output during the next conversion + adc.singleConversion(ad7928::InputChannel::Ch0); + MODM_LOG_INFO << adc.singleConversion(ad7928::InputChannel::Ch1) << modm::endl; + MODM_LOG_INFO << adc.singleConversion(ad7928::InputChannel::Ch2) << modm::endl; + // Enable auto-shutdown + adc.setAutoShutdownEnabled(true); + MODM_LOG_INFO << adc.singleConversion(ad7928::InputChannel::Ch2) << modm::endl; + + MODM_LOG_INFO << "Test single conversion with auto-shutdown (Ch 5):" << modm::endl; + adc.singleConversion(ad7928::InputChannel::Ch5); + MODM_LOG_INFO << adc.singleConversion(ad7928::InputChannel::Ch0) << modm::endl; + adc.setAutoShutdownEnabled(false); + + MODM_LOG_INFO << "Test sequence mode" << modm::endl; + MODM_LOG_INFO << "Program sequence Ch0,Ch1,Ch5, Ch0,Ch4,Ch5" << modm::endl; + adc.startSequence(sequence1, sequence2); + + // Run forever + while (true) + { + MODM_LOG_INFO << adc.nextSequenceConversion() << modm::endl; + modm::delay(500ms); } return 0; diff --git a/examples/stm32f746g_discovery/adc_ad7928/project.xml b/examples/stm32f746g_discovery/adc_ad7928/project.xml index ca4d50e087..793139009f 100644 --- a/examples/stm32f746g_discovery/adc_ad7928/project.xml +++ b/examples/stm32f746g_discovery/adc_ad7928/project.xml @@ -5,10 +5,7 @@ modm:driver:ad7928 - modm:platform:gpio modm:platform:spi:2 - modm:processing:protothread - modm:processing:timer modm:build:scons diff --git a/examples/stm32f746g_discovery/tmp102/main.cpp b/examples/stm32f746g_discovery/tmp102/main.cpp index 7921edb050..362011ca5b 100644 --- a/examples/stm32f746g_discovery/tmp102/main.cpp +++ b/examples/stm32f746g_discovery/tmp102/main.cpp @@ -17,84 +17,46 @@ #include typedef I2cMaster1 MyI2cMaster; +modm::tmp102::Data temperatureData; +modm::Tmp102 temp{temperatureData}; - -class ThreadOne : public modm::pt::Protothread +modm::Fiber fiber_sensor([] { -public: - ThreadOne() - : temp(temperatureData, 0x48) - { - } + while(not temp.ping()) modm::this_fiber::sleep_for(100ms); - bool - update() - { - temp.update(); + temp.setUpdateRate(200); + temp.enableExtendedMode(); - PT_BEGIN(); + temp.configureAlertMode( + modm::tmp102::ThermostatMode::Comparator, + modm::tmp102::AlertPolarity::ActiveLow, + modm::tmp102::FaultQueue::Faults6); + temp.setLowerLimit(28.f); + temp.setUpperLimit(30.f); - // ping the device until it responds - while(true) - { - // we wait until the task started - if (PT_CALL(temp.ping())) - break; - // otherwise, try again in 100ms - timeout.restart(100ms); - PT_WAIT_UNTIL(timeout.isExpired()); + bool result{}; + while (true) + { + temp.readComparatorMode(result); + float temperature = temperatureData.getTemperature(); + uint8_t tI = (int) temperature; + uint16_t tP = (temperature - tI) * 10000; + MODM_LOG_INFO << "T= " << tI << "."; + if (tP == 0) { + MODM_LOG_INFO << "0000 C"; } - - - PT_CALL(temp.setUpdateRate(200)); - PT_CALL(temp.enableExtendedMode()); - - PT_CALL(temp.configureAlertMode( - modm::tmp102::ThermostatMode::Comparator, - modm::tmp102::AlertPolarity::ActiveLow, - modm::tmp102::FaultQueue::Faults6)); - PT_CALL(temp.setLowerLimit(28.f)); - PT_CALL(temp.setUpperLimit(30.f)); - - while (true) - { - { - PT_CALL(temp.readComparatorMode(result)); - float temperature = temperatureData.getTemperature(); - uint8_t tI = (int) temperature; - uint16_t tP = (temperature - tI) * 10000; - MODM_LOG_INFO << "T= " << tI << "."; - if (tP == 0) - { - MODM_LOG_INFO << "0000 C"; - } - else if (tP == 625) - { - MODM_LOG_INFO << "0" << tP << " C"; - } - else - { - MODM_LOG_INFO << tP << " C"; - } - if (result) { MODM_LOG_INFO << " Heat me up!"; } - MODM_LOG_INFO << modm::endl; - } - timeout.restart(200ms); - PT_WAIT_UNTIL(timeout.isExpired()); - Board::LedD13::toggle(); + else if (tP == 625) { + MODM_LOG_INFO << "0" << tP << " C"; } - - PT_END(); + else { + MODM_LOG_INFO << tP << " C"; + } + if (result) { MODM_LOG_INFO << " Heat me up!"; } + MODM_LOG_INFO << modm::endl; + modm::this_fiber::sleep_for(200ms); + Board::LedD13::toggle(); } - -private: - bool result; - modm::ShortTimeout timeout; - modm::tmp102::Data temperatureData; - modm::Tmp102 temp; -}; - -ThreadOne one; +}); // ---------------------------------------------------------------------------- int @@ -108,10 +70,6 @@ main() MODM_LOG_INFO << "\n\nRESTART\n\n"; - while (true) - { - one.update(); - } - + modm::fiber::Scheduler::run(); return 0; } diff --git a/examples/stm32f746g_discovery/tmp102/project.xml b/examples/stm32f746g_discovery/tmp102/project.xml index 1b940c166a..a8e9f5ff32 100644 --- a/examples/stm32f746g_discovery/tmp102/project.xml +++ b/examples/stm32f746g_discovery/tmp102/project.xml @@ -7,8 +7,7 @@ modm:driver:tmp102 modm:io modm:platform:i2c:1 - modm:processing:protothread - modm:processing:timer + modm:processing:fiber modm:build:scons