This branch contains the source code for the full Ada + SPARK Crazyflie 2.0 firmware. If you want to use the SPARK + C version, switch to the crazyflie2 branch instead.
./ | Root, contains the .gpr project file
+ init | Contains the main unit
+ config | Configuration files
+ drivers | Hardware driver layer
| + body | Drivers packages implementation
| + spec | Drivers packages interface. Interface with the HAL
+ hal | Hardware abstaction layer
| + body | HAL packages implementation
| + spec | HAL packages specification. Interface with the modules
+ modules | Firmware operating code
| + body | Firmware tasks and implementation of the functional modules (e.g: stabilization)
| + spec | Firmware tasks and specification of the functional modules
+ utils | Utils code. Implementation of utility packages (e.g: filtering).
| + body | Utils packages implementation
| + spec | Utils packages specification. Used by other parts of the firmware (e.g: modules, HAL)
+ types
| + spec | Contains type definitions that are shared with several firmware parts
+ stm32_peripheral_libs | Git submodule for STM32 peripheral libraries. See: https://github.com/AdaCore/bareboard
This repository uses git submodules. Clone with the --recursive flag to clone the submodules:
git clone --recursive https://github.com/AnthonyLeonardoGracio/crazyflie-firmware.git
The firmware is written in Ada 2012 and in SPARK 2014 and targets a STM32F4 chip, based on ARM. Therefore, a compiler for ARM (ELF) is needed: The "GNAT GPL 2016" compiler for ARM (ELF) is one such compiler. A recent GNAT Pro compiler for that target will also suffice.
To be able to analyze the SPARK code, you will need the SPARK toolsuite (e.g: "SPARK GPL 2016").
The firmware uses a Ravenscar-Full runtime that targets STM32F4 boards. This runtime is included in the "GNAT GPL 2016" for ARM (ELF) package and in the recent GNAT Pro packages for ARM.
To build the actual firmware, go on the project's root directory and type:
gprbuild -P cf_ada_spark.gpr -p
The firmware can be flashed using the STM32f4 DFU mode.
First, install the dfu-util on your matchine. On Ubuntu:
apt-get install dfu-util
Then, set the Crazyflie's STM32F4 in DFU mode by holding down the reset button for about 5 seconds, until you see the blue led blinking in a fastest way.
- Plug the USB to micro-USB cable into your laptop
- Disconnect the battery from your Crazyflie 2.0
- Push in the power button on your Crazyflie 2.0. While continuing to hold in the power button (this is the tricky part), plug the micro-USB connector end of the cable into the Crazyflie.
- Continue holding the power button for about five seconds since you plugged the USB cable in). Watch the blue LED on the M2 arm until it displays a secondary (faster) blink rate (flashes about once a second). Then you can release the button.
With the STM32F4 in DFU mode, you should be able to find it with lsusb:
lsusb
...
Bus XXX Device XXX: ID 0483:df11 STMicroelectronics STM Device in DFU Mode
Create the BIN file from the ELF one with objcopy and then flash it using dfu-util:
arm-eabi-objcopy obj/cflie.elf -O binary obj/cflie.bin
sudo dfu-util -d 0483:df11 -a 0 -s 0x08000000 -D obj/cflie.bin