AppArmor: Fix underflow in xindex calculation
authorJohn Johansen <john.johansen@canonical.com>
Wed, 22 Feb 2012 08:32:30 +0000 (00:32 -0800)
committerJohn Johansen <john.johansen@canonical.com>
Mon, 27 Feb 2012 19:38:21 +0000 (11:38 -0800)
If the xindex value stored in the accept tables is 0, the extraction of
that value will result in an underflow (0 - 4).

In properly compiled policy this should not happen for file rules but
it may be possible for other rule types in the future.

To exploit this underflow a user would have to be able to load a corrupt
policy, which requires CAP_MAC_ADMIN, overwrite system policy in kernel
memory or know of a compiler error resulting in the flaw being present
for loaded policy (no such flaw is known at this time).

Signed-off-by: John Johansen <john.johansen@canonical.com>
Acked-by: Kees Cook <kees@ubuntu.com>

security/apparmor/include/file.h

index ab8c6d8..f98fd47 100644 (file)
@@ -117,7 +117,7 @@ static inline u16 dfa_map_xindex(u16 mask)
                index |= AA_X_NAME;
        } else if (old_index == 3) {
                index |= AA_X_NAME | AA_X_CHILD;
-       } else {
+       } else if (old_index) {
                index |= AA_X_TABLE;
                index |= old_index - 4;
        }