diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-11 00:51:23 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-01-11 00:51:23 -0500 |
commit | e7691a1ce341c80ed9504244a36b31c025217391 (patch) | |
tree | e9941bb350f64a726130e299c411821da6f41a53 /security/selinux | |
parent | 5cd9599bba428762025db6027764f1c59d0b1e1b (diff) | |
parent | 8fcc99549522fc7a0bbaeb5755855ab0d9a59ce8 (diff) |
Merge branch 'for-linus' of git://selinuxproject.org/~jmorris/linux-security
* 'for-linus' of git://selinuxproject.org/~jmorris/linux-security: (32 commits)
ima: fix invalid memory reference
ima: free duplicate measurement memory
security: update security_file_mmap() docs
selinux: Casting (void *) value returned by kmalloc is useless
apparmor: fix module parameter handling
Security: tomoyo: add .gitignore file
tomoyo: add missing rcu_dereference()
apparmor: add missing rcu_dereference()
evm: prevent racing during tfm allocation
evm: key must be set once during initialization
mpi/mpi-mpow: NULL dereference on allocation failure
digsig: build dependency fix
KEYS: Give key types their own lockdep class for key->sem
TPM: fix transmit_cmd error logic
TPM: NSC and TIS drivers X86 dependency fix
TPM: Export wait_for_stat for other vendor specific drivers
TPM: Use vendor specific function for status probe
tpm_tis: add delay after aborting command
tpm_tis: Check return code from getting timeouts/durations
tpm: Introduce function to poll for result of self test
...
Fix up trivial conflict in lib/Makefile due to addition of CONFIG_MPI
and SIGSIG next to CONFIG_DQL addition.
Diffstat (limited to 'security/selinux')
-rw-r--r-- | security/selinux/selinuxfs.c | 14 | ||||
-rw-r--r-- | security/selinux/ss/conditional.c | 2 |
2 files changed, 5 insertions, 11 deletions
diff --git a/security/selinux/selinuxfs.c b/security/selinux/selinuxfs.c index f46658722c78..48a7d0014b4f 100644 --- a/security/selinux/selinuxfs.c +++ b/security/selinux/selinuxfs.c | |||
@@ -749,14 +749,6 @@ out: | |||
749 | return length; | 749 | return length; |
750 | } | 750 | } |
751 | 751 | ||
752 | static inline int hexcode_to_int(int code) { | ||
753 | if (code == '\0' || !isxdigit(code)) | ||
754 | return -1; | ||
755 | if (isdigit(code)) | ||
756 | return code - '0'; | ||
757 | return tolower(code) - 'a' + 10; | ||
758 | } | ||
759 | |||
760 | static ssize_t sel_write_create(struct file *file, char *buf, size_t size) | 752 | static ssize_t sel_write_create(struct file *file, char *buf, size_t size) |
761 | { | 753 | { |
762 | char *scon = NULL, *tcon = NULL; | 754 | char *scon = NULL, *tcon = NULL; |
@@ -808,9 +800,11 @@ static ssize_t sel_write_create(struct file *file, char *buf, size_t size) | |||
808 | if (c1 == '+') | 800 | if (c1 == '+') |
809 | c1 = ' '; | 801 | c1 = ' '; |
810 | else if (c1 == '%') { | 802 | else if (c1 == '%') { |
811 | if ((c1 = hexcode_to_int(*r++)) < 0) | 803 | c1 = hex_to_bin(*r++); |
804 | if (c1 < 0) | ||
812 | goto out; | 805 | goto out; |
813 | if ((c2 = hexcode_to_int(*r++)) < 0) | 806 | c2 = hex_to_bin(*r++); |
807 | if (c2 < 0) | ||
814 | goto out; | 808 | goto out; |
815 | c1 = (c1 << 4) | c2; | 809 | c1 = (c1 << 4) | c2; |
816 | } | 810 | } |
diff --git a/security/selinux/ss/conditional.c b/security/selinux/ss/conditional.c index 2ec904177fe0..377d148e7157 100644 --- a/security/selinux/ss/conditional.c +++ b/security/selinux/ss/conditional.c | |||
@@ -175,7 +175,7 @@ void cond_policydb_destroy(struct policydb *p) | |||
175 | int cond_init_bool_indexes(struct policydb *p) | 175 | int cond_init_bool_indexes(struct policydb *p) |
176 | { | 176 | { |
177 | kfree(p->bool_val_to_struct); | 177 | kfree(p->bool_val_to_struct); |
178 | p->bool_val_to_struct = (struct cond_bool_datum **) | 178 | p->bool_val_to_struct = |
179 | kmalloc(p->p_bools.nprim * sizeof(struct cond_bool_datum *), GFP_KERNEL); | 179 | kmalloc(p->p_bools.nprim * sizeof(struct cond_bool_datum *), GFP_KERNEL); |
180 | if (!p->bool_val_to_struct) | 180 | if (!p->bool_val_to_struct) |
181 | return -ENOMEM; | 181 | return -ENOMEM; |