]> git.ipfire.org Git - thirdparty/linux.git/commitdiff
xfrm: clear trailing padding in build_polexpire()
authorYasuaki Torimaru <yasuakitorimaru@gmail.com>
Thu, 26 Mar 2026 05:58:00 +0000 (14:58 +0900)
committerSteffen Klassert <steffen.klassert@secunet.com>
Mon, 30 Mar 2026 05:47:32 +0000 (07:47 +0200)
build_expire() clears the trailing padding bytes of struct
xfrm_user_expire after setting the hard field via memset_after(),
but the analogous function build_polexpire() does not do this for
struct xfrm_user_polexpire.

The padding bytes after the __u8 hard field are left
uninitialized from the heap allocation, and are then sent to
userspace via netlink multicast to XFRMNLGRP_EXPIRE listeners,
leaking kernel heap memory contents.

Add the missing memset_after() call, matching build_expire().

Fixes: 1da177e4c3f4 ("Linux-2.6.12-rc2")
Cc: stable@vger.kernel.org
Signed-off-by: Yasuaki Torimaru <yasuakitorimaru@gmail.com>
Reviewed-by: Simon Horman <horms@kernel.org>
Reviewed-by: Breno Leitao <leitao@debian.org>
Signed-off-by: Steffen Klassert <steffen.klassert@secunet.com>
net/xfrm/xfrm_user.c

index 1656b487f8334ee5a72488d52926756b29e76ae8..5d59c11fc01efaefbd3fef6a1df37486d11a83ed 100644 (file)
@@ -3960,6 +3960,8 @@ static int build_polexpire(struct sk_buff *skb, struct xfrm_policy *xp,
                return err;
        }
        upe->hard = !!hard;
+       /* clear the padding bytes */
+       memset_after(upe, 0, hard);
 
        nlmsg_end(skb, nlh);
        return 0;