diff options
author | John Johansen <john.johansen@canonical.com> | 2020-10-06 14:43:16 -0700 |
---|---|---|
committer | John Johansen <john.johansen@canonical.com> | 2022-07-13 17:18:29 -0700 |
commit | 524d8e14258a3c31bcaf915db5762e41249eb924 (patch) | |
tree | 3d071c02f5bf3ecfd3af63e3d44cd5b8046a294d /security/apparmor/lsm.c | |
parent | df4390934da48e0462d1e77fba3e15f080e2c2a0 (diff) | |
download | linux-524d8e14258a3c31bcaf915db5762e41249eb924.tar.gz linux-524d8e14258a3c31bcaf915db5762e41249eb924.tar.bz2 linux-524d8e14258a3c31bcaf915db5762e41249eb924.zip |
apparmor: disable showing the mode as part of a secid to secctx
Displaying the mode as part of the seectx takes up unnecessary memory,
makes it so we can't use refcounted secctx so we need to alloc/free on
every conversion from secid to secctx and introduces a space that
could be potentially mishandled by tooling.
Eg. In an audit record we get
subj_type=firefix (enforce)
Having the mode reported is not necessary, and might even be confusing
eg. when writing an audit rule to match the above record field you
would use
-F subj_type=firefox
ie. the mode is not included. AppArmor provides ways to find the mode
without reporting as part of the secctx. So disable this by default
before its use is wide spread and we can't. For now we add a sysctl
to control the behavior as we can't guarantee no one is using this.
Acked-by: Andrea Righi <andrea.righi@canonical.com>
Signed-off-by: John Johansen <john.johansen@canonical.com>
Diffstat (limited to 'security/apparmor/lsm.c')
-rw-r--r-- | security/apparmor/lsm.c | 8 |
1 files changed, 8 insertions, 0 deletions
diff --git a/security/apparmor/lsm.c b/security/apparmor/lsm.c index b1a0f2172a2e..090a20805664 100644 --- a/security/apparmor/lsm.c +++ b/security/apparmor/lsm.c @@ -1764,6 +1764,14 @@ static struct ctl_table apparmor_sysctl_table[] = { .mode = 0600, .proc_handler = apparmor_dointvec, }, + { + .procname = "apparmor_display_secid_mode", + .data = &apparmor_display_secid_mode, + .maxlen = sizeof(int), + .mode = 0600, + .proc_handler = apparmor_dointvec, + }, + { } }; |