diff options
author | Chanho Park <chanho61.park@samsung.com> | 2014-06-03 19:54:53 +0900 |
---|---|---|
committer | Marek Szyprowski <m.szyprowski@samsung.com> | 2015-04-13 12:45:02 +0200 |
commit | d5e7b001613c5d6ad25564584d04bea456c3619e (patch) | |
tree | d002b0195af1414966b05789d9306a046ab31a9b | |
parent | 48848ae35843895dd5d5dd9f8d2311e17fd22dde (diff) | |
download | linux-exynos-d5e7b001613c5d6ad25564584d04bea456c3619e.tar.gz linux-exynos-d5e7b001613c5d6ad25564584d04bea456c3619e.tar.bz2 linux-exynos-d5e7b001613c5d6ad25564584d04bea456c3619e.zip |
smack: add permissive mode for debugging purpose
This patch adds smack permissive mode.
Signed-off-by: Chanho Park <chanho61.park@samsung.com>
-rw-r--r-- | security/smack/Kconfig | 8 | ||||
-rw-r--r-- | security/smack/smack.h | 9 | ||||
-rw-r--r-- | security/smack/smack_access.c | 12 | ||||
-rw-r--r-- | security/smack/smack_lsm.c | 11 | ||||
-rw-r--r-- | security/smack/smackfs.c | 72 |
5 files changed, 112 insertions, 0 deletions
diff --git a/security/smack/Kconfig b/security/smack/Kconfig index 271adae81796..b1c221d694c6 100644 --- a/security/smack/Kconfig +++ b/security/smack/Kconfig @@ -40,3 +40,11 @@ config SECURITY_SMACK_NETFILTER This enables security marking of network packets using Smack labels. If you are unsure how to answer this question, answer N. + +config SECURITY_SMACK_PERMISSIVE_MODE + bool "Enable Permissive mode for debugging purpose" + depends on SECURITY_SMACK + help + This selects the permissive mode of smack for debug purpose. This + do not block any access of the smack policy and just warn the block + by log message. diff --git a/security/smack/smack.h b/security/smack/smack.h index 67ccb7b2b89b..4e9eca9559c7 100644 --- a/security/smack/smack.h +++ b/security/smack/smack.h @@ -340,6 +340,15 @@ static inline int smack_privileged(int cap) return 0; } +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE +/* + * permissive mode + */ +#define SMACK_PERMISSIVE_DENIED 0x0 +#define SMACK_PERMISSIVE_ALLOWED 0x1 +extern int permissive_mode; +#endif + /* * logging functions */ diff --git a/security/smack/smack_access.c b/security/smack/smack_access.c index 1158430f5bb9..b7af29b0e66b 100644 --- a/security/smack/smack_access.c +++ b/security/smack/smack_access.c @@ -55,6 +55,14 @@ LIST_HEAD(smack_known_list); static u32 smack_next_secid = 10; /* + * are we running in permissive mode? + * can be overwritten at run-time by /smack/permissive + */ +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE +int permissive_mode = SMACK_PERMISSIVE_ALLOWED; +#endif + +/* * what events do we log * can be overwritten at run-time by /smack/logging */ @@ -198,6 +206,10 @@ out_audit: smack_log(subject->smk_known, object->smk_known, request, rc, a); #endif +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE + if (permissive_mode == SMACK_PERMISSIVE_ALLOWED) + return 0; +#endif return rc; } diff --git a/security/smack/smack_lsm.c b/security/smack/smack_lsm.c index c934311812f1..17ed8413eb37 100644 --- a/security/smack/smack_lsm.c +++ b/security/smack/smack_lsm.c @@ -4407,6 +4407,17 @@ static __init int smack_init(void) return 0; } +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE +static int __init mode_setup(char *str) +{ + unsigned long mode; + if (!kstrtoul(str, 10, &mode)) + permissive_mode = mode ? 1 : 0; + return 1; +} +__setup("permissive=", mode_setup); +#endif + /* * Smack requires early initialization in order to label * all processes and objects when they are created. diff --git a/security/smack/smackfs.c b/security/smack/smackfs.c index bce4e8f1b267..916170cd5abf 100644 --- a/security/smack/smackfs.c +++ b/security/smack/smackfs.c @@ -54,6 +54,9 @@ enum smk_inos { SMK_CHANGE_RULE = 19, /* change or add rules (long labels) */ SMK_SYSLOG = 20, /* change syslog label) */ SMK_PTRACE = 21, /* set ptrace rule */ +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE + SMK_PERMISSIVE = 22, /* permissive mode */ +#endif }; /* @@ -706,6 +709,71 @@ static const struct file_operations smk_load_ops = { .release = seq_release, }; +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE +/** + * smk_read_permissive - read() for /smack/permissive + * @filp: file pointer, not actually used + * @buf: where to put the result + * @cn: maximum to send along + * @ppos: where to start + * + * Returns number of bytes read or error code, as appropriate + */ +static ssize_t smk_read_permissive(struct file *filp, char __user *buf, + size_t count, loff_t *ppos) +{ + char temp[32]; + ssize_t rc; + + if (*ppos != 0) + return 0; + + sprintf(temp, "%d\n", permissive_mode); + rc = simple_read_from_buffer(buf, count, ppos, temp, strlen(temp)); + return rc; +} + +/** + * smk_write_permissive - write() for /smack/permissive + * @file: file pointer, not actually used + * @buf: where to get the data from + * @count: bytes sent + * @ppos: where to start + * + * Returns number of bytes written or error code, as appropriate + */ +static ssize_t smk_write_permissive(struct file *file, const char __user *buf, + size_t count, loff_t *ppos) +{ + char temp[32]; + int i; + + if (!capable(CAP_MAC_ADMIN)) + return -EPERM; + + if (count >= sizeof(temp) || count == 0) + return -EINVAL; + + if (copy_from_user(temp, buf, count) != 0) + return -EFAULT; + + temp[count] = '\0'; + + if (sscanf(temp, "%d", &i) != 1) + return -EINVAL; + if (i < 0 || i > 1) + return -EINVAL; + permissive_mode = i; + return count; +} + +static const struct file_operations smk_permissive_ops = { + .read = smk_read_permissive, + .write = smk_write_permissive, + .llseek = default_llseek, +}; +#endif /* End of CONFIG_SECURITY_SMACK_PERMISSIVE_MODE */ + /** * smk_cipso_doi - initialize the CIPSO domain */ @@ -2384,6 +2452,10 @@ static int smk_fill_super(struct super_block *sb, void *data, int silent) "syslog", &smk_syslog_ops, S_IRUGO|S_IWUSR}, [SMK_PTRACE] = { "ptrace", &smk_ptrace_ops, S_IRUGO|S_IWUSR}, +#ifdef CONFIG_SECURITY_SMACK_PERMISSIVE_MODE + [SMK_PERMISSIVE] = { + "permissive", &smk_permissive_ops, S_IRUGO|S_IWUSR}, +#endif /* last one */ {""} }; |