pinebuds/services/ble_app/app_main/app_ble_rx_handler.c

162 lines
4.6 KiB
C
Raw Permalink Normal View History

2022-08-15 04:20:27 -05:00
#include "app_ble_rx_handler.h"
#include "app_bt_func.h"
#include "ble_app_dbg.h"
#include "cmsis.h"
#include "cmsis_os.h"
#include "cqueue.h"
2022-08-15 04:20:27 -05:00
#ifdef BISTO_ENABLED
#include "gsound_custom_ble.h"
#include "gsound_service.h"
2022-08-15 04:20:27 -05:00
#endif
#define BLE_RX_EVENT_MAX_MAILBOX 16
#define BLE_RX_BUF_SIZE (2048)
2022-08-15 04:20:27 -05:00
static uint8_t app_ble_rx_buf[BLE_RX_BUF_SIZE];
static CQueue app_ble_rx_cqueue;
#define VOICEPATH_COMMON_OTA_BUFF_SIZE 4096
uint8_t *app_voicepath_get_common_ota_databuf(void) {
static uint8_t voicepath_common_ota_buf[VOICEPATH_COMMON_OTA_BUFF_SIZE];
return voicepath_common_ota_buf;
2022-08-15 04:20:27 -05:00
}
#ifdef BES_OTA_BASIC
extern void ota_bes_handle_received_data(uint8_t *otaBuf, bool isViaBle,
uint16_t dataLenth);
2022-08-15 04:20:27 -05:00
#if defined(IBRT)
#ifdef IBRT_OTA
extern void ota_ibrt_handle_received_data(uint8_t *otaBuf, bool isViaBle,
uint16_t len);
2022-08-15 04:20:27 -05:00
#endif
#endif
#endif
#if (BLE_APP_TOTA)
extern void app_tota_handle_received_data(uint8_t *buffer, uint16_t maxBytes);
2022-08-15 04:20:27 -05:00
#endif
static osThreadId app_ble_rx_thread = NULL;
static bool ble_rx_thread_init_done = false;
extern void gsound_send_control_rx_cfm(uint8_t conidx);
extern uint8_t app_ota_get_conidx(void);
extern void app_ota_send_rx_cfm(uint8_t conidx);
static void app_ble_rx_handler_thread(const void *arg);
osThreadDef(app_ble_rx_handler_thread, osPriorityNormal, 1, 2048, "ble_rx");
osMailQDef(ble_rx_event_mailbox, BLE_RX_EVENT_MAX_MAILBOX, BLE_RX_EVENT_T);
2022-08-15 04:20:27 -05:00
static osMailQId app_ble_rx_event_mailbox = NULL;
static int32_t app_ble_rx_event_mailbox_init(void) {
app_ble_rx_event_mailbox = osMailCreate(osMailQ(ble_rx_event_mailbox), NULL);
if (app_ble_rx_event_mailbox == NULL) {
LOG_I("Failed to Create app_ble_rx_event_mailbox");
return -1;
}
return 0;
2022-08-15 04:20:27 -05:00
}
static void update_init_state(bool state) { ble_rx_thread_init_done = state; }
2022-08-15 04:20:27 -05:00
static bool get_init_state(void) { return ble_rx_thread_init_done; }
2022-08-15 04:20:27 -05:00
static void app_ble_rx_mailbox_free(BLE_RX_EVENT_T *rx_event) {
osStatus status;
2022-08-15 04:20:27 -05:00
status = osMailFree(app_ble_rx_event_mailbox, rx_event);
ASSERT(osOK == status, "Free ble rx event mailbox failed!");
2022-08-15 04:20:27 -05:00
}
void app_ble_rx_handler_init(void) {
if (!get_init_state()) {
InitCQueue(&app_ble_rx_cqueue, BLE_RX_BUF_SIZE,
(CQItemType *)app_ble_rx_buf);
app_ble_rx_event_mailbox_init();
app_ble_rx_thread =
osThreadCreate(osThread(app_ble_rx_handler_thread), NULL);
update_init_state(true);
} else {
LOG_I("rx already initialized");
}
2022-08-15 04:20:27 -05:00
}
void app_ble_push_rx_data(uint8_t flag, uint8_t conidx, uint8_t *ptr,
uint16_t len) {
uint32_t lock = int_lock();
int32_t ret = EnCQueue(&app_ble_rx_cqueue, ptr, len);
int_unlock(lock);
ASSERT(CQ_OK == ret, "BLE rx buffer overflow! %d,%d",
AvailableOfCQueue(&app_ble_rx_cqueue), len);
BLE_RX_EVENT_T *event =
(BLE_RX_EVENT_T *)osMailAlloc(app_ble_rx_event_mailbox, 0);
event->flag = flag;
event->conidx = conidx;
event->ptr = ptr;
event->len = len;
osMailPut(app_ble_rx_event_mailbox, event);
2022-08-15 04:20:27 -05:00
}
static int32_t app_ble_rx_mailbox_get(BLE_RX_EVENT_T **rx_event) {
osEvent evt;
evt = osMailGet(app_ble_rx_event_mailbox, osWaitForever);
if (evt.status == osEventMail) {
*rx_event = (BLE_RX_EVENT_T *)evt.value.p;
LOG_I("flag %d ptr %p len %d", (*rx_event)->flag, (*rx_event)->ptr,
(*rx_event)->len);
return 0;
}
return -1;
2022-08-15 04:20:27 -05:00
}
extern int app_ibrt_if_tws_sniff_block(uint32_t block_next_sec);
static void app_ble_rx_handler_thread(void const *argument) {
while (true) {
BLE_RX_EVENT_T *rx_event = NULL;
if (!app_ble_rx_mailbox_get(&rx_event)) {
uint8_t tmpData[512];
uint32_t lock = int_lock();
DeCQueue(&app_ble_rx_cqueue, tmpData, rx_event->len);
int_unlock(lock);
switch (rx_event->flag) {
#ifdef BISTO_ENABLED
case BLE_RX_DATA_GSOUND_CONTROL:
#ifdef IBRT
app_ibrt_if_tws_sniff_block(5);
#endif
LOG_I("gsound processes %d control data.", rx_event->len);
app_gsound_rx_control_data_handler(rx_event->ptr, rx_event->len);
break;
#endif
#if (BLE_APP_OTA)
case BLE_RX_DATA_SELF_OTA:
#if defined(IBRT)
#ifdef IBRT_OTA
ota_ibrt_handle_received_data(tmpData, true, rx_event->len);
app_ota_send_rx_cfm(app_ota_get_conidx());
#endif
#else
ota_bes_handle_received_data(tmpData, true, rx_event->len);
#endif
break;
#endif
#if (BLE_APP_TOTA)
case BLE_RX_DATA_SELF_TOTA:
app_tota_handle_received_data(tmpData, rx_event->len);
break;
#endif
default:
break;
}
app_ble_rx_mailbox_free(rx_event);
2022-08-15 04:20:27 -05:00
}
}
2022-08-15 04:20:27 -05:00
}