在使用中碰到生成二维码时死机的现象,经发现是由于开机时,后台进行了蓝牙初始化操作,初始化操作的完成是异步事件通知的。在初始化完成之前,调用了二维码生成的代码,导致在二维码生成的过程中,又进行了蓝牙初始化的操作。初步估计这两部分操作比较耗资源,导致冲突出错。通过检查蓝牙初始化完成事件来错开这两部分同时操作,问题暂时解决。
相关主要代码如下:
static volatile U8 BluetoothInitedFlag = 0;
void WaitForBtInited(void)
{
while(1)
{
if(BluetoothInitedFlag == 1)
{
break;
}
}
}
void TRSPX_bt_evt_hdl(bt_evt_t *evt)
{
switch(evt->evt_id)
{
case BT_MISC_EVENT_INITED:
TRSPX_bt_inited_handler(evt);
BluetoothInitedFlag = 1;
DOOR_PRINT("......BT_MISC_EVENT_INITED......\n");
break;
case BLE_GAP_EVT_CONNECTED:
CleanDoorBleAutoDisTime();
TRSPX_connection_complete_handler(evt);
SetAtPassFlag(0);
DOOR_PRINT("......BLE_GAP_EVT_CONNECTED......\n");
break;
//case BLE_GAP_EVT_DISCONNECED:
case BLE_GAP_EVT_DISCONNECGED:
CleanDoorBleAutoDisTime();
TRSPX_ble_status = BLE_IDLE;
TRSPX_bt_inited_after_disconnected(evt);
SetAtPassFlag(0); //清楚已验证标志
ClrDisconnectProcessFig();
Ble_AutoRst(-1); //清除自动复位
Enable_SendCard_ToApp(0);
DOOR_PRINT("......BLE_GAP_EVT_DISCONNECED......\n");
break;
case BLE_GAP_EVT_CONNECT_PARM_UPDATE:
DOOR_PRINT("......BLE_GAP_EVT_CONNECT_PARM_UPDATE......\n");
break;
/*
case BLE_SM_EVT_SEC_INFO_REQUEST:
DOOR_PRINT("......BLE_SM_EVT_SEC_INFO_REQUEST......\n");
break;
*/
}
}
TRSPX_init();
BT_InitEx(TRSPX_bt_evt_hdl, NULL, 0);
WaitForBtInited();