工程师们,你们好,我在使用CC2640R2F进行开发串口接收到数据统计,要做一个超时检测功能,在一段时间内没有接收到数据则回复一个错误,请问可以使用定时器吗?这个定时器在串口收到数据后重新装载,重新计数,请问我该使用什么接口?我看了论坛里的一些帖子,有一个GAPTimer的接口,在配置结构体的时候有一个Hwip的配置,这个接口好像不太对,麻烦解答一下,谢谢(蓝牙5.0)
GuppyCat:
回复 Viki Shi:
GPTimerCC26XX_Handle hTimer;
static GPTimerCC26XX_Value ReloadValue = 0;//这个值用来重装
void timerCallback(GPTimerCC26XX_Handle handle, GPTimerCC26XX_IntMask interruptMask)
//触发中断事件,向串口打印完成并关闭定时器
{UART_Handle MyUart = GetUartHandle();UART_write(MyUart, "Finish", 6);GPTimerCC26XX_stop(hTimer);
}void UartTimeOutTimer_Start(void)//开启定时器
{GPTimerCC26XX_start(hTimer);
}void UartTimeOutTimer_Init(void)//定时器初始化
{GPTimerCC26XX_Params params;GPTimerCC26XX_Params_init(¶ms);params.width= GPT_CONFIG_16BIT;//16bit width timerparams.mode= GPT_MODE_PERIODIC;//Period timerparams.direction= GPTimerCC26XX_DIRECTION_UP;//Timer's direction upparams.debugStallMode = GPTimerCC26XX_DEBUG_STALL_OFF;//No debug stall modewhile(1){hTimer = GPTimerCC26XX_open(CC2640R2_LAUNCHXL_GPTIMER0, ¶ms);//Open timerif(hTimer == NULL) {continue;//If open failed, retry again}elsebreak;}Types_FreqHzfreq;BIOS_getCpuFreq(&freq);ReloadValue = freq.lo – 1; //47999999,这里为其赋上期望值
GPTimerCC26XX_setLoadValue(hTimer, ReloadValue);GPTimerCC26XX_registerInterrupt(hTimer, timerCallback, GPT_INT_TIMEOUT);
}void UartTimeOutTimer_ReloadValue(void)//定时时间重置{GPTimerCC26XX_setLoadValue(hTimer, ReloadValue);
}您好,我的代码定时时间不对(我期望的预设值是1s),我找了很久,找不到问题所在,另外,定时器重装直接用GPTimerCC26XX_setLoadValue接口可以吗?
GuppyCat:
回复 GuppyCat:
位宽写错了,定时器重装直接用GPTimerCC26XX_setLoadValue接口可以吗?
Viki Shi:
回复 GuppyCat:
GPTimerCC26XX_setLoadValue 的设置请参考这边类似帖:e2e.ti.com/…/2234068
Viki Shi:
回复 GuppyCat:
感谢提供反馈
GuppyCat:
回复 Viki Shi:
您好,我已将这份代码(修改后)放到simple_peripheral中,并能正常运行,连接移植前simple_central后正常收发,但是我将这份代码移植到simple_central的时候(移植过程中在main中增加了定时器初始化,与simple_peripheral相同),出现了如下问题:
simple_central串口在接收数据后,能够通过事件到达APP(simple_central和simple_peripheral已经连接完成,simple_peripheral向simple_central发送数据正常),但是simple_central此时却无法将数据成功下发到simple_peripheral。
调试时发现如下代码中返回的status并不是SUCCESS,并且在之后串口无法工作,协议栈其他部分正常(simple_peripheral发送数据到simple_central时返回值是SUCCESS)//Send messagestatus = GATT_WriteCharValue(dstConnHandle, &req, selfEntity);if ( status != SUCCESS ){GATT_bm_free((gattMsg_t *)&req, ATT_WRITE_REQ);}请问这个问题的原因是什么?能提供我一个大概问题的方向吗?