diff options
Diffstat (limited to 'security/selinux')
-rw-r--r-- | security/selinux/ss/conditional.c | 2 | ||||
-rw-r--r-- | security/selinux/ss/policydb.c | 3 |
2 files changed, 5 insertions, 0 deletions
diff --git a/security/selinux/ss/conditional.c b/security/selinux/ss/conditional.c index 456e1a9bcfde..34afeadd9e73 100644 --- a/security/selinux/ss/conditional.c +++ b/security/selinux/ss/conditional.c | |||
@@ -242,6 +242,8 @@ int cond_read_bool(struct policydb *p, struct hashtab *h, void *fp) | |||
242 | goto err; | 242 | goto err; |
243 | 243 | ||
244 | len = le32_to_cpu(buf[2]); | 244 | len = le32_to_cpu(buf[2]); |
245 | if (((len == 0) || (len == (u32)-1))) | ||
246 | goto err; | ||
245 | 247 | ||
246 | rc = -ENOMEM; | 248 | rc = -ENOMEM; |
247 | key = kmalloc(len + 1, GFP_KERNEL); | 249 | key = kmalloc(len + 1, GFP_KERNEL); |
diff --git a/security/selinux/ss/policydb.c b/security/selinux/ss/policydb.c index 4b243855ed7b..8c661f0451ec 100644 --- a/security/selinux/ss/policydb.c +++ b/security/selinux/ss/policydb.c | |||
@@ -1094,6 +1094,9 @@ static int str_read(char **strp, gfp_t flags, void *fp, u32 len) | |||
1094 | int rc; | 1094 | int rc; |
1095 | char *str; | 1095 | char *str; |
1096 | 1096 | ||
1097 | if ((len == 0) || (len == (u32)-1)) | ||
1098 | return -EINVAL; | ||
1099 | |||
1097 | str = kmalloc(len + 1, flags); | 1100 | str = kmalloc(len + 1, flags); |
1098 | if (!str) | 1101 | if (!str) |
1099 | return -ENOMEM; | 1102 | return -ENOMEM; |