2021-11-04 17:26:41 +00:00
|
|
|
#pragma once
|
|
|
|
|
|
|
|
#include <stdint.h>
|
2021-11-13 02:41:54 +00:00
|
|
|
#include <stdbool.h>
|
2021-11-04 17:26:41 +00:00
|
|
|
|
|
|
|
#ifdef __cplusplus
|
|
|
|
extern "C" {
|
|
|
|
#endif
|
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
/*
|
|
|
|
* Low-level interface to Core2 - startup, shutdown, mode switching, FUS commands.
|
|
|
|
*/
|
|
|
|
|
2022-04-27 15:53:48 +00:00
|
|
|
typedef enum {
|
|
|
|
BleGlueC2ModeUnknown = 0,
|
|
|
|
BleGlueC2ModeFUS,
|
|
|
|
BleGlueC2ModeStack,
|
|
|
|
} BleGlueC2Mode;
|
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
#define BLE_MAX_VERSION_STRING_LEN (20)
|
2022-04-27 15:53:48 +00:00
|
|
|
typedef struct {
|
|
|
|
BleGlueC2Mode mode;
|
|
|
|
/**
|
|
|
|
* Wireless Info
|
|
|
|
*/
|
|
|
|
uint8_t VersionMajor;
|
|
|
|
uint8_t VersionMinor;
|
|
|
|
uint8_t VersionSub;
|
|
|
|
uint8_t VersionBranch;
|
|
|
|
uint8_t VersionReleaseType;
|
|
|
|
uint8_t MemorySizeSram2B; /*< Multiple of 1K */
|
|
|
|
uint8_t MemorySizeSram2A; /*< Multiple of 1K */
|
|
|
|
uint8_t MemorySizeSram1; /*< Multiple of 1K */
|
|
|
|
uint8_t MemorySizeFlash; /*< Multiple of 4K */
|
|
|
|
uint8_t StackType;
|
2024-02-16 07:20:45 +00:00
|
|
|
char StackTypeString[BLE_MAX_VERSION_STRING_LEN];
|
2022-04-27 15:53:48 +00:00
|
|
|
/**
|
|
|
|
* Fus Info
|
|
|
|
*/
|
|
|
|
uint8_t FusVersionMajor;
|
|
|
|
uint8_t FusVersionMinor;
|
|
|
|
uint8_t FusVersionSub;
|
|
|
|
uint8_t FusMemorySizeSram2B; /*< Multiple of 1K */
|
|
|
|
uint8_t FusMemorySizeSram2A; /*< Multiple of 1K */
|
|
|
|
uint8_t FusMemorySizeFlash; /*< Multiple of 4K */
|
|
|
|
} BleGlueC2Info;
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
// Stage 1: core2 startup and FUS
|
|
|
|
BleGlueStatusStartup,
|
|
|
|
BleGlueStatusBroken,
|
|
|
|
BleGlueStatusC2Started,
|
|
|
|
// Stage 2: radio stack
|
|
|
|
BleGlueStatusRadioStackRunning,
|
|
|
|
BleGlueStatusRadioStackMissing
|
|
|
|
} BleGlueStatus;
|
|
|
|
|
2022-01-05 16:10:18 +00:00
|
|
|
typedef void (
|
|
|
|
*BleGlueKeyStorageChangedCallback)(uint8_t* change_addr_start, uint16_t size, void* context);
|
2021-11-04 17:26:41 +00:00
|
|
|
|
2021-11-13 02:41:54 +00:00
|
|
|
/** Initialize start core2 and initialize transport */
|
2024-02-16 07:20:45 +00:00
|
|
|
void ble_glue_init(void);
|
2021-11-04 17:26:41 +00:00
|
|
|
|
2021-11-13 02:41:54 +00:00
|
|
|
/** Start Core2 Radio stack
|
|
|
|
*
|
|
|
|
* @return true on success
|
|
|
|
*/
|
2024-02-16 07:20:45 +00:00
|
|
|
bool ble_glue_start(void);
|
|
|
|
|
|
|
|
void ble_glue_stop(void);
|
2021-11-13 02:41:54 +00:00
|
|
|
|
|
|
|
/** Is core2 alive and at least FUS is running
|
|
|
|
*
|
|
|
|
* @return true if core2 is alive
|
|
|
|
*/
|
2024-02-16 07:20:45 +00:00
|
|
|
bool ble_glue_is_alive(void);
|
2021-11-13 02:41:54 +00:00
|
|
|
|
2022-04-27 15:53:48 +00:00
|
|
|
/** Waits for C2 to reports its mode to callback
|
|
|
|
*
|
|
|
|
* @return true if it reported before reaching timeout
|
|
|
|
*/
|
2024-02-16 07:20:45 +00:00
|
|
|
bool ble_glue_wait_for_c2_start(int32_t timeout_ms);
|
2022-04-27 15:53:48 +00:00
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
BleGlueStatus ble_glue_get_c2_status(void);
|
2022-04-27 15:53:48 +00:00
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
const BleGlueC2Info* ble_glue_get_c2_info(void);
|
2022-01-02 22:36:42 +00:00
|
|
|
|
2021-11-13 02:41:54 +00:00
|
|
|
/** Is core2 radio stack present and ready
|
|
|
|
*
|
|
|
|
* @return true if present and ready
|
|
|
|
*/
|
2024-02-16 07:20:45 +00:00
|
|
|
bool ble_glue_is_radio_stack_ready(void);
|
2021-11-13 02:41:54 +00:00
|
|
|
|
|
|
|
/** Set callback for NVM in RAM changes
|
|
|
|
*
|
|
|
|
* @param[in] callback The callback to call on NVM change
|
|
|
|
* @param context The context for callback
|
|
|
|
*/
|
2022-01-05 16:10:18 +00:00
|
|
|
void ble_glue_set_key_storage_changed_callback(
|
|
|
|
BleGlueKeyStorageChangedCallback callback,
|
|
|
|
void* context);
|
2021-11-04 17:26:41 +00:00
|
|
|
|
2022-04-27 15:53:48 +00:00
|
|
|
bool ble_glue_reinit_c2();
|
|
|
|
|
|
|
|
typedef enum {
|
|
|
|
BleGlueCommandResultUnknown,
|
|
|
|
BleGlueCommandResultOK,
|
|
|
|
BleGlueCommandResultError,
|
|
|
|
BleGlueCommandResultRestartPending,
|
|
|
|
BleGlueCommandResultOperationOngoing,
|
|
|
|
} BleGlueCommandResult;
|
|
|
|
|
2022-01-14 08:39:41 +00:00
|
|
|
/** Restart MCU to launch radio stack firmware if necessary
|
|
|
|
*
|
|
|
|
* @return true on radio stack start command
|
|
|
|
*/
|
2022-04-27 15:53:48 +00:00
|
|
|
BleGlueCommandResult ble_glue_force_c2_mode(BleGlueC2Mode mode);
|
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
BleGlueCommandResult ble_glue_fus_stack_delete(void);
|
2022-04-27 15:53:48 +00:00
|
|
|
|
|
|
|
BleGlueCommandResult ble_glue_fus_stack_install(uint32_t src_addr, uint32_t dst_addr);
|
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
BleGlueCommandResult ble_glue_fus_get_status(void);
|
|
|
|
|
|
|
|
BleGlueCommandResult ble_glue_fus_wait_operation(void);
|
2022-04-27 15:53:48 +00:00
|
|
|
|
2024-02-16 07:20:45 +00:00
|
|
|
typedef struct {
|
|
|
|
uint32_t magic;
|
|
|
|
uint32_t source_pc;
|
|
|
|
uint32_t source_lr;
|
|
|
|
uint32_t source_sp;
|
|
|
|
} BleGlueHardfaultInfo;
|
|
|
|
|
|
|
|
/** Get hardfault info
|
|
|
|
*
|
|
|
|
* @return hardfault info. NULL if no hardfault
|
|
|
|
*/
|
|
|
|
const BleGlueHardfaultInfo* ble_glue_get_hardfault_info(void);
|
2022-01-14 08:39:41 +00:00
|
|
|
|
2021-11-04 17:26:41 +00:00
|
|
|
#ifdef __cplusplus
|
|
|
|
}
|
2022-05-06 13:37:10 +00:00
|
|
|
#endif
|