security: Add proper checks for Android specific capability checks
authorTushar Behera <tushar.behera@linaro.org>
Mon, 26 Mar 2012 11:24:15 +0000 (16:54 +0530)
committerArve Hjønnevåg <arve@android.com>
Mon, 1 Jul 2013 20:40:45 +0000 (13:40 -0700)
Commit b641072 ("security: Add AID_NET_RAW and AID_NET_ADMIN capability
check in cap_capable().") introduces additional checks for AID_NET_xxx
macros. Since the header file including those macros are conditionally
included, the checks should also be conditionally executed.

Change-Id: Iaec5208d5b95a46b1ac3f2db8449c661e803fa5b
Signed-off-by: Tushar Behera <tushar.behera@linaro.org>
Signed-off-by: Andrey Konovalov <andrey.konovalov@linaro.org>
security/commoncap.c

index 3e81aa978b597d9103aa21cc06d3095e70764ac6..5870fdc224b436d954f240a546b5398bbc3ce028 100644 (file)
@@ -82,10 +82,12 @@ int cap_capable(const struct cred *cred, struct user_namespace *targ_ns,
 {
        struct user_namespace *ns = targ_ns;
 
+#ifdef CONFIG_ANDROID_PARANOID_NETWORK
        if (cap == CAP_NET_RAW && in_egroup_p(AID_NET_RAW))
                return 0;
        if (cap == CAP_NET_ADMIN && in_egroup_p(AID_NET_ADMIN))
                return 0;
+#endif
 
        /* See if cred has the capability in the target user namespace
         * by examining the target user namespace and all of the target