-
Notifications
You must be signed in to change notification settings - Fork 0
Commit
This commit does not belong to any branch on this repository, and may belong to a fork outside of the repository.
- Loading branch information
Showing
36 changed files
with
2,338 additions
and
80 deletions.
There are no files selected for viewing
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
|
@@ -14,3 +14,4 @@ Cargo.lock | |
**/*.rs.bk | ||
|
||
/app.map | ||
/app.bin |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,15 @@ | ||
[package] | ||
name = "bootloader" | ||
version = "0.1.0" | ||
edition = "2021" | ||
|
||
[dependencies] | ||
cortex-m = "0.7" | ||
cortex-m-rt = "0.7" | ||
embedded-hal = "1" | ||
panic-rtt-target = { version = "0.1.3" } | ||
rtt-target = { version = "0.5" } | ||
crc = "3" | ||
|
||
[dependencies.va416xx-hal] | ||
path = "../va416xx-hal" |
This file contains bidirectional Unicode text that may be interpreted or compiled differently than what appears below. To review, open the file in an editor that reveals hidden Unicode characters.
Learn more about bidirectional Unicode characters
Original file line number | Diff line number | Diff line change |
---|---|---|
@@ -0,0 +1,47 @@ | ||
VA416xx Bootloader Application | ||
======= | ||
|
||
This is the Rust version of the bootloader supplied by Vorago. | ||
|
||
## Memory Map | ||
|
||
The bootloader uses the following memory map: | ||
|
||
| Address | Notes | Size | | ||
| ------ | ---- | ---- | | ||
| 0x0 | Bootloader start | code up to 0x3FFC bytes | | ||
| 0x3FFC | Bootloader CRC | word | | ||
| 0x4000 | App image A start | code up to 0x1DFFC (~120K) bytes | | ||
| 0x21FFC | App image A CRC check length | word | | ||
| 0x21FFE | App image A CRC check value | word | | ||
| 0x22000 | App image B start | code up to 0x1DFFC (~120K) bytes | | ||
| 0x3FFFC | App image B CRC check length | word | | ||
| 0x3FFFE | App image B CRC check value | word | | ||
| 0x40000 | End of NVM | end | | ||
|
||
## Additional Information | ||
|
||
As opposed to the Vorago example code, this bootloader assumes a 40 MHz external clock | ||
but does not scale that clock up. It also uses a word (4 bytes) instead of a half-word for the CRC | ||
and uses the ISO 3309 CRC32 standard checksum. | ||
|
||
This bootloader does not provide tools to flash the NVM memories by itself. Instead, you can use | ||
the [flashloader](https://egit.irs.uni-stuttgart.de/rust/va416xx-rs/src/branch/main/flashloader) | ||
application to perform this task using a CCSDS interface via a UART. | ||
|
||
The bootloader performs the following steps: | ||
|
||
1. The application will calculate the checksum of itself if the bootloader CRC is blank (all zeroes | ||
or all ones). If the CRC is not blank and the checksum check fails, it will immediately boot | ||
application image A. Otherwise, it proceeds to the next step. | ||
2. Check the checksum of App A. If that checksum is valid, it will boot App A. If not, it will | ||
proceed to the next step. | ||
3. Check the checksum of App B. If that checksum is valid, it will boot App B. If not, it will | ||
boot App A as the fallback image. | ||
|
||
You could adapt and combine this bootloader with a non-volatile memory to select a prefered app | ||
image, which would be a first step towards an updatable flight software. | ||
|
||
Please note that you *MUST* compile the application at slot A and slot B with an appropriate | ||
`memory.x` file where the base address of the `FLASH` was adapted according to the base address | ||
shown in the memory map above. The memory files to do this were provided in the `scripts` folder. |
Oops, something went wrong.