Commit 3bf3d728 authored by John Johansen's avatar John Johansen

apparmor: verify loaded permission bits masks don't overlap

Add an additional verification that loaded permission sets don't
overlap in ways that are not intended. This will help ensure that
permission accumulation can't result in an invalid permission set.
Signed-off-by: default avatarJohn Johansen <john.johansen@canonical.com>
parent 3dfd16ab
...@@ -1150,11 +1150,37 @@ static bool verify_dfa_xindex(struct aa_dfa *dfa, int table_size) ...@@ -1150,11 +1150,37 @@ static bool verify_dfa_xindex(struct aa_dfa *dfa, int table_size)
return true; return true;
} }
static bool verify_perm_indexes(struct aa_policydb *pdb) static bool verify_perm(struct aa_perms *perm)
{
/* TODO: allow option to just force the perms into a valid state */
if (perm->allow & perm->deny)
return false;
if (perm->subtree & ~perm->allow)
return false;
if (perm->cond & (perm->allow | perm->deny))
return false;
if (perm->kill & perm->allow)
return false;
if (perm->complain & (perm->allow | perm->deny))
return false;
if (perm->prompt & (perm->allow | perm->deny))
return false;
if (perm->complain & perm->prompt)
return false;
if (perm->hide & perm->allow)
return false;
return true;
}
static bool verify_perms(struct aa_policydb *pdb)
{ {
int i; int i;
for (i = 0; i < pdb->size; i++) { for (i = 0; i < pdb->size; i++) {
if (!verify_perm(&pdb->perms[i]))
return false;
/* verify indexes into str table */
if (pdb->perms[i].xindex >= pdb->trans.size) if (pdb->perms[i].xindex >= pdb->trans.size)
return false; return false;
if (pdb->perms[i].tag >= pdb->trans.size) if (pdb->perms[i].tag >= pdb->trans.size)
...@@ -1187,17 +1213,17 @@ static int verify_profile(struct aa_profile *profile) ...@@ -1187,17 +1213,17 @@ static int verify_profile(struct aa_profile *profile)
return -EPROTO; return -EPROTO;
} }
if (!verify_perm_indexes(&profile->file)) { if (!verify_perms(&profile->file)) {
audit_iface(profile, NULL, NULL, audit_iface(profile, NULL, NULL,
"Unpack: Invalid perm index", NULL, -EPROTO); "Unpack: Invalid perm index", NULL, -EPROTO);
return -EPROTO; return -EPROTO;
} }
if (!verify_perm_indexes(&profile->policy)) { if (!verify_perms(&profile->policy)) {
audit_iface(profile, NULL, NULL, audit_iface(profile, NULL, NULL,
"Unpack: Invalid perm index", NULL, -EPROTO); "Unpack: Invalid perm index", NULL, -EPROTO);
return -EPROTO; return -EPROTO;
} }
if (!verify_perm_indexes(&profile->xmatch)) { if (!verify_perms(&profile->xmatch)) {
audit_iface(profile, NULL, NULL, audit_iface(profile, NULL, NULL,
"Unpack: Invalid perm index", NULL, -EPROTO); "Unpack: Invalid perm index", NULL, -EPROTO);
return -EPROTO; return -EPROTO;
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment