mirror of
https://github.com/DarkFlippers/unleashed-firmware
synced 2025-01-26 03:25:00 +00:00
60a9d7e6cf
* ble: profile rework, initial * apps: hid: fix for pairing cleanup * app: hid: select transport based on #define * fixing PVS warnings * ble: serial service: fixed uid naming * bt service: on-demand dialog init; ble profiles: docs; battery svc: proper update * Added shci_cmd_resp_wait/shci_cmd_resp_release impl with semaphore * app: hid: separated transport code * ble: fixed service init order for serial svc; moved hardfault check to ble_glue * cli: ps: added thread prio to output, fixed heap display * ble_glue: naming changes; separate thread for event processing; * furi: added runtime stats; cli: added cpu% to `ps` * cli: fixed thread time calculation * furi: added getter for thread priority * fixing pvs warnings * hid profile: fixed naming * more naming fixes * hal: ble init small cleanup * cleanup & draft beacon api * f18: api sync * apps: moved example_custom_font from debug to examples * BLE extra beacon demo app * naming fix * UI fixes for demo app (wip) * desktop, ble svc: added statusbar icon for beacon * minor cleanup * Minor cleanup & naming fixes * api sync * Removed stale header * hal: added FURI_BLE_EXTRA_LOG for extra logging; comments & code cleanup * naming & macro fixes * quick fixes from review * Eliminated stock svc_ctl * cli: ps: removed runtime stats * minor include fixes * (void) * naming fixes * More naming fixes * fbt: always build all libs * fbt: explicitly globbing libs; dist: logging SDK path * scripts: fixed lib path precedence * hal: bt: profiles: naming changes, support for passing params to a profile; include cleanup * ble: hid: added parameter processing for profile template * api sync * BLE HID: long name trim * Removed unused check * desktop: updated beacon status icon; ble: hid: cleaner device name management * desktop: updated status icon Co-authored-by: あく <alleteam@gmail.com> Co-authored-by: nminaylov <nm29719@gmail.com>
169 lines
5.8 KiB
C
169 lines
5.8 KiB
C
#include "ble_app.h"
|
|
|
|
#include <core/check.h>
|
|
#include <ble/ble.h>
|
|
#include <interface/patterns/ble_thread/tl/hci_tl.h>
|
|
#include <interface/patterns/ble_thread/shci/shci.h>
|
|
#include "gap.h"
|
|
#include "furi_ble/event_dispatcher.h"
|
|
|
|
#include <furi_hal.h>
|
|
#include <furi.h>
|
|
|
|
#define TAG "Bt"
|
|
|
|
PLACE_IN_SECTION("MB_MEM1") ALIGN(4) static TL_CmdPacket_t ble_app_cmd_buffer;
|
|
PLACE_IN_SECTION("MB_MEM2") ALIGN(4) static uint32_t ble_app_nvm[BLE_NVM_SRAM_SIZE];
|
|
|
|
_Static_assert(
|
|
sizeof(SHCI_C2_Ble_Init_Cmd_Packet_t) == 58,
|
|
"Ble stack config structure size mismatch (check new config options - last updated for v.1.17.3)");
|
|
|
|
typedef struct {
|
|
FuriMutex* hci_mtx;
|
|
FuriSemaphore* hci_sem;
|
|
} BleApp;
|
|
|
|
static BleApp* ble_app = NULL;
|
|
|
|
static void ble_app_hci_event_handler(void* pPayload);
|
|
static void ble_app_hci_status_not_handler(HCI_TL_CmdStatus_t status);
|
|
|
|
static const HCI_TL_HciInitConf_t hci_tl_config = {
|
|
.p_cmdbuffer = (uint8_t*)&ble_app_cmd_buffer,
|
|
.StatusNotCallBack = ble_app_hci_status_not_handler,
|
|
};
|
|
|
|
static const SHCI_C2_CONFIG_Cmd_Param_t config_param = {
|
|
.PayloadCmdSize = SHCI_C2_CONFIG_PAYLOAD_CMD_SIZE,
|
|
.Config1 = SHCI_C2_CONFIG_CONFIG1_BIT0_BLE_NVM_DATA_TO_SRAM,
|
|
.BleNvmRamAddress = (uint32_t)ble_app_nvm,
|
|
.EvtMask1 = SHCI_C2_CONFIG_EVTMASK1_BIT1_BLE_NVM_RAM_UPDATE_ENABLE,
|
|
};
|
|
|
|
static const SHCI_C2_Ble_Init_Cmd_Packet_t ble_init_cmd_packet = {
|
|
.Header = {{0, 0, 0}}, // Header unused
|
|
.Param = {
|
|
.pBleBufferAddress = 0, // pBleBufferAddress not used
|
|
.BleBufferSize = 0, // BleBufferSize not used
|
|
.NumAttrRecord = CFG_BLE_NUM_GATT_ATTRIBUTES,
|
|
.NumAttrServ = CFG_BLE_NUM_GATT_SERVICES,
|
|
.AttrValueArrSize = CFG_BLE_ATT_VALUE_ARRAY_SIZE,
|
|
.NumOfLinks = CFG_BLE_NUM_LINK,
|
|
.ExtendedPacketLengthEnable = CFG_BLE_DATA_LENGTH_EXTENSION,
|
|
.PrWriteListSize = CFG_BLE_PREPARE_WRITE_LIST_SIZE,
|
|
.MblockCount = CFG_BLE_MBLOCK_COUNT,
|
|
.AttMtu = CFG_BLE_MAX_ATT_MTU,
|
|
.SlaveSca = CFG_BLE_SLAVE_SCA,
|
|
.MasterSca = CFG_BLE_MASTER_SCA,
|
|
.LsSource = CFG_BLE_LSE_SOURCE,
|
|
.MaxConnEventLength = CFG_BLE_MAX_CONN_EVENT_LENGTH,
|
|
.HsStartupTime = CFG_BLE_HSE_STARTUP_TIME,
|
|
.ViterbiEnable = CFG_BLE_VITERBI_MODE,
|
|
.Options = CFG_BLE_OPTIONS,
|
|
.HwVersion = 0,
|
|
.max_coc_initiator_nbr = 32,
|
|
.min_tx_power = 0,
|
|
.max_tx_power = 0,
|
|
.rx_model_config = 1,
|
|
/* New stack (13.3->15.0) */
|
|
.max_adv_set_nbr = 1, // Only used if SHCI_C2_BLE_INIT_OPTIONS_EXT_ADV is set
|
|
.max_adv_data_len = 1650, // Only used if SHCI_C2_BLE_INIT_OPTIONS_EXT_ADV is set
|
|
.tx_path_compens = 0, // RF TX Path Compensation, * 0.1 dB
|
|
.rx_path_compens = 0, // RF RX Path Compensation, * 0.1 dB
|
|
.ble_core_version = SHCI_C2_BLE_INIT_BLE_CORE_5_4,
|
|
/*15.0->17.0*/
|
|
.Options_extension = SHCI_C2_BLE_INIT_OPTIONS_ENHANCED_ATT_NOTSUPPORTED |
|
|
SHCI_C2_BLE_INIT_OPTIONS_APPEARANCE_READONLY,
|
|
}};
|
|
|
|
bool ble_app_init(void) {
|
|
SHCI_CmdStatus_t status;
|
|
ble_app = malloc(sizeof(BleApp));
|
|
// Allocate semafore and mutex for ble command buffer access
|
|
ble_app->hci_mtx = furi_mutex_alloc(FuriMutexTypeNormal);
|
|
ble_app->hci_sem = furi_semaphore_alloc(1, 0);
|
|
|
|
// Initialize Ble Transport Layer
|
|
hci_init(ble_app_hci_event_handler, (void*)&hci_tl_config);
|
|
|
|
do {
|
|
// Configure NVM store for pairing data
|
|
if((status = SHCI_C2_Config((SHCI_C2_CONFIG_Cmd_Param_t*)&config_param))) {
|
|
FURI_LOG_E(TAG, "Failed to configure 2nd core: %d", status);
|
|
break;
|
|
}
|
|
|
|
// Start ble stack on 2nd core
|
|
if((status = SHCI_C2_BLE_Init((SHCI_C2_Ble_Init_Cmd_Packet_t*)&ble_init_cmd_packet))) {
|
|
FURI_LOG_E(TAG, "Failed to start ble stack: %d", status);
|
|
break;
|
|
}
|
|
|
|
if((status = SHCI_C2_SetFlashActivityControl(FLASH_ACTIVITY_CONTROL_SEM7))) {
|
|
FURI_LOG_E(TAG, "Failed to set flash activity control: %d", status);
|
|
break;
|
|
}
|
|
} while(false);
|
|
|
|
return status == SHCI_Success;
|
|
}
|
|
|
|
void ble_app_get_key_storage_buff(uint8_t** addr, uint16_t* size) {
|
|
*addr = (uint8_t*)ble_app_nvm;
|
|
*size = sizeof(ble_app_nvm);
|
|
}
|
|
|
|
void ble_app_deinit(void) {
|
|
furi_check(ble_app);
|
|
|
|
furi_mutex_free(ble_app->hci_mtx);
|
|
furi_semaphore_free(ble_app->hci_sem);
|
|
free(ble_app);
|
|
ble_app = NULL;
|
|
memset(&ble_app_cmd_buffer, 0, sizeof(ble_app_cmd_buffer));
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
// AN5289, 4.9
|
|
|
|
void hci_cmd_resp_release(uint32_t flag) {
|
|
UNUSED(flag);
|
|
furi_check(ble_app);
|
|
furi_check(furi_semaphore_release(ble_app->hci_sem) == FuriStatusOk);
|
|
}
|
|
|
|
void hci_cmd_resp_wait(uint32_t timeout) {
|
|
furi_check(ble_app);
|
|
furi_check(furi_semaphore_acquire(ble_app->hci_sem, timeout) == FuriStatusOk);
|
|
}
|
|
|
|
///////////////////////////////////////////////////////////////////////////////
|
|
|
|
static void ble_app_hci_event_handler(void* pPayload) {
|
|
furi_check(ble_app);
|
|
|
|
tHCI_UserEvtRxParam* pParam = (tHCI_UserEvtRxParam*)pPayload;
|
|
BleEventFlowStatus event_flow_status =
|
|
ble_event_dispatcher_process_event((void*)&(pParam->pckt->evtserial));
|
|
|
|
if(event_flow_status != BleEventFlowDisable) {
|
|
pParam->status = HCI_TL_UserEventFlow_Enable;
|
|
} else {
|
|
pParam->status = HCI_TL_UserEventFlow_Disable;
|
|
}
|
|
}
|
|
|
|
static void ble_app_hci_status_not_handler(HCI_TL_CmdStatus_t status) {
|
|
if(status == HCI_TL_CmdBusy) {
|
|
furi_hal_power_insomnia_enter();
|
|
furi_mutex_acquire(ble_app->hci_mtx, FuriWaitForever);
|
|
} else if(status == HCI_TL_CmdAvailable) {
|
|
furi_mutex_release(ble_app->hci_mtx);
|
|
furi_hal_power_insomnia_exit();
|
|
}
|
|
}
|
|
|
|
void SVCCTL_ResumeUserEventFlow(void) {
|
|
hci_resume_flow();
|
|
}
|