aboutsummaryrefslogtreecommitdiffstats
path: root/include/net/tcp.h
diff options
context:
space:
mode:
authorIlpo Järvinen <ilpo.jarvinen@helsinki.fi>2007-08-09 08:14:46 -0400
committerDavid S. Miller <davem@sunset.davemloft.net>2007-10-10 19:48:00 -0400
commite60402d0a909ca2e6e2fbdf9ed004ef0fae36d33 (patch)
treeb40a00b801cf44f81bebd7dadddb19c0086b145c /include/net/tcp.h
parentb9c4595bc4947faa236a849324fe3492e388d949 (diff)
[TCP]: Move sack_ok access to obviously named funcs & cleanup
Previously code had IsReno/IsFack defined as macros that were local to tcp_input.c though sack_ok field has user elsewhere too for the same purpose. This changes them to static inlines as preferred according the current coding style and unifies the access to sack_ok across multiple files. Magic bitops of sack_ok for FACK and DSACK are also abstracted to functions with appropriate names. Note: - One sack_ok = 1 remains but that's self explanary, i.e., it enables sack - Couple of !IsReno cases are changed to tcp_is_sack - There were no users for IsDSack => I dropped it Signed-off-by: Ilpo Järvinen <ilpo.jarvinen@helsinki.fi> Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'include/net/tcp.h')
-rw-r--r--include/net/tcp.h28
1 files changed, 28 insertions, 0 deletions
diff --git a/include/net/tcp.h b/include/net/tcp.h
index b92bdc7c92a9..0a4ed6e85c6f 100644
--- a/include/net/tcp.h
+++ b/include/net/tcp.h
@@ -719,6 +719,34 @@ static inline void tcp_ca_event(struct sock *sk, const enum tcp_ca_event event)
719 icsk->icsk_ca_ops->cwnd_event(sk, event); 719 icsk->icsk_ca_ops->cwnd_event(sk, event);
720} 720}
721 721
722/* These functions determine how the current flow behaves in respect of SACK
723 * handling. SACK is negotiated with the peer, and therefore it can vary
724 * between different flows.
725 *
726 * tcp_is_sack - SACK enabled
727 * tcp_is_reno - No SACK
728 * tcp_is_fack - FACK enabled, implies SACK enabled
729 */
730static inline int tcp_is_sack(const struct tcp_sock *tp)
731{
732 return tp->rx_opt.sack_ok;
733}
734
735static inline int tcp_is_reno(const struct tcp_sock *tp)
736{
737 return !tcp_is_sack(tp);
738}
739
740static inline int tcp_is_fack(const struct tcp_sock *tp)
741{
742 return tp->rx_opt.sack_ok & 2;
743}
744
745static inline void tcp_enable_fack(struct tcp_sock *tp)
746{
747 tp->rx_opt.sack_ok |= 2;
748}
749
722static inline unsigned int tcp_left_out(const struct tcp_sock *tp) 750static inline unsigned int tcp_left_out(const struct tcp_sock *tp)
723{ 751{
724 return tp->sacked_out + tp->lost_out; 752 return tp->sacked_out + tp->lost_out;