提交 4807b518 编写于 作者: L Loic Poulain 提交者: Marcel Holtmann

Bluetooth: Fix HCI H5 corrupted ack value

In this expression: seq = (seq - 1) % 8
seq (u8) is implicitly converted to an int in the arithmetic operation.
So if seq value is 0, operation is ((0 - 1) % 8) => (-1 % 8) => -1.
The new seq value is 0xff which is an invalid ACK value, we expect 0x07.
It leads to frequent dropped ACK and retransmission.
Fix this by using '&' binary operator instead of '%'.
Signed-off-by: NLoic Poulain <loic.poulain@intel.com>
Signed-off-by: NMarcel Holtmann <marcel@holtmann.org>
Cc: stable@vger.kernel.org
上级 5d88cc73
...@@ -237,7 +237,7 @@ static void h5_pkt_cull(struct h5 *h5) ...@@ -237,7 +237,7 @@ static void h5_pkt_cull(struct h5 *h5)
break; break;
to_remove--; to_remove--;
seq = (seq - 1) % 8; seq = (seq - 1) & 0x07;
} }
if (seq != h5->rx_ack) if (seq != h5->rx_ack)
......
Markdown is supported
0% .
You are about to add 0 people to the discussion. Proceed with caution.
先完成此消息的编辑!
想要评论请 注册