BLE 数据包重传机制

转自:http://blog.csdn.net/zwc1725/article/details/52788524


处于连接态的两个BLE终端使用简单的“停等”机制进行通信,如下图所示,



图一 BLE 数据包重传流程图


每个BLE终端都维护两个1 bit参数:transmitSeqNum和nextExpectedSeqNum,分别指

示当前传输的数据包序号和下一个期待接收的数据包序号,它们与Packet中的SN和NESN字段一起维护Master和Slave之间的重传机制。

transmitSeqNum和nextExpectedSeqNum在connect建立时都初始化为0。


发送数据包时,对于SN字段,若数据包为新传,则设置为自身transmitSeqNum取值,否者与上一次传输一致;对于NESN字段,始终设置为自身nextExpectedSeqNum取值。

接收数据包时,transmitSeqNum和nextExpectedSeqNum按照如下原则进行更新: 


1  若SN字段与自身nextExpectedSeqNum一致,则表明该数据包为重传, nextExpectedSeqNum不变;否者为新传,并且需要将自身nextExpectedSeqNum取反。


 2  若NESN字段与自身transmitSeqNum一致,则表明接收到NACK,即上一次自己 发送的数据包失败,需要重发;否者表明收到ACK,需要发送新的数据包,并且将将自身transmitSeqNum取反。 


3  若接收到的数据包CRC错误,则不更新transmitSeqNum和nextExpectedSeqNum, 并重发上一次自己发送的数据包(判定收到了NACK) 以下处理流程如下图所示,



图二 数据包发送方和接收方处理流程图


如此设计,Master和Slave之间的“停等”重传机制可良好运转。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值