Skip to content

Latest commit

 

History

History
39 lines (31 loc) · 1.7 KB

File metadata and controls

39 lines (31 loc) · 1.7 KB

stm32-blink

This example shows a simple baremetal firmware for an STM32 board that blinks an LED repeatedly. The example does not use any vendor SDKs or external toolchains, the entire firmware is only built from code in this example directory.

How to build and run this example:

  • Connect the STM32F746G-DISCO board via the ST-LINK USB port to your Mac.
  • Make sure you have a recent nightly Swift toolchain that has Embedded Swift support.
  • Install the stlink command line tools, e.g. via brew install stlink.
  • Build and upload the program to flash memory of the microcontroller:
$ cd stm32-blink
$ TOOLCHAINS='<toolchain-identifier>' ./build.sh
$ st-flash --reset write .build/blink.bin 0x08000000
  • The green LED next to the RESET button should now be blinking in a pattern.

The resulting size of the compiled and linked binary is very small (which shouldn't be surprising given that this toy example only blinks an LED), and demonstrates how the Embedded Swift compilation mode doesn't include unnecessary code or data in the resulting program:

$ size -m .build/blink
Segment __TEXT: 656
  Section __text: 142
  total 142
Segment __VECTORS: 456
  Section __text: 456
  total 456
Segment __LINKEDIT: 188
total 1300

The binary contains only 142 bytes of code! Additionally, the vector table needed by the CPU is actually dominating the size of the final firmware. Note that the __LINKEDIT segment is discarded when forming the final .bin file, which is 1168 bytes in size:

$ cat .build/blink.bin | wc -c
    1168