Dave, just a trivial patch for fixing westwood functions prefixes and few comments. It applies against kernel 2.6.3-rc2. I didn't compile it but it's really to trivial! :) Regards. -- Angelo Dell'Aera 'buffer' Antifork Research, Inc. http://buffer.antifork.org --- linux-2.6.3-rc2/net/ipv4/tcp_input.c.old 2004-02-10 18:17:37.000000000 +0100 +++ linux-2.6.3-rc2/net/ipv4/tcp_input.c 2004-02-10 18:33:44.000000000 +0100 @@ -2051,17 +2051,20 @@ */ tp->frto_counter = (tp->frto_counter + 1) % 3; } + /* * TCP Westwood * Functions needed for estimating bandwidth. */ /* + * @tcp_westwood_init * This function initializes fields used in TCP Westwood. * We can't get no information about RTT at this time so * we are forced to set it to 0. */ -static void init_westwood(struct sock *sk) + +static void tcp_westwood_init(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); @@ -2077,32 +2080,34 @@ } /* - * @westwood_do_filter + * @tcp_westwood_do_filter * Low-pass filter. Implemented using constant coeffients. */ -static inline __u32 westwood_do_filter(__u32 a, __u32 b) + +static inline __u32 tcp_westwood_do_filter(__u32 a, __u32 b) { return (((7 * a) + b) >> 3); } -static void westwood_filter(struct sock *sk, __u32 delta) +static void tcp_westwood_filter(struct sock *sk, __u32 delta) { struct tcp_opt *tp = tcp_sk(sk); __u32 sample = tp->westwood.bk / delta; tp->westwood.bw_ns_est = - westwood_do_filter(tp->westwood.bw_ns_est, sample); + tcp_westwood_do_filter(tp->westwood.bw_ns_est, sample); tp->westwood.bw_est = - westwood_do_filter(tp->westwood.bw_est, + tcp_westwood_do_filter(tp->westwood.bw_est, tp->westwood.bw_ns_est); tp->westwood.bw_sample = sample; } -/* @westwood_update_rttmin +/* @tcp_westwood_update_rttmin * It is used to update RTTmin. In this case we MUST NOT use * WESTWOOD_RTT_MIN minimum bound since we could be on a LAN! */ -static inline __u32 westwood_update_rttmin(struct sock *sk) + +static inline __u32 tcp_westwood_update_rttmin(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); __u32 rttmin = tp->westwood.rtt_min; @@ -2117,11 +2122,11 @@ } /* - * @westwood_acked - * Evaluate increases for dk. It requires no lock since when it is - * called lock should already be held. Be careful about it! + * @tcp_westwood_acked + * Evaluate increases for dk. */ -static inline __u32 westwood_acked(struct sock *sk) + +static inline __u32 tcp_westwood_acked(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); @@ -2129,14 +2134,15 @@ } /* - * @westwood_new_window + * @tcp_westwood_new_window * It evaluates if we are receiving data inside the same RTT window as * when we started. * Return value: * It returns 0 if we are still evaluating samples in the same RTT * window, 1 if the sample has to be considered in the next window. */ -static int westwood_new_window(struct sock *sk) + +static int tcp_westwood_new_window(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); __u32 left_bound; @@ -2162,14 +2168,12 @@ } /* - * @westwood_update_window + * @tcp_westwood_update_window * It updates RTT evaluation window if it is the right moment to do - * it. If so it calls filter for evaluating bandwidth. Be careful - * about __westwood_update_window() since it is called without - * any form of lock. It should be used only for internal purposes. - * Call westwood_update_window() instead. + * it. If so it calls filter for evaluating bandwidth. */ -static void __westwood_update_window(struct sock *sk, __u32 now) + +static void __tcp_westwood_update_window(struct sock *sk, __u32 now) { struct tcp_opt *tp = tcp_sk(sk); __u32 delta = now - tp->westwood.rtt_win_sx; @@ -2178,30 +2182,31 @@ return; if (tp->westwood.rtt) - westwood_filter(sk, delta); + tcp_westwood_filter(sk, delta); tp->westwood.bk = 0; tp->westwood.rtt_win_sx = tcp_time_stamp; } -static void westwood_update_window(struct sock *sk, __u32 now) +static void tcp_westwood_update_window(struct sock *sk, __u32 now) { - if (westwood_new_window(sk)) - __westwood_update_window(sk, now); + if (tcp_westwood_new_window(sk)) + __tcp_westwood_update_window(sk, now); } /* - * @__westwood_fast_bw + * @__tcp_westwood_fast_bw * It is called when we are in fast path. In particular it is called when * header prediction is successfull. In such case infact update is * straight forward and doesn't need any particular care. */ + void __tcp_westwood_fast_bw(struct sock *sk, struct sk_buff *skb) { struct tcp_opt *tp = tcp_sk(sk); - westwood_update_window(sk, tcp_time_stamp); + tcp_westwood_update_window(sk, tcp_time_stamp); tp->westwood.bk += westwood_acked(sk); tp->westwood.snd_una = tp->snd_una; @@ -2214,7 +2219,7 @@ * It updates accounted and cumul_ack when receiving a dupack. */ -static void westwood_dupack_update(struct sock *sk) +static void tcp_westwood_dupack_update(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); @@ -2222,46 +2227,46 @@ tp->westwood.cumul_ack = tp->mss_cache; } -static inline int westwood_may_change_cumul(struct tcp_opt *tp) +static inline int tcp_westwood_may_change_cumul(struct tcp_opt *tp) { return ((tp->westwood.cumul_ack) > tp->mss_cache); } -static inline void westwood_partial_update(struct tcp_opt *tp) +static inline void tcp_westwood_partial_update(struct tcp_opt *tp) { tp->westwood.accounted -= tp->westwood.cumul_ack; tp->westwood.cumul_ack = tp->mss_cache; } -static inline void westwood_complete_update(struct tcp_opt *tp) +static inline void tcp_westwood_complete_update(struct tcp_opt *tp) { tp->westwood.cumul_ack -= tp->westwood.accounted; tp->westwood.accounted = 0; } /* - * @westwood_acked_count + * @tcp_westwood_acked_count * This function evaluates cumul_ack for evaluating dk in case of * delayed or partial acks. */ -static __u32 westwood_acked_count(struct sock *sk) +static __u32 tcp_westwood_acked_count(struct sock *sk) { struct tcp_opt *tp = tcp_sk(sk); - tp->westwood.cumul_ack = westwood_acked(sk); + tp->westwood.cumul_ack = tcp_westwood_acked(sk); /* If cumul_ack is 0 this is a dupack since it's not moving * tp->snd_una. */ if (!(tp->westwood.cumul_ack)) - westwood_dupack_update(sk); + tcp_westwood_dupack_update(sk); - if (westwood_may_change_cumul(tp)) { + if (tcp_westwood_may_change_cumul(tp)) { /* Partial or delayed ack */ if ((tp->westwood.accounted) >= (tp->westwood.cumul_ack)) - westwood_partial_update(tp); + tcp_westwood_partial_update(tp); else - westwood_complete_update(tp); + tcp_westwood_complete_update(tp); } tp->westwood.snd_una = tp->snd_una; @@ -2271,19 +2276,19 @@ /* - * @__westwood_slow_bw + * @__tcp_westwood_slow_bw * It is called when something is going wrong..even if there could - * be no problems! Infact a simple delayed packet may trigger a + * be no problems! In fact a simple delayed packet may trigger a * dupack. But we need to be careful in such case. */ void __tcp_westwood_slow_bw(struct sock *sk, struct sk_buff *skb) { struct tcp_opt *tp = tcp_sk(sk); - westwood_update_window(sk, tcp_time_stamp); + tcp_westwood_update_window(sk, tcp_time_stamp); - tp->westwood.bk += westwood_acked_count(sk); - tp->westwood.rtt_min = westwood_update_rttmin(sk); + tp->westwood.bk += tcp_westwood_acked_count(sk); + tp->westwood.rtt_min = tcp_westwood_update_rttmin(sk); } /* This routine deals with incoming acks, but not outgoing ones. */ @@ -4124,7 +4129,7 @@ if(tp->af_specific->conn_request(sk, skb) < 0) return 1; - init_westwood(sk); + tcp_westwood_init(sk); /* Now we have several options: In theory there is * nothing else in the frame. KA9Q has an option to @@ -4147,7 +4152,7 @@ goto discard; case TCP_SYN_SENT: - init_westwood(sk); + tcp_westwood_init(sk); queued = tcp_rcv_synsent_state_process(sk, skb, th, len); if (queued >= 0) - : send the line "unsubscribe linux-net" in the body of a message to majordomo@vger.kernel.org More majordomo info at http://vger.kernel.org/majordomo-info.html