设备在AVG中每20秒断开连接

⚠️
嗨,...感谢您来论坛。令人兴奋的消息!我们现在正在迁至我们的新论坛平台,将提供更好的功能,并包含在主对话框网站中。所有帖子和帐户都已迁移。我们现在只接受新论坛上的流量 - 请发布任何新线程https://www.dialog-seminile.com/support.。我们将在未来几天修复错误/优化搜索和标记。
12个帖子/ 0新
最后一篇
Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
设备在AVG中每20秒断开连接

你好,
我正在使用DA14580通过UART传输数据。
当我添加uart连接时,设备平均每20秒从手机断开一次。
如果我不使用uart,设备不会断开。(从主循环我发送uart请求每10秒)
user_app_disconnect.20SEC通过电话连接到设备后调用。

我的UART实现可能导致设备断开连接是什么?或者,如何防止设备断开连接。
如何弄清楚导致断开连接的原因。

谢谢,
Ezza

设备:
Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
调试后,GAPC

调试之后,将调用gapc_disconnect_ind_handler。

Static int gapc_disconnect_ind_handler(ke_msg_id_t const msgid,
struct gapc_disconnect_ind const * param,
ke_task_id_t const dest_id,
ke_task_id_t const src_id)
{
if(ke_idx_get(src_id)== diss_env.con_info.conidx)
{
diss_disable (param - > conhdl);
}

return(ke_msg_consumed);
}

-----------------------------------
gapc_disconnect_ind const * param参数有一个断开连接的原因。

///表示链接已断开连接
struct gapc_disconnect_ind.
{
///连接句柄
uint16_t conhdl;
///断开的原因
UINT8_T理由;
};
原因值为0x08。

mt_dialog.
离线
最后一次露面:3个月2天前
职员
加入:2015-06-08 11:34
嗨Ezza,

嗨Ezza,

好吧,我可以假设的是,您正在使用UART保持ARM占用,并且在此期间没有安排BLE事件,所以设备永远不会按时连接事件,最终您正在丢失连接事件和超时发生。您获得的断开连接原因是由于连接超时,这表明您正在缺少连接事件。

谢谢mt_dialog.

Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
你好,

你好,
谢谢你的回复。
我怎样才能防止这种情况发生呢?
我不希望我的设备在uart事件期间断开连接。

Ibbkoeln.
离线
最后一次露面:4个月2天前
加入:2016-03-18 10:34
嗨Ezza,

嗨Ezza,

也许您在主循环中的UART调用期间正在进行一些耗时或阻塞操作?你是什​​么意思“主循环”?据我所知,用户应用程序API中没有主循环,只是回调。我想我们必须看到你的代码更好地了解这一点。

问候,
奥利弗

Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
你好,

你好,
因为DA14580没有“Read”指示事件。我必须进入主拱门,并在那里添加一个自定义代码。
在Arch_Main的主循环中,我调用UART命令来更新BLE的DB,以便手机应用读取更新的数据。
例如,我在我的ST固件上有一个计数器,该计数器正在全部更新,并且应用程序需要读取该计数器。我通过每10秒发送来自主循环的UART命令,在BLE的DB上保持更新。

是否有任何方法来增加断开事件的超时值?(例如,即使我没有捕获连接事件,等待超过20秒)。
为什么通过UART发送\获取命令会导致断开连接?

谢谢,
Ezza

Ibbkoeln.
离线
最后一次露面:4个月2天前
加入:2016-03-18 10:34
嗨Ezza,

嗨Ezza,

要定期阅读值,我强烈建议使用易于计时器API而不是更改ARCH_MAIN,因为这可以很容易地打扰BLE定时。以下是我如何实现这一点:

#define read_value_interval 1000 // 1 => 10ms

静态timer_hnd readvaluetimer = easy_timer_invalid_timer;
静态UINT8 rxdata [rx_size];

void rxuartcallback(uint8状态){
if(state == uart_ok){
//处理rxData
ReadValuetimer = app_easy_timer(100,ReadValueFromuart);
} 别的 {
/ /错误处理
}
}

空白readValueFromUart () {
uart_read (rxData RX_SIZE rxUartCallback);

uint8 cmd [] = {...};
UART_WRITE(cmd,sizeof(cmd),null);
}

void user_on_connection(uint8_t connection_idx,struct gapc_connection_req_ind const * param){
......
readValueTimer = app_easy_timer(READ_VALUE_INTERVAL, readValueFromUart);
}

void user_on_disconnect(struct gapc_disconnect_ind const * param){
if(readvaluetimer!= easy_timer_invalid_timer){
app_easy_timer_cancel(ReadValuetimer);
readvaluetimer = easy_timer_invalid_timer;
}
}

问候,
奥利弗

Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
你好,

你好,
不幸的是,它仍然是相同的问题。我更改了代码并从Arch_Main中删除了所有内容并使用Easy_Timer。
此外,即使我从手机上发送活动,如“写入”,它仍然将在AVG中的20SEC中断开连接。

Ibbkoeln.
离线
最后一次露面:4个月2天前
加入:2016-03-18 10:34
连接稳定吗?

连接是否稳定,没有读取/写入一个特征,只是在后台连续读取uart上的值?

Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
你好,

你好,
即使我什么都不做(既不读也不写),它也不稳定。
我只是连接设备,等待它断开连接。

Ezza
离线
最后一次露面:一年6个月前
加入:2017-09-07十一33
你好,

你好,
我可以在哪里搅乱断开事件,并防止它发生?
它对我们来说是一个阻碍,因为设备不断断开连接,手机应用程序获得异常,直到它最终成功从ble中读取所有的值。这将导致性能的显著下降。

mt_dialog.
离线
最后一次露面:3个月2天前
职员
加入:2015-06-08 11:34
嗨Ezza,

嗨Ezza,

您将阻止任何UART活动重叠连接间隔,UART通信应突发,而不是长时间占用的ARM,因为您可以按时按时编程BLE事件。例如,您可以在.app_on_system_powered中附加一个UART逻辑才能处理任何UART事件,但您不应该长时间留在那里,您应该返回Keep_Power后,以便再次强制计划_While_ble_on()以重新运行以便安排任何将发生的BLE事件,然后SDK将在其余的UART活动中再次运行.app_on_system_powered。关于增加监督超时,我想现在超时大约20秒如果增加它,那么这将从断开连接取决于您正在使用的连接间隔,但再次这不是您应该查看您的实现的解决方案为了在UART交互期间不放松连接事件。您无法停止断开触发断开,只要监控超时发生,即使阻止您的回调仍将断开该消息,也会从堆栈中从堆栈中获取。

谢谢mt_dialog.