嗨对话框,
我正在开发一对BLE设备,两个服务器和从站,基于DA14580。在彼此连接之后,即使我留下这些处理器闲置(没有读/写/通知,否I2C,GPIO ...处于活动状态),但它们仍然断开随机连接。它看起来像链接层中的一个腐败,因为在断开连接后,它们无法再次重新连接。以下是我为此连接设置的参数以及一些Wireshark捕获。
味精- > nb_peers = 1;
Memcpy((void *)和msg->对等体[0] .addr,(void *)peer_addr,bd_addr_len);
msg->对等体[0] .addr_type = peer_addr_type;
msg-> con_intv_max = 10;
味精- > con_intv_min = 10;
msg-> ce_len_max = 0x20;
msg-> ce_len_min = 0x20;
msg-> con_latency = 0;
味精- > superv_to = 100;
味精- > scan_interval = 0 x180;
味精- > scan_window = 0 x160;
味精- > op。代码= GAPM_CONNECTION_DIRECT;
Wireshark捕获:
9796 61.273854000主从机BLE数据26空数据PDU
9797 61.275295000从站主机BLE数据26空数据PDU
9798 61.286603000主从机BLE数据26空数据PDU
9799 61.287569000 Slave Master BLE Data 26空数据PDU
9800 61.298855000主从BLE Data 26空数据PDU
9801 61.299789000从站主机BLE数据26空数据PDU
9802 62.320227000 AB_MAT5 BLE ADV 48 ADV_IND
9803 62.321788000 AB_MAT5 BLE ADV 48 ADV_IND
服务器和客户端保持60s的连接,无法相互连接。
我仍然可以看到奴隶侧广告,但甚至使用iPhone使用LightBlue应用程序,我无法再连接到奴隶。
Wireshark捕获:
25 6.273182000 AB_MAT4 BLE ADV 48 ADV_IND
26 6.274736000 50:0B:F8:18:AC:29 80:EA:CA:00:00:41 BLE ADV 60 Connect_Req
27 6.276461000主从机BLE数据26空数据PDU
28 6.303327000主从BLE Data 26空数据PDU
29 6.333342000主从机BLE数据26空数据PDU
30 6.363329000主从BLE数据26空数据PDU
31 6.393384000主从机BLE数据26空数据PDU
32 6.423327000主从BLE数据26空数据PDU
33 6.453367000主从BLE数据26空数据PDU
34 6.483385000主从机BLE数据26空数据PDU
35 6.513421000主从机BLE数据26空数据PDU
36 6.543378000主从机BLE数据26空数据PDU
37 6.573448000主从机BLE数据26空数据PDU
38 6.603361000主从机BLE数据26空数据PDU
39 6.633361000主从机BLE数据26空数据PDU
40 7.640482000 ab_mat4 BLE ADV 48 ADV_IND
41 7.642505000 AB_MAT4 BLE ADV 48 ADV_IND
在此测试中,我将连接间隔设置为12.5 ms。在这种情况下,服务器和客户端将在60秒到45分钟后随机断开连接。
在后面的测试中,我将连接间隔更改为30毫秒。他们可以保持更长时间的联系(超过10个小时),但仍然会断开。
我想假设我在空闲状态下将处理器留下,一切都应该自动通过BLE堆栈处理并发送空以保持连接应与我的应用程序代码无关。此外,我在断开连接时没有任何应用活动。
请帮我找出断开的原因,以及如何提高连接的稳定性。
非常感谢。
一些更新,
从我的隔夜测试中,它看起来像BLE定时器无法适当地工作。
首先,它可以工作大约3个小时(可能更多)。我们可以看到,正如我设置的值,master每30毫秒向slave发送一个空PDU。
726216 10926.699285000主从BLE Data 26空数据PDU
726217 10926.699861000 Slave Master BLE Data 26空数据PDU
726218 10926.729275000主从BLE Data 26空数据PDU
726219 10926.729815000从站主机BLE数据26空数据PDU
726220 10926.759274000主从机BLE数据26空数据PDU
726221 10926.760253000从站主板数据26空数据PDU
726222 10926.789250000主从机BLE数据26空数据PDU
726223 10926.790219000 Slave Master BLE Data 26空数据PDU
726224 10926.818524000主从BLE数据26空数据PDU
我猜嗅探员在这里丢了一个。
726225 10926.848719000主从机BLE数据26空数据PDU
726226 10926.850223000 Slave Master Data 26空数据PDU
由于某种原因,我失去了大约10个小时的捕获。幸运的是,就在它们断开连接之前,嗅探器又收到了信号。但是在这个时候,主端似乎表现得很疯狂,它每2ms发送一个空的PDU给客户端,或者当它从从端收到一个空的PDU的时候。
726227 47816.865216000主从BLE Data 26空数据PDU
726228 47816.866244000 Slave Master BLE Data 26空数据PDU
726229 47816.867143000主从机BLE数据26空数据PDU
726230 47816.868015000从机主机BLE数据26空数据PDU
726231 47816.868887000主从BLE数据26空数据PDU
726232 47816.869742000从站主机BLE数据26空数据PDU
726233 47816.870613000主从BLE Data 26空数据PDU
726234 47816.871492000从站主机BLE数据26空数据PDU
.......
726560 47817.196839000主从BLE Data 26空数据PDU
726561 47817.197927000 Slave Master BLE Data 26空数据PDU
726562 47817.198787000主从BLE Data 26空数据PDU
726563 47817.199657000从机主BLE数据26空数据PDU
726564 47817.201497000 ab_mat5 BLE ADV 48 ADV_IND
726565 47817.202433000 ab_mat5 BLE ADV 48 ADV_IND
我希望这些信息给你们对这个问题更有意义,非常感谢。
谢谢!
zwang308,
您在当前实施中使用的SDK以及您拥有的开发套件是什么?据我所知,您使用的连接参数与DSP项目几乎相同。当您与设备连接时,您的假设是正确的,堆栈将通过在不要求应用程序执行任何操作时通过交换空数据包来保持连接。
从第一个日志我可以看到,你的主人停止发送空数据包,以保持连接活着,因此没有响应的奴隶端,超时发生和连接丢失,当这种情况发生时,也许你应该检查你的主机的状态。
从第2条日志来看,从服务器似乎没有响应来自主机的连接请求,检查你是如何在外围代码中处理连接请求的,并检查设备是否到达连接确认。
关于第3个日志,这似乎很奇怪,我无法想象为什么中央将以如此高的速率开始发送空的数据包,特别是如果没有数据发送,中央本身或设备。
由于MT_dialog
我使用的是SDK 3.0.10.1。
问题是连接会随机中断。
对于12ms连接间隔,有时连接进展超过一小时;但有时他们会在2分钟后断开连接。
在将连接间隔更改为30ms后,平均连接时间更长。但他们仍然随机断开连接,
当它们断开连接时,实际上没有应用程序活动。我假设BLE堆栈将处理连接,在此期间自动发送/ack空PDU。
此外,即使他们断开连接,它们也应该能够重新连接。但是一旦他们断开连接,就无法再连接到奴隶,无论我使用我的主应用程序还是使用一些标准设备。苹果手机。
对我而言,它看起来像Slave的BLE堆栈的一部分搞砸了:从机可以接收来自Master的连接请求(它停止广告),但它无法发送ACK。所以,两侧刚刚在1秒后断开连接。奴隶开始再次宣传奴隶。
这些是我测试中得到的一切。
非常感谢你的帮助!
顺便说一下,我对所有测试使用相同的代码库。我确信从属侧发送连接请求确认,否则它们不会连接。同样,问题是Connect -----保持随机时间的连接---断开连接,从不能够重新连接。
谢谢,
zwang308,
我已经实现了一个中央和外设上的SDK 3.0.10.1(没有配置文件包括),我已经设置连接参数到主机与您的相同的连接间隔等于12.5毫秒之间的专业和基本套件。到目前为止,一切似乎都是正确的,连接持续到我可以看(超过两个小时),我也能够重新连接到主机,(在延长睡眠模式)。您是否实现了任何配置文件或任何其他功能,以尝试和再现您的问题?
由于MT_dialog
嗨MT_dialog,
我所做的就像你的DSP项目一样。
当我收到包时,我开发I2C驱动程序并将数据放入NVRAM。在app_asynch_trim函数中,我拉动缓冲区并通过ble发送数据。
但在我的测试中,我禁用APP_ASYNCH_TRIM中的I2C驱动程序和拉动功能。在测试中,两个DA14580S在断开连接时真的无所畏惧。
从我的观察开始,他们一直在发送空的PDU一段时间,突然将主站暂停发送空的PDU。我们有方法要知道为什么大师停止发送空的PDU吗?我们可以从内核那里收到一条消息,以知道他们为什么断开连接。
对我来说,似乎他们随机断开连接。我们上周做了很多测试,有时联系良好超过16小时;有时他们会在2分钟后断开连接。
它真的很困惑我。
谢谢!
zwang308,
您可以运行主表单keil并检查此问题时检查,您的主人是什么状态?您的处理程序也表明当您停止主机接收数据时,主站或至少由您的从站断开连接。您可以将休闲点放在您的设备上,并检查您作为断开连接的原因。没有办法检查主设备不会发送任何数据,错误指示或类似的东西,因为这不应该发生堆栈应该始终保持连接。
由于MT_dialog
嗨mt_dialog,
他们第一次断开连接。外围设备上的错误代码为0x13(远程用户终止连接),而中心侧的错误代码为0x08(连接超时)。
之后,外设端的错误码总是0x08,中央端的错误码是0x3e(CONNECTION FAILED TO BE ESTABLISHED)。
我不认为代码实际上停止了一点,因为双方一直在广告/扫描和连接状态之间切换。
我们知道为什么会发生这种情况吗?
我们是否有一个软复位芯片的方法(从开头运行固件而无需重新加载固件或仅重置BLE堆栈)?
非常感谢。
zwang308,
在我们执行的测试中,我们没有观察到任何类似的情况(例如,中央停止发送数据包),尽管我们设法跟踪了一个边角情况,其中外设在特定情况下无法连接,针对特定边角情况的补丁还没有发布。对于这种情况,我们建议对580执行一个sw复位或重置堆栈。
您可以尝试发出重置使用SW_RESET SYS_CTRL_REG字段,设置sysram起始地址(请检查数据表),尽管它不是一个好主意,然后重新引导从原始图像者优先(下载使用引导装载程序中的代码580)你也可以试着发送GAPM_RESET命令以重置堆栈。
也是可以共享一些代码(中央和设备),以便看看,因为我们无法在我们身边复制问题?
由于MT_dialog
嗨mt_dialog,
你能给我一个发送代码的邮箱地址吗?你可以通过电子邮件和我联系。
非常感谢,
zwang308,
问题是由于过时的SDK。
由于MT_dialog
嗨,mt_dialog。
我正在遭受与Zwang308先生的错误相同的错误。我正在使用SDK版本v3.0.8。你说这是由于一个过时的SDK,请告诉我哪个SDK没问题。谢谢。
嗨menson,
最新的SDK是580设备的5.0.4。
由于MT_dialog