mirror of
https://github.com/ArduPilot/ardupilot
synced 2025-01-05 07:28:29 -04:00
AP_Periph: added application descriptor
this is used by MissionPlanner to see if correct fw is already loaded
This commit is contained in:
parent
6a413babe0
commit
30195ea6b5
@ -47,6 +47,8 @@ void loop(void)
|
|||||||
|
|
||||||
static uint32_t start_ms;
|
static uint32_t start_ms;
|
||||||
|
|
||||||
|
const struct app_descriptor app_descriptor __attribute__((section(".app_descriptor")));;
|
||||||
|
|
||||||
void AP_Periph_FW::init()
|
void AP_Periph_FW::init()
|
||||||
{
|
{
|
||||||
hal.uartA->begin(AP_SERIALMANAGER_CONSOLE_BAUD, 32, 128);
|
hal.uartA->begin(AP_SERIALMANAGER_CONSOLE_BAUD, 32, 128);
|
||||||
@ -65,6 +67,17 @@ void AP_Periph_FW::init()
|
|||||||
AFIO->MAPR = mapr | AFIO_MAPR_CAN_REMAP_REMAP2 | AFIO_MAPR_SPI3_REMAP;
|
AFIO->MAPR = mapr | AFIO_MAPR_CAN_REMAP_REMAP2 | AFIO_MAPR_SPI3_REMAP;
|
||||||
#endif
|
#endif
|
||||||
|
|
||||||
|
printf("Booting %08x:%08x %u/%u len=%u 0x%08x\n",
|
||||||
|
app_descriptor.image_crc1,
|
||||||
|
app_descriptor.image_crc2,
|
||||||
|
app_descriptor.version_major, app_descriptor.version_minor,
|
||||||
|
app_descriptor.image_size,
|
||||||
|
app_descriptor.git_hash);
|
||||||
|
|
||||||
|
if (hal.util->was_watchdog_reset()) {
|
||||||
|
printf("Reboot after watchdog reset\n");
|
||||||
|
}
|
||||||
|
|
||||||
#ifdef HAL_PERIPH_ENABLE_GPS
|
#ifdef HAL_PERIPH_ENABLE_GPS
|
||||||
gps.init(serial_manager);
|
gps.init(serial_manager);
|
||||||
#endif
|
#endif
|
||||||
|
@ -13,6 +13,27 @@
|
|||||||
#include "Parameters.h"
|
#include "Parameters.h"
|
||||||
#include "ch.h"
|
#include "ch.h"
|
||||||
|
|
||||||
|
#ifndef CAN_APP_VERSION_MAJOR
|
||||||
|
#define CAN_APP_VERSION_MAJOR 1
|
||||||
|
#endif
|
||||||
|
#ifndef CAN_APP_VERSION_MINOR
|
||||||
|
#define CAN_APP_VERSION_MINOR 0
|
||||||
|
#endif
|
||||||
|
|
||||||
|
/*
|
||||||
|
app descriptor compatible with MissionPlanner
|
||||||
|
*/
|
||||||
|
struct app_descriptor {
|
||||||
|
uint8_t sig[8] = { 0x40, 0xa2, 0xe4, 0xf1, 0x64, 0x68, 0x91, 0x06 };
|
||||||
|
uint32_t image_crc1 = 0;
|
||||||
|
uint32_t image_crc2 = 0;
|
||||||
|
uint32_t image_size = 0;
|
||||||
|
uint32_t git_hash = 0;
|
||||||
|
uint8_t version_major = CAN_APP_VERSION_MAJOR;
|
||||||
|
uint8_t version_minor = CAN_APP_VERSION_MINOR;
|
||||||
|
uint8_t reserved[6] = { 0xff, 0xff, 0xff, 0xff, 0xff, 0xff };
|
||||||
|
};
|
||||||
|
extern const struct app_descriptor app_descriptor;
|
||||||
|
|
||||||
class AP_Periph_FW {
|
class AP_Periph_FW {
|
||||||
public:
|
public:
|
||||||
|
@ -60,12 +60,6 @@ static uint32_t canard_memory_pool[2048/4];
|
|||||||
static uint8_t PreferredNodeID = HAL_CAN_DEFAULT_NODE_ID;
|
static uint8_t PreferredNodeID = HAL_CAN_DEFAULT_NODE_ID;
|
||||||
static uint8_t transfer_id;
|
static uint8_t transfer_id;
|
||||||
|
|
||||||
#ifndef CAN_APP_VERSION_MAJOR
|
|
||||||
#define CAN_APP_VERSION_MAJOR 1
|
|
||||||
#endif
|
|
||||||
#ifndef CAN_APP_VERSION_MINOR
|
|
||||||
#define CAN_APP_VERSION_MINOR 0
|
|
||||||
#endif
|
|
||||||
#ifndef CAN_APP_NODE_NAME
|
#ifndef CAN_APP_NODE_NAME
|
||||||
#define CAN_APP_NODE_NAME "org.ardupilot.ap_periph"
|
#define CAN_APP_NODE_NAME "org.ardupilot.ap_periph"
|
||||||
#endif
|
#endif
|
||||||
@ -117,6 +111,11 @@ static void handle_get_node_info(CanardInstance* ins,
|
|||||||
pkt.status = node_status;
|
pkt.status = node_status;
|
||||||
pkt.software_version.major = CAN_APP_VERSION_MAJOR;
|
pkt.software_version.major = CAN_APP_VERSION_MAJOR;
|
||||||
pkt.software_version.minor = CAN_APP_VERSION_MINOR;
|
pkt.software_version.minor = CAN_APP_VERSION_MINOR;
|
||||||
|
pkt.software_version.optional_field_flags = UAVCAN_PROTOCOL_SOFTWAREVERSION_OPTIONAL_FIELD_FLAG_VCS_COMMIT | UAVCAN_PROTOCOL_SOFTWAREVERSION_OPTIONAL_FIELD_FLAG_IMAGE_CRC;
|
||||||
|
pkt.software_version.vcs_commit = app_descriptor.git_hash;
|
||||||
|
uint32_t *crc = (uint32_t *)&pkt.software_version.image_crc;
|
||||||
|
crc[0] = app_descriptor.image_crc1;
|
||||||
|
crc[1] = app_descriptor.image_crc2;
|
||||||
|
|
||||||
readUniqueID(pkt.hardware_version.unique_id);
|
readUniqueID(pkt.hardware_version.unique_id);
|
||||||
|
|
||||||
@ -555,6 +554,10 @@ static void can_safety_button_update(void)
|
|||||||
static void onTransferReceived(CanardInstance* ins,
|
static void onTransferReceived(CanardInstance* ins,
|
||||||
CanardRxTransfer* transfer)
|
CanardRxTransfer* transfer)
|
||||||
{
|
{
|
||||||
|
#ifdef HAL_GPIO_PIN_LED_CAN1
|
||||||
|
palToggleLine(HAL_GPIO_PIN_LED_CAN1);
|
||||||
|
#endif
|
||||||
|
|
||||||
/*
|
/*
|
||||||
* Dynamic node ID allocation protocol.
|
* Dynamic node ID allocation protocol.
|
||||||
* Taking this branch only if we don't have a node ID, ignoring otherwise.
|
* Taking this branch only if we don't have a node ID, ignoring otherwise.
|
||||||
|
Loading…
Reference in New Issue
Block a user