sctp: fix copying more bytes than expected in sctp_add_bind_addr
commit133800d1f0288b9ddfc0d0aded10d9efa82d5b8c
authorMarcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Tue, 8 Mar 2016 13:34:28 +0000 (8 10:34 -0300)
committerDavid S. Miller <davem@davemloft.net>
Tue, 8 Mar 2016 20:04:08 +0000 (8 15:04 -0500)
treefa156a2753d1c80c12910790cb12ddf6db7da30b
parente2857b8f11a289ed2b61d18d0665e05c1053c446
sctp: fix copying more bytes than expected in sctp_add_bind_addr

Dmitry reported that sctp_add_bind_addr may read more bytes than
expected in case the parameter is a IPv4 addr supplied by the user
through calls such as sctp_bindx_add(), because it always copies
sizeof(union sctp_addr) while the buffer may be just a struct
sockaddr_in, which is smaller.

This patch then fixes it by limiting the memcpy to the min between the
union size and a (new parameter) provided addr size. Where possible this
parameter still is the size of that union, except for reading from
user-provided buffers, which then it accounts for protocol type.

Reported-by: Dmitry Vyukov <dvyukov@google.com>
Tested-by: Dmitry Vyukov <dvyukov@google.com>
Signed-off-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
include/net/sctp/structs.h
net/sctp/bind_addr.c
net/sctp/protocol.c
net/sctp/sm_make_chunk.c
net/sctp/socket.c