Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit 12e17659 authored by Eric Dumazet's avatar Eric Dumazet Committed by Sasha Levin
Browse files

tcp: tcp_get_info() should fetch socket fields once



[ Upstream commit fad9dfefea6405039491e7e4fc21fb6e59e7d26c ]

tcp_get_info() can be called without holding socket lock,
so any socket fields can change under us.

Use READ_ONCE() to fetch sk_pacing_rate and sk_max_pacing_rate

Fixes: 977cb0ec ("tcp: add pacing_rate information into tcp_info")
Signed-off-by: default avatarEric Dumazet <edumazet@google.com>
Signed-off-by: default avatarDavid S. Miller <davem@davemloft.net>
Signed-off-by: default avatarSasha Levin <sasha.levin@oracle.com>
parent c2c3964c
Loading
Loading
Loading
Loading
+6 −4
Original line number Diff line number Diff line
@@ -2639,6 +2639,7 @@ void tcp_get_info(const struct sock *sk, struct tcp_info *info)
	const struct tcp_sock *tp = tcp_sk(sk);
	const struct inet_connection_sock *icsk = inet_csk(sk);
	u32 now = tcp_time_stamp;
	u32 rate;

	memset(info, 0, sizeof(*info));

@@ -2699,10 +2700,11 @@ void tcp_get_info(const struct sock *sk, struct tcp_info *info)

	info->tcpi_total_retrans = tp->total_retrans;

	info->tcpi_pacing_rate = sk->sk_pacing_rate != ~0U ?
					sk->sk_pacing_rate : ~0ULL;
	info->tcpi_max_pacing_rate = sk->sk_max_pacing_rate != ~0U ?
					sk->sk_max_pacing_rate : ~0ULL;
	rate = READ_ONCE(sk->sk_pacing_rate);
	info->tcpi_pacing_rate = rate != ~0U ? rate : ~0ULL;

	rate = READ_ONCE(sk->sk_max_pacing_rate);
	info->tcpi_max_pacing_rate = rate != ~0U ? rate : ~0ULL;
}
EXPORT_SYMBOL_GPL(tcp_get_info);