521f1cf1db
Two different problems are fixed here : 1) inet_sk_diag_fill() might be called without socket lock held. icsk->icsk_ca_ops can change under us and module be unloaded. -> Access to freed memory. Fix this using rcu_read_lock() to prevent module unload. 2) Some TCP Congestion Control modules provide information but again this is not safe against icsk->icsk_ca_ops change and nla_put() errors were ignored. Some sockets could not get the additional info if skb was almost full. Fix this by returning a status from get_info() handlers and using rcu protection as well. Signed-off-by: Eric Dumazet <edumazet@google.com> Acked-by: Daniel Borkmann <daniel@iogearbox.net> Signed-off-by: David S. Miller <davem@davemloft.net>
25 lines
866 B
C
25 lines
866 B
C
/*
|
|
* TCP Vegas congestion control interface
|
|
*/
|
|
#ifndef __TCP_VEGAS_H
|
|
#define __TCP_VEGAS_H 1
|
|
|
|
/* Vegas variables */
|
|
struct vegas {
|
|
u32 beg_snd_nxt; /* right edge during last RTT */
|
|
u32 beg_snd_una; /* left edge during last RTT */
|
|
u32 beg_snd_cwnd; /* saves the size of the cwnd */
|
|
u8 doing_vegas_now;/* if true, do vegas for this RTT */
|
|
u16 cntRTT; /* # of RTTs measured within last RTT */
|
|
u32 minRTT; /* min of RTTs measured within last RTT (in usec) */
|
|
u32 baseRTT; /* the min of all Vegas RTT measurements seen (in usec) */
|
|
};
|
|
|
|
void tcp_vegas_init(struct sock *sk);
|
|
void tcp_vegas_state(struct sock *sk, u8 ca_state);
|
|
void tcp_vegas_pkts_acked(struct sock *sk, u32 cnt, s32 rtt_us);
|
|
void tcp_vegas_cwnd_event(struct sock *sk, enum tcp_ca_event event);
|
|
int tcp_vegas_get_info(struct sock *sk, u32 ext, struct sk_buff *skb);
|
|
|
|
#endif /* __TCP_VEGAS_H */
|