CC2640R2F从机(Peripheral)执行GATT_WriteNoRsp后程序崩溃问题
时间:10-02
整理:3721RD
点击:
CC2640R2F参考官方simple_peripheral_cc2640r2lp_app例程写了一段Peripheral向Central写变量的代码,采用WriteNoRsp方式,connection handle和character handle已事先正确获得,并且simple_peripheral_cc2640r2lp_stack部分已去掉了NO_GATT_CLIENT定义,WriteNoRsp返回SUCCESS,通过sniffer抓包也能够抓到Peripheral发送的写变量数据包。
现在遇到的问题是WriteNoRsp执行完之后,执行到Event_post这里程序就会崩溃,跳到ti_sysbios_family_arm_m3_Hwi_excHandler,如果不执行WrtieNoRsp就没有问题,查了很久都没有找到原因,希望各位高手能指点一二,非常感谢!
static gattMsg_t t_Message;
static uint16 u16_ConnectionHandle;
static uint16 u16_CharacterHandle;
static ICall_SyncHandle t_ICallSyncHandle;
static ICall_EntityID t_ICallEntityID;
#define EVENT_WRITE (1 << 0)
void ProcessTask(UArg a0, UArg a1)
{
uint32_t t_Events;
ICall_registerApp(&t_ICallEntityID, &t_ICallSyncHandle);
while (1)
{
t_Events = Event_pend(t_ICallSyncHandle, Event_Id_NONE,
EVENT_WRITE, ICALL_TIMEOUT_FOREVER);
//do something
}
}
uint GATT_Write (const uint8 *u8p_Data, uint8 u8_Length)
{
attWriteReq_t *tp_WriteRequest;
tp_WriteRequest = &t_Message.writeReq;
tp_WriteRequest->pValue = (uint8 *)GATT_bm_alloc(u16_ConnectionHandle, ATT_WRITE_REQ, (uint16)u8_Length, NULL);
if (tp_WriteRequest->pValue != NULL )
{
tp_WriteRequest->len = u8_Length;
tp_WriteRequest->sig = 0;
tp_WriteRequest->cmd = 1;
memcpy(tp_WriteRequest->pValue, u8p_Data, u8_Length);
tp_WriteRequest->handle = u16_CharacterHandle;
if (GATT_WriteNoRsp(u16_ConnectionHandle, tp_WriteRequest) != SUCCESS)
{
GATT_bm_free(&t_Message, ATT_WRITE_REQ);
return FUNCTION_FAIL;
}
}
Event_post(t_ICallSyncHandle, EVENT_WRITE);
return FUNCTION_OK;
}
找到原因了,Gatt_WriteNoRsp所在任务堆栈溢出了,原来参考官方示例设置为512字节,改成1024字节就正常了,官方示例的堆栈设置太保守了...
看到你在E2E发的帖子了,原因是堆栈溢出。其实对于堆栈大小,TI没有明确规定,一般来说,如果应用比较复杂, 需要手动改一下大小
谢谢分享经验,说明rtos还是耗费硬件资源的
