SELinux: header generation may hit infinite loop
authorEric Paris <eparis@redhat.com>
Fri, 20 Nov 2009 16:00:12 +0000 (11:00 -0500)
committerJames Morris <jmorris@namei.org>
Sun, 22 Nov 2009 22:00:44 +0000 (09:00 +1100)
If a permission name is long enough the selinux class definition generation
tool will go into a infinite loop.  This is because it's macro max() is
fooled into thinking it is dealing with unsigned numbers.  This patch makes
sure the macro always uses signed number so 1 > -1.

Signed-off-by: Eric Paris <eparis@redhat.com>
Signed-off-by: James Morris <jmorris@namei.org>
scripts/selinux/genheaders/genheaders.c

index 771b86f..2462696 100644 (file)
@@ -13,7 +13,7 @@ struct security_class_mapping {
 #include "classmap.h"
 #include "initial_sid_to_string.h"
 
-#define max(x, y) ((x > y) ? x : y)
+#define max(x, y) (((int)(x) > (int)(y)) ? x : y)
 
 const char *progname;