...
the bootloader code
two identical bootloader config pages
the application code
(also: a section for the calib flash page, should be in the normal linker script too)
The two config pages are for redundancy. We will use the persist
module to manage storing the config blob in those pages. A CRC (cyclic redundancy check - a quick hash function) will be stored along with the blob to ensure its integrity; if one page has an invalid blob, we overwrite it with the other one. This way we always have a valid config page, since fixing invalid config would otherwise require manually reflashing the bootloader onto the board.
...
Code Block |
---|
ID Name Current Project Info Git Version 5 newton centre_console f8df7d2-clean 2 galileo bms_carrier 23daff3-dirty 8 maxwell power_distribution front 6a4a7bb-dirty 11 einstein steering bc869ef-clean 7 curie power_distribution rear c6e8925-clean 16 hawking mci 798fe65-dirty 4 faraday pedal_board 5131f78-clean 9 turing charger 9e6987b-dirty |
(this might be even more useful if we added branch namesThe client can also use the git command thing to look up the branch name from the commit hash and display it automagically!)
This command can also be used to implement pattern-matching for all of the following commands. To implement pattern-matching, all that’s technically required is to get a list of IDs that match a pattern, but the extra information can be used to display a warning before potentially-dangerous commands like flash
, or just a list of the boards that a command applies to, like this:
...
This scheme has the disadvantage that the node ID is at the beginning, so bootloader datagrams from controller boards aren’t given a higher priority in general. However, the client (which is the only party broadcasting extremely long and important datagrams like flashing content) has the special node ID 0, so the client’s non-starting datagram messages have the highest priority on the bus (all zeros) while the client’s starting messages have close to it - in our setup, bested only by the BPS heartbeat.Under this scheme, code flashed via the
We will have to work around an x86 thing: see line 262 in x86/can_hw.c.
Under this scheme, code flashed via the bootloader can coexist with code flashed the traditional way, but the scheme does require that we reflash all boards so that every node on the network is aware of and at least ignores bootloader messages.
...
One other topic: we should have a way to jump from the application code back to the bootloader via a CAN message to run more commands. This is a peripheral feature since we can just power cycle the system. We can either do it upon receipt of any bootloader datagram start message (and pass the start message back to the bootloader), or we can do it with a normal CAN message with a handler pre-registered. In any case, we’d have to initialize CAN in smoke tests and small projects in order for them to be accessible via this method.
Way to do this without starting up into bootloader on initialization: https://www.st.com/resource/en/application_note/dm00230416-onthefly-firmware-update-for-dual-bank-stm32-microcontrollers-stmicroelectronics.pdf. Two boot banks.
Client and API
The core of the client should be implemented as a modular Python script so that it can be deployed not just on x86 but also on e.g. a raspberry pi in the car to enable over-the-air firmware updates. The make
interface to the bootloader client can be implemented as just shelling out to the Python script.
...