]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
apparmor: Fix double free of ns_name in aa_replace_profiles()
authorJohn Johansen <john.johansen@canonical.com>
Wed, 10 Sep 2025 13:22:17 +0000 (06:22 -0700)
committerJohn Johansen <john.johansen@canonical.com>
Mon, 9 Mar 2026 23:05:43 +0000 (16:05 -0700)
if ns_name is NULL after
1071         error = aa_unpack(udata, &lh, &ns_name);

and if ent->ns_name contains an ns_name in
1089                 } else if (ent->ns_name) {

then ns_name is assigned the ent->ns_name
1095                         ns_name = ent->ns_name;

however ent->ns_name is freed at
1262                 aa_load_ent_free(ent);

and then again when freeing ns_name at
1270         kfree(ns_name);

Fix this by NULLing out ent->ns_name after it is transferred to ns_name

Fixes: 145a0ef21c8e9 ("apparmor: fix blob compression when ns is forced on a policy load
")
Reported-by: Qualys Security Advisory <qsa@qualys.com>
Tested-by: Salvatore Bonaccorso <carnil@debian.org>
Reviewed-by: Georgia Garcia <georgia.garcia@canonical.com>
Reviewed-by: Cengiz Can <cengiz.can@canonical.com>
Signed-off-by: John Johansen <john.johansen@canonical.com>
security/apparmor/policy.c

index 5668218525926d2262c8bd8ae291717023264925..4476515d97b1f94d9a915abbe418e2e5a59e8e7c 100644 (file)
@@ -1166,6 +1166,7 @@ ssize_t aa_replace_profiles(struct aa_ns *policy_ns, struct aa_label *label,
                                goto fail;
                        }
                        ns_name = ent->ns_name;
+                       ent->ns_name = NULL;
                } else
                        count++;
        }