aboutsummaryrefslogtreecommitdiff
path: root/kernel/user.c
diff options
context:
space:
mode:
authorSam Jansen <sjansen@google.com>2007-11-19 23:28:21 -0800
committerDavid S. Miller <davem@davemloft.net>2007-11-19 23:28:21 -0800
commit5487796f0c9475586277a0a7a91211ce5746fa6a (patch)
tree80ea156ec6f2b549706b57b267e1dcf327e0dde2 /kernel/user.c
parent6e42141009ff18297fe19d19296738b742f861db (diff)
[TCP]: Problem bug with sysctl_tcp_congestion_control function
From: "Sam Jansen" <sjansen@google.com> sysctl_tcp_congestion_control seems to have a bug that prevents it from actually calling the tcp_set_default_congestion_control function. This is not so apparent because it does not return an error and generally the /proc interface is used to configure the default TCP congestion control algorithm. This is present in 2.6.18 onwards and probably earlier, though I have not inspected 2.6.15--2.6.17. sysctl_tcp_congestion_control calls sysctl_string and expects a successful return code of 0. In such a case it actually sets the congestion control algorithm with tcp_set_default_congestion_control. Otherwise, it returns the value returned by sysctl_string. This was correct in 2.6.14, as sysctl_string returned 0 on success. However, sysctl_string was updated to return 1 on success around about 2.6.15 and sysctl_tcp_congestion_control was not updated. Even though sysctl_tcp_congestion_control returns 1, do_sysctl_strategy converts this return code to '0', so the caller never notices the error. Signed-off-by: David S. Miller <davem@davemloft.net>
Diffstat (limited to 'kernel/user.c')
0 files changed, 0 insertions, 0 deletions