The SSBL is an open-source second stage bootloader which provides advanced boot functionality for the SP Racing H7 series flight controllers. For example, to boot Flight Control software which is larger than the 448K default, such as PX4.
- Why?
The SPRacing H7 series flight controllers (H7EXTREME, H7ZERO, H7NANO) use the H750 CPU which has excellent performance but very limited internal flash space. The H7 FC's use the internal flash for a bootloader which copies a program from external flash or SD card into memory, and then the program runs from memory instead of internal flash. The program is limited to a maximum size, 448K, which is fine for Cleanflight/Betaflight as it fits in that space. However, for larger auto-pilot systems and/or ones which have advanced navigation capabilites, such as PX4 and Ardupilot, 448K is not enough.
- How?
The SSBL takes the place of the regular program and allows the flight controller to use supported external flash chips as memory from which code can be run, instead of copying the code to RAM before running it. This allows for a) much larger programs on the external flash, and b) allows the program to use the 448k of RAM which would otherwise contain the program itself.
IMPORTANT: See Supported and Unsupported flash chips.
- SPRacingH7EXTREME PX4 Edition - https://shop.seriouslypro.com/sp-racing-h7-extreme (make sure to select PX4 Edition when purchasing).
The SSBL currently supports the following flash chips:
- W25Q128 (W25Q128JVEIQ/W25Q128JVEJQ/W25Q128JVEIM/W25Q128JVEJM)
Support for other flash chips is possible, but requires SP Racing bootloader and SSBL support, as the SP Racing bootloader must be able to boot the SSBL.
- W25N01GV (Does not support QSPI Memory Mapped Mode)
- Everything else not listed as supported.
Important: The SPRacing H7 series FCs using the W25N01 flash chip are NOT supported. You NEED the PX4 edition and the PX4 edition bootloader. If you want to have the flash chip replaced on a non-PX4 board contact SP Racing via the contact-us page on the shop site. 7.50EUR fitting + return postage.
Technically you could replace your W25N01 with a W25Q128 and install the SSBL to SD card and boot from SD card, if you feel inclined.
The SSBL is run the same way any other firmware is run by the bootloader. Usually the SP Racing Bootloader will run firmware from External Flash, but can also run firmware from SD card without installing it to external flash.
- Follow the installation in the Installation section below.
- Power on the FC.
Note: if you're using an SD card make sure it doesn't have a file called CFEXSTFW.BIN
on it.
If your FC has a MicroSD card socket then .bin
file can be renamed to CFEXSTFW.BIN
and place on the MicroSD card, the SP Racing bootloader will always try booting from SD card first before External Flash.
This allows you to leave your existing firmware on the External Flash.
IMPORTANT: DO NOT USE THE BOOT BUTTON ON YOUR FC IF IT HAS ONE AND IT HAS THE SPRACING BOOTLOADER INSTALLED.
Similarly do not use other tools or commands to enter the ST Micros Bootloader, doing and issuing incorrect commands to it can result in the FC being unable to boot until a bootloader is restored. Always use the SP Racing Bootloader to update the external flash, NEVER attempt the use the ST Micros Bootloader.
Since the SSBL is simply just an EXST firmware file it can be flashed using any tool that can flash existing EXST firmware. E.g. Cleanflight/Betaflight configurator.
- Place FC in SB Racing Bootloader mode - power off, hold BIND (not BOOT), power on - LED flashes fast, release BIND, LED flashes slow - DFU mode enabled. OR use CF/BF
bl flash
CLI command. - Ensure DFU appears where the COM PORT selection is usually displayed. You may need to install DFU drivers, see CF/BF docs/wiki.
- Click "Firmware Flasher"
- Click "Load Firmware [Local]"
- Open the .hex file for the SSBL, e.g. "SSBL_SPRACINGH7EXTREME_RELEASE.hex"
- Click "Flash Firmware".
- Place FC in SB Racing Bootloader mode - power off, hold BIND (not BOOT), power on - LED flashes fast, release BIND, LED flashes slow - DFU mode enabled. OR use CF/BF
bl flash
CLI command. - Ensure device manager shows the FC as below:
- Flash the SSBL binary to the last 448K of the External Flash chip using
dfu-util
(assumes 16MB flash chip).
dfu-util -D build/SSBL_SPRACINGH7EXTREME_RELEASE.bin -s 0x90F90000:0x70000
- Power off and on.
Also, it's possible to copy the file from the SD card to the External Flash using the SP Racing Bootloader. See spracing/betaflight#1 "Firmware upgrade procedure via SD card". Use the .bin
file for the SSBL instead of the .bin
file for Betaflight/Cleanflight.
The SSBL runs very quickly, it should just enable the LED and launch the installed firmware on the External Flash.
However, if the firmware doesn't boot then SSBL has a feature to provide error reporting if things are bad. Errors are reported using an LED. The LED will flash very fast 20 times. Then it will flash slowly, count the slow flashes to get the 'blink code'.
Blink code | Meaning |
---|---|
1 | Developer error |
2 | External Flash not detected/supported |
3 | Firmware invalid |
Since each flight control firmware is responsible for it's own configuration storage and additional use of External Flash you may find that one flight controller firmware will overwrite data used by another one. This is a current limitation of each respective flight control software and the respective project's time and willingness to provide interoperability. For instance, CF/BF/PX4 all use the same section of External Flash dedicated to storing configuration. PX4 uses a portion of the external flash for firmware while CF/BF will use the external flash for black-box logging.
Also, for developers, it's technically possible to add support for partitions on the external flash and have each FC system be aware of such partitions and provide a boot choice system without using the SD card dual boot system (below). For instance GPT partioning could be used on the external flash. Some space at the beginning of the external flash has been reserved for this already.
It's already possible to dual boot the SP Racing FC's with different firmware so you can try out and use different firmware on your aircraft and you can use the SSBL with this existing dual-boot system.
It's possible to compile Cleanflight/Betaflight to use SD card for logging, configuration and firmware, so you can place CF/BF on an SD card and it won't overwrite the external flash. So - insert CF/BF SD card - fly CF/BF. Remove SD card, fly PX4.
- Install CF/BF toolchain.
- Compile CF/BF - Edit
src/main/target/SPRACINGH7EXTREME/target.h
change:
#define CONFIG_IN_EXTERNAL_FLASH
//#define CONFIG_IN_SDCARD
to
//#define CONFIG_IN_EXTERNAL_FLASH
#define CONFIG_IN_SDCARD
- Build the firmware
make TARGET=SPRACINGH7EXTREME
- Format your SD card using the SD Association SD card formatter tool - https://www.sdcard.org/downloads/formatter/)
- Copy it to your SD card (where
U:
is your SD card)
copy obj/betaflight_4.x.x_SPRACINGH7EXTREME.bin U:\CFEXSTFW.BIN
- Insert SD card into FC, boot FC running CF/BF.
- Change blackbox logging to log to SD CARD instead of External Flash.
For further details/help regarding toolchain installation and compiling firmware refer to each project's documentation sources and/or developer chat rooms.
- Install PX4 to External Flash as normal, see PX4 installation section.
- Done! To Fly CF/BF use the SD card and boot, to Fly PX4 remove the SD card and boot.
Install the SSBL first, see Installation above.
- Place FC in SP Racing Bootloader mode - power off, hold BIND (not BOOT), power on - LED flashes fast, release BIND, LED flashed slow - DFU mode enabled. OR use CF/BF
bl flash
CLI command. - Ensure an DFU device is detected and install ST DFU drivers as required.
-
Get a PX4 binary for the FC. The example below assumes you have a non-padded file called PX4.bin, if it's already padded and exactly 2097152 bytes long skip the next step. You may find some here: https://github.com/spracing/px4_firmware/releases - see also the Related PX4 issues section below.
-
Use
dd
to pad the binary, or you can create an empty file exactly 2MB long (1024 * 1024 * 2 = 2097152 bytes) and copy the PX4.bin content to the start of it using your tool of choice, save it asPX4_2MB.bin
dd if=/dev/zero ibs=1k count=2048 of=PX4_2MB.bin
dd conv=notrunc if=PX4.bin of=PX4_2MB.bin
- Flash the binary using dfu-util.
dfu-util -D PX4_2MB.bin -s 0x90100000:0x200000
Note: The 0x90100000 is the address that PX4 is built to run from, which is an address for the external flash that the SP Racing Bootloader exposes via DFU.
- Verify the flash. The
dfu-util
command below copies the contents of the flash back to the computer, thediff
command will tell you if the contents are identical or different. Do not attempt to fly ifdiff
doesn't say the files are identical - retry.
dfu-util -U PX4_2MB-VERIFY.bin -s 0x90100000:0x200000
diff -sb PX4_2MB.bin PX4_2MB-VERIFY.bin
- Power off, make sure that the SSBL is installed (either to SD card or to external flash), power on and use QGroundControl to configure the FC as normal.
Note: The above assumes the PX4 binary should be 2MB, if PX4 grows then adjust the 2048
and 0x200000
values above to suit larger firmware.
- Pre-padded firmware availability: PX4/PX4-Autopilot#16043
Install the SSBL first, see Installation above.
- Place FC in SP Racing Bootloader mode - power off, hold BIND (not BOOT), power on - LED flashes fast, release BIND, LED flashed slow - DFU mode enabled. OR use CF/BF
bl flash
CLI command. - Ensure an DFU device is detected and install ST DFU drivers as required.
-
Get an Ardupilot .bin or .hex for the FC, firmware for AP can be downloaded here: https://firmware.ardupilot.org/ For example, the 'Copter' firmware for the 4.4.4 release is here: https://firmware.ardupilot.org/Copter/stable-4.4.4/SPRacingH7/
-
If you only have a .hex file, then convert the .hex to a .bin file using any "Intel Hex to bin" converter, For example, you can open and view the .hex file using HxD for Windows via the "File > Import > Intel Hex" menu item. Before you can save the file as a .bin file you have to select the 0x00000000-07FFFFFFF block and delete it, as per this screenshot:
-
Rename the 'ardu*.bin' file to
AP.bin
. e.g.arducopter.bin
->AP.bin
orarducopter-heli.bin
->AP.bin
. -
Use
dd
to pad the binary, or you can create an empty file exactly 2MB long (1024 * 1024 * 2 = 2097152 bytes) and copy theAP.bin
content to the start of it using your tool of choice, save it asAP_2MB.bin
dd if=/dev/zero ibs=1k count=2048 of=AP_2MB.bin
dd conv=notrunc if=AP.bin of=AP_2MB.bin
- Flash the binary using dfu-util.
dfu-util -D AP_2MB.bin -s 0x90100000:0x200000
Note: The 0x90100000 is the address that AP is built to run from, which is an address for the external flash that the SP Racing Bootloader exposes via DFU.
- Verify the flash. The
dfu-util
command below copies the contents of the flash back to the computer, thediff
command will tell you if the contents are identical or different. Do not attempt to fly ifdiff
doesn't say the files are identical - retry.
dfu-util -U AP_2MB-VERIFY.bin -s 0x90100000:0x200000
diff -sb AP_2MB.bin AP_2MB-VERIFY.bin
- Power off, make sure that the SSBL is installed on external flash (SSBL on SD card may work with AP too however it's currently untested). Power on and use Mission Planner to connect and configure the FC as normal.
Note: The AP firmware will create a COM port when it boots, you can check the Windows Device Manager when powering on to see which port to use.
Mission Planner: https://ardupilot.org/planner/ Downloads: https://firmware.ardupilot.org/Tools/MissionPlanner/
- Follow the instructions for the SP Racing H7 EXTREME PX4 Edition above, but download the correct firmware for the FC from an official source.
If Mission planner won't connect to the board you can:
- Check that no other programs are trying to use the same COM port (e.g. BF configurator, QGroundControl, etc).
- Use a terminal emulator (e.g. putty) to connect to the COM port at 115200 baud to look for error messages, for example if you don't have an SD card inserted you will get the error message "If Mission planner won't connect to the board" repeatedly.
To remove the SSBL, place the FC in SP Racing Bootloader mode and flash any firmware (e.g. CF/bF) as normal.
make TARGET=SPRACINGH7EXTREME
the .bin
/.hex
files appear in build
.
- MCU reset
- MCU checks boot option registers (Flash is default)
- SP Racing boot loader in MCU Flash loads the SSBL EXST firmware from SD card (first) or external flash into RAM.
- Second Stage Boot Loader (SSBL) runs from RAM.
- SSBL checks for supported flash chip, enables QSPI memory mapped mode and launches firmware (e.g. PX4) from external flash, and all RAM used by SPRacing Bootloader and SSBL is available for use again.
Note: The SSBL currently a checks to see if the stack address is located in main ram (0x24xxxxxx) before it will boot. See source for details.
The W25Q128 flash chip is currently used, and it has minumum erasable size of 4KB (1 sector) and maximum erasable size of 64KB (block erase, as used by CF/BF).
The first 3 64KB erasable blocks are reserved for paritioning usage, e.g. using GPT. The next block is not MB aligned so it's currently unused. The SSBL runs firmware (e.g. PX4) from the 0x90100000 onwards. The last 512KB is used for firmware config (64KB) and the SSBL itself (448KB).
0x90000000-0x90000fff (4KB) Reserved for flash Layout and boot choice. e.g. via GPT.
0x90001000-0x9002ffff (188KB) Reserved (partitioning/etc). e.g. for GPT.
0x90030000-0x900fffff (828KB) (1024-188-4) Unused/Empty
0x90100000-0x902fffff (2MB) PX4 Firmware.
0x90300000-0x90f7ffff (12.5MB) Unused/Empty
0x90f80000-0x90f8ffff (64KB) - PX4 Config/Bootloader erasable 'config' partition.
0x90f90000-0x90ffffff (448KB) - BF/iNAV/Second stage bootloader/etc.
Check the issue tracker, pull-requests and wiki for known issues and workarounds:
Issue tracker: https://github.com/spracing/ssbl/issues Pull requests: https://github.com/spracing/ssbl/pulls Wiki: https://github.com/spracing/ssbl/wiki
- Igor Mišić for adding SPRacingH7EXTREME PX4 support - PX4/PX4-Autopilot#15385