diff options
author | Eric Paris <eparis@redhat.com> | 2012-04-04 13:46:46 -0400 |
---|---|---|
committer | Eric Paris <eparis@redhat.com> | 2012-04-09 12:22:57 -0400 |
commit | 92ae9e82d9a2c4b9b388d6a9e7a4b2ccb0b4452f (patch) | |
tree | c9fb517b25ff64f1a07abf62fa90512a48949fc4 /security/selinux | |
parent | bb7081ab93582fd2557160549854200a5fc7b42a (diff) |
SELinux: remove needless sel_div function
I'm not really sure what the idea behind the sel_div function is, but it's
useless. Since a and b are both unsigned, it's impossible for a % b < 0.
That means that part of the function never does anything. Thus it's just a
normal /. Just do that instead. I don't even understand what that operation
was supposed to mean in the signed case however....
If it was signed:
sel_div(-2, 4) == ((-2 / 4) - ((-2 % 4) < 0))
((0) - ((-2) < 0))
((0) - (1))
(-1)
What actually happens:
sel_div(-2, 4) == ((18446744073709551614 / 4) - ((18446744073709551614 % 4) < 0))
((4611686018427387903) - ((2 < 0))
(4611686018427387903 - 0)
((unsigned int)4611686018427387903)
(4294967295)
Neither makes a whole ton of sense to me. So I'm getting rid of the
function entirely.
Signed-off-by: Eric Paris <eparis@redhat.com>
Diffstat (limited to 'security/selinux')
-rw-r--r-- | security/selinux/selinuxfs.c | 7 |
1 files changed, 1 insertions, 6 deletions
diff --git a/security/selinux/selinuxfs.c b/security/selinux/selinuxfs.c index f4b5a0baaec..640feaa06c0 100644 --- a/security/selinux/selinuxfs.c +++ b/security/selinux/selinuxfs.c | |||
@@ -1533,11 +1533,6 @@ static int sel_make_initcon_files(struct dentry *dir) | |||
1533 | return 0; | 1533 | return 0; |
1534 | } | 1534 | } |
1535 | 1535 | ||
1536 | static inline unsigned int sel_div(unsigned long a, unsigned long b) | ||
1537 | { | ||
1538 | return a / b - (a % b < 0); | ||
1539 | } | ||
1540 | |||
1541 | static inline unsigned long sel_class_to_ino(u16 class) | 1536 | static inline unsigned long sel_class_to_ino(u16 class) |
1542 | { | 1537 | { |
1543 | return (class * (SEL_VEC_MAX + 1)) | SEL_CLASS_INO_OFFSET; | 1538 | return (class * (SEL_VEC_MAX + 1)) | SEL_CLASS_INO_OFFSET; |
@@ -1545,7 +1540,7 @@ static inline unsigned long sel_class_to_ino(u16 class) | |||
1545 | 1540 | ||
1546 | static inline u16 sel_ino_to_class(unsigned long ino) | 1541 | static inline u16 sel_ino_to_class(unsigned long ino) |
1547 | { | 1542 | { |
1548 | return sel_div(ino & SEL_INO_MASK, SEL_VEC_MAX + 1); | 1543 | return (ino & SEL_INO_MASK) / (SEL_VEC_MAX + 1); |
1549 | } | 1544 | } |
1550 | 1545 | ||
1551 | static inline unsigned long sel_perm_to_ino(u16 class, u32 perm) | 1546 | static inline unsigned long sel_perm_to_ino(u16 class, u32 perm) |