tcp_input: if tcp->req > recvreq, send ack only when state is TCP_ESTABLISHED
The Bluetooth network on N62 does not retransmit packet, so no packet retransmition if we drop one, we will drop packet when tcp_close_eventhandler is register and invoke by tcp_input. then we will always early return and never stop, the peer will only close the connection if we send reset packet. precondition: close -> register tcp_close_eventhandler; tcp_input -> tcp_callback(TCP_NEWDATA) -> devif_conn_event -> tcp_close_eventhandler -> flags &= ~TCP_NEWDATA -> NOT entry tcp_data_event -> conn->recvreq NOT increase old flow: tcp_input -> tcp->seqno greater than conn->rcvseq -> tcp_send(TCP_ACK) with this patch: tcp_input -> tcp->seqno greater than conn->rcvseq -> !TCP_ESTABLISHED -> case TCP_FIN_WAIT_1 -> dev->d_len greater than 0 -> tcp_reset Signed-off-by: zhanghongyu <zhanghongyu@xiaomi.com>
This commit is contained in:
parent
5fedb1e6de
commit
3c4897310b
@ -1185,8 +1185,11 @@ found:
|
|||||||
|
|
||||||
tcp_input_ofosegs(dev, conn, iplen);
|
tcp_input_ofosegs(dev, conn, iplen);
|
||||||
#endif
|
#endif
|
||||||
tcp_send(dev, conn, TCP_ACK, tcpiplen);
|
if ((conn->tcpstateflags & TCP_STATE_MASK) <= TCP_ESTABLISHED)
|
||||||
return;
|
{
|
||||||
|
tcp_send(dev, conn, TCP_ACK, tcpiplen);
|
||||||
|
return;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
}
|
}
|
||||||
|
Loading…
Reference in New Issue
Block a user