mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-15 09:34:17 +00:00
tipc: fix bug in link protocol message create function
In commit dd3f9e70f59f43a5712eba9cf3ee4f1e6999540c ("tipc: add packet sequence number at instant of transmission") we made a change with the consequence that packets in the link backlog queue don't contain valid sequence numbers. However, when we create a link protocol message, we still use the sequence number of the first packet in the backlog, if there is any, as "next_sent" indicator in the message. This may entail unnecessary retransissions or stale packet transmission when there is very low traffic on the link. This commit fixes this issue by only using the current value of tipc_link::snd_nxt as indicator. Signed-off-by: Jon Maloy <jon.maloy@ericsson.com> Signed-off-by: David S. Miller <davem@davemloft.net>
This commit is contained in:
parent
05c985436d
commit
f3903bcc00
@ -1320,8 +1320,6 @@ void tipc_link_proto_xmit(struct tipc_link *l_ptr, u32 msg_typ, int probe_msg,
|
|||||||
|
|
||||||
if (!tipc_link_is_up(l_ptr))
|
if (!tipc_link_is_up(l_ptr))
|
||||||
return;
|
return;
|
||||||
if (skb_queue_len(&l_ptr->backlogq))
|
|
||||||
next_sent = buf_seqno(skb_peek(&l_ptr->backlogq));
|
|
||||||
msg_set_next_sent(msg, next_sent);
|
msg_set_next_sent(msg, next_sent);
|
||||||
if (!skb_queue_empty(&l_ptr->deferdq)) {
|
if (!skb_queue_empty(&l_ptr->deferdq)) {
|
||||||
last_rcv = buf_seqno(skb_peek(&l_ptr->deferdq));
|
last_rcv = buf_seqno(skb_peek(&l_ptr->deferdq));
|
||||||
|
Loading…
x
Reference in New Issue
Block a user