This is just some STM32F4DISCOVERY demo application written in Rust.
Find a file
2019-12-20 13:34:23 +01:00
.cargo Remove unused example stuff from the Cargo config 2019-04-02 16:09:35 +02:00
examples Remove the deny(warnings) attributes 2019-06-29 12:08:16 +02:00
src Reorder the task attributes for clearity 2019-12-20 13:34:23 +01:00
.gitignore Initial import into Git 2019-03-05 15:04:26 +01:00
.gitlab-ci.yml Improve the README a bit more 2019-04-11 20:21:59 +02:00
Cargo.toml Port example to stm32f4xx-hal version 0.6 2019-12-20 13:16:19 +01:00
LICENSE.md Add license and readme files 2019-03-19 08:52:48 +01:00
memory.x Initial import into Git 2019-03-05 15:04:26 +01:00
openocd.cfg Initial import into Git 2019-03-05 15:04:26 +01:00
openocd.gdb Initial import into Git 2019-03-05 15:04:26 +01:00
README.md Remove trailing whitespace 2019-06-24 22:32:19 +02:00

stm32f4disc-demo

This is just some STM32F4DISCOVERY demo application using Rust. It has a simple serial command-interface for controlling (via GPIO) what the LED ring does: cycle clock-wise, counter clock-wise, or follow the accelerometer. The accelerometer is accessed via SPI.

The project also shows how to do unit testing and how to use GitLab CI.

Serial interface

The serial interface is configured on USART 2 and can be accessed using, for example, an USB-to-serial cable connected to a ground pin, and RX to PA2 and TX to PA3.

The interface will output the following lines:

  • init after initialization has finished
  • button when the user button has been pressed
  • level when the board is being held in a perfect level position (when in acceleration mode)

The following lines can be given as commands:

  • on to turn all the leds on (and disable accelerometer/cycle mode)
  • off to turn all the leds off (and disable accelerometer/cycle mode)
  • accel to switch to accelerometer mode
  • cycle to switch to cycle mode
  • stop to freeze the LEDs in the current position

License

0-clause BSD license.