]> git.baikalelectronics.ru Git - kernel.git/commit
net: ipv4: tcp_probe: cleanup snprintf() use
authorVasiliy Kulikov <segoon@openwall.com>
Sun, 14 Nov 2010 07:06:08 +0000 (07:06 +0000)
committerDavid S. Miller <davem@davemloft.net>
Wed, 17 Nov 2010 20:27:46 +0000 (12:27 -0800)
commit52cf4a1d7cd443e677455a2ee4cf1c46135b0328
tree87e070e4d51fe128214c838f534afe1c28178f19
parent9f4de71d9e186733dea7c9f9500148bab8982edb
net: ipv4: tcp_probe: cleanup snprintf() use

snprintf() returns number of bytes that were copied if there is no overflow.
This code uses return value as number of copied bytes.  Theoretically format
string '%lu.%09lu %pI4:%u %pI4:%u %d %#x %#x %u %u %u %u\n' may be expanded
up to 163 bytes.  In reality tv.tv_sec is just few bytes instead of 20, 2 ports
are just 5 bytes each instead of 10, length is 5 bytes instead of 10.  The rest
is an unstrusted input.  Theoretically if tv_sec is big then copy_to_user() would
overflow tbuf.

tbuf was increased to fit in 163 bytes.  snprintf() is used to follow return
value semantic.

Signed-off-by: Vasiliy Kulikov <segoon@openwall.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
net/ipv4/tcp_probe.c