sctp: Fix out-of-bounds warning in sctp_process_asconf_param()
authorGustavo A. R. Silva <gustavoars@kernel.org>
Fri, 16 Apr 2021 19:12:36 +0000 (14:12 -0500)
committerGreg Kroah-Hartman <gregkh@linuxfoundation.org>
Sat, 22 May 2021 08:40:30 +0000 (10:40 +0200)
[ Upstream commit e5272ad4aab347dde5610c0aedb786219e3ff793 ]

Fix the following out-of-bounds warning:

net/sctp/sm_make_chunk.c:3150:4: warning: 'memcpy' offset [17, 28] from the object at 'addr' is out of the bounds of referenced subobject 'v4' with type 'struct sockaddr_in' at offset 0 [-Warray-bounds]

This helps with the ongoing efforts to globally enable -Warray-bounds
and get us closer to being able to tighten the FORTIFY_SOURCE routines
on memcpy().

Link: https://github.com/KSPP/linux/issues/109
Reported-by: kernel test robot <lkp@intel.com>
Signed-off-by: Gustavo A. R. Silva <gustavoars@kernel.org>
Reviewed-by: Kees Cook <keescook@chromium.org>
Acked-by: Marcelo Ricardo Leitner <marcelo.leitner@gmail.com>
Signed-off-by: David S. Miller <davem@davemloft.net>
Signed-off-by: Sasha Levin <sashal@kernel.org>
net/sctp/sm_make_chunk.c

index acb0c2631c7928aa43e8c64a60d7e5e834ddb360..0c5aff3bb53910a8f3e4ab7f754d671055ed17d1 100644 (file)
@@ -3129,7 +3129,7 @@ static __be16 sctp_process_asconf_param(struct sctp_association *asoc,
                 * primary.
                 */
                if (af->is_any(&addr))
-                       memcpy(&addr.v4, sctp_source(asconf), sizeof(addr));
+                       memcpy(&addr, sctp_source(asconf), sizeof(addr));
 
                peer = sctp_assoc_lookup_paddr(asoc, &addr);
                if (!peer)