AP_CheckFirmware: add separate AP_CheckFirmwareDefine for correctly setting firmware versions

This commit is contained in:
bugobliterator 2024-02-08 16:08:41 +11:00 committed by Andrew Tridgell
parent c54521511c
commit fd3c723103
3 changed files with 55 additions and 29 deletions

View File

@ -218,16 +218,7 @@ const app_descriptor_t *get_app_descriptor(void)
#if !defined(HAL_BOOTLOADER_BUILD) #if !defined(HAL_BOOTLOADER_BUILD)
extern const AP_HAL::HAL &hal; extern const AP_HAL::HAL &hal;
/*
declare constant app_descriptor in flash
*/
extern const app_descriptor_t app_descriptor; extern const app_descriptor_t app_descriptor;
#if CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS
const app_descriptor_t app_descriptor __attribute__((section(".app_descriptor")));
#else
const app_descriptor_t app_descriptor;
#endif
/* /*
this is needed to ensure we don't elide the app_descriptor this is needed to ensure we don't elide the app_descriptor

View File

@ -57,45 +57,45 @@ enum class check_fw_result_t : uint8_t {
#define AP_APP_DESCRIPTOR_SIGNATURE_UNSIGNED { 0x40, 0xa2, 0xe4, 0xf1, 0x64, 0x68, 0x91, 0x06 } #define AP_APP_DESCRIPTOR_SIGNATURE_UNSIGNED { 0x40, 0xa2, 0xe4, 0xf1, 0x64, 0x68, 0x91, 0x06 }
struct app_descriptor_unsigned { struct app_descriptor_unsigned {
uint8_t sig[8] = AP_APP_DESCRIPTOR_SIGNATURE_UNSIGNED; uint8_t sig[8];
// crc1 is the crc32 from firmware start to start of image_crc1 // crc1 is the crc32 from firmware start to start of image_crc1
uint32_t image_crc1 = 0; uint32_t image_crc1;
// crc2 is the crc32 from the start of version_major to the end of the firmware // crc2 is the crc32 from the start of version_major to the end of the firmware
uint32_t image_crc2 = 0; uint32_t image_crc2;
// total size of firmware image in bytes // total size of firmware image in bytes
uint32_t image_size = 0; uint32_t image_size;
uint32_t git_hash = 0; uint32_t git_hash;
// software version number // software version number
uint8_t version_major = APP_FW_MAJOR; uint8_t version_major;
uint8_t version_minor = APP_FW_MINOR; uint8_t version_minor;
// APJ_BOARD_ID (hardware version). This is also used in CAN NodeInfo // APJ_BOARD_ID (hardware version). This is also used in CAN NodeInfo
// with high byte in HardwareVersion.major and low byte in HardwareVersion.minor // with high byte in HardwareVersion.major and low byte in HardwareVersion.minor
uint16_t board_id = APJ_BOARD_ID; uint16_t board_id;
uint8_t reserved[8] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; uint8_t reserved[8];
}; };
struct app_descriptor_signed { struct app_descriptor_signed {
uint8_t sig[8] = AP_APP_DESCRIPTOR_SIGNATURE_SIGNED; uint8_t sig[8];
// crc1 is the crc32 from firmware start to start of image_crc1 // crc1 is the crc32 from firmware start to start of image_crc1
uint32_t image_crc1 = 0; uint32_t image_crc1;
// crc2 is the crc32 from the start of version_major to the end of the firmware // crc2 is the crc32 from the start of version_major to the end of the firmware
uint32_t image_crc2 = 0; uint32_t image_crc2;
// total size of firmware image in bytes // total size of firmware image in bytes
uint32_t image_size = 0; uint32_t image_size;
uint32_t git_hash = 0; uint32_t git_hash;
// firmware signature // firmware signature
uint32_t signature_length = 0; uint32_t signature_length;
uint8_t signature[72] = {}; uint8_t signature[72];
// software version number // software version number
uint8_t version_major = APP_FW_MAJOR; uint8_t version_major;
uint8_t version_minor = APP_FW_MINOR; uint8_t version_minor;
// APJ_BOARD_ID (hardware version). This is also used in CAN NodeInfo // APJ_BOARD_ID (hardware version). This is also used in CAN NodeInfo
// with high byte in HardwareVersion.major and low byte in HardwareVersion.minor // with high byte in HardwareVersion.major and low byte in HardwareVersion.minor
uint16_t board_id = APJ_BOARD_ID; uint16_t board_id;
uint8_t reserved[8] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }; uint8_t reserved[8];
}; };
#if AP_SIGNED_FIRMWARE #if AP_SIGNED_FIRMWARE

View File

@ -0,0 +1,35 @@
#ifndef FORCE_VERSION_H_INCLUDE
#error AP_CheckFirmwareDefines.h should never be included directly. You probably want to include AP_CheckFirmware/AP_CheckFirmware.h
#endif
#include "AP_CheckFirmware.h"
#if AP_CHECK_FIRMWARE_ENABLED
/*
declare constant app_descriptor in flash
*/
extern const app_descriptor_t app_descriptor;
#if CONFIG_HAL_BOARD == HAL_BOARD_CHIBIOS
const app_descriptor_t app_descriptor __attribute__((section(".app_descriptor"))) = {
#else
const app_descriptor_t app_descriptor = {
#endif
#if AP_SIGNED_FIRMWARE
.sig = AP_APP_DESCRIPTOR_SIGNATURE_SIGNED,
#else
.sig = AP_APP_DESCRIPTOR_SIGNATURE_UNSIGNED,
#endif
.image_crc1 = 0,
.image_crc2 = 0,
.image_size = 0,
.git_hash = 0,
#if AP_SIGNED_FIRMWARE
.signature_length = 0,
.signature = {},
#endif
.version_major = APP_FW_MAJOR,
.version_minor = APP_FW_MINOR,
.board_id = APJ_BOARD_ID,
.reserved = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff, 0xff }
};
#endif // AP_CHECK_FIRMWARE_ENABLED