diff options
author | David Howells <dhowells@redhat.com> | 2016-09-24 19:05:27 +0200 |
---|---|---|
committer | David Howells <dhowells@redhat.com> | 2016-09-25 00:49:46 +0200 |
commit | 0d967960d39ee89f9e0289692e9f7232f490e55c (patch) | |
tree | 043b35c0ef2f2367018bb42ebfd2ab5b65c1e7cd /net/rxrpc/misc.c | |
parent | rxrpc: Generate a summary of the ACK state for later use (diff) | |
download | linux-0d967960d39ee89f9e0289692e9f7232f490e55c.tar.xz linux-0d967960d39ee89f9e0289692e9f7232f490e55c.zip |
rxrpc: Schedule an ACK if the reply to a client call appears overdue
If we've sent all the request data in a client call but haven't seen any
sign of the reply data yet, schedule an ACK to be sent to the server to
find out if the reply data got lost.
If the server hasn't yet hard-ACK'd the request data, we send a PING ACK to
demand a response to find out whether we need to retransmit.
If the server says it has received all of the data, we send an IDLE ACK to
tell the server that we haven't received anything in the receive phase as
yet.
To make this work, a non-immediate PING ACK must carry a delay. I've chosen
the same as the IDLE ACK for the moment.
Signed-off-by: David Howells <dhowells@redhat.com>
Diffstat (limited to 'net/rxrpc/misc.c')
-rw-r--r-- | net/rxrpc/misc.c | 2 |
1 files changed, 2 insertions, 0 deletions
diff --git a/net/rxrpc/misc.c b/net/rxrpc/misc.c index 901c012a2700..a608769343e6 100644 --- a/net/rxrpc/misc.c +++ b/net/rxrpc/misc.c @@ -198,7 +198,9 @@ const char rxrpc_timer_traces[rxrpc_timer__nr_trace][8] = { }; const char rxrpc_propose_ack_traces[rxrpc_propose_ack__nr_trace][8] = { + [rxrpc_propose_ack_client_tx_end] = "ClTxEnd", [rxrpc_propose_ack_input_data] = "DataIn ", + [rxrpc_propose_ack_ping_for_lost_reply] = "LostRpl", [rxrpc_propose_ack_ping_for_params] = "Params ", [rxrpc_propose_ack_respond_to_ack] = "Rsp2Ack", [rxrpc_propose_ack_respond_to_ping] = "Rsp2Png", |