Blame SOURCES/shadow-4.1.5-uflg.patch

fa2969
diff -up shadow-4.1.5/libmisc/find_new_gid.c.uflg shadow-4.1.5/libmisc/find_new_gid.c
fa2969
--- shadow-4.1.5/libmisc/find_new_gid.c.uflg	2011-07-30 01:10:27.000000000 +0200
fa2969
+++ shadow-4.1.5/libmisc/find_new_gid.c	2012-03-19 12:51:46.090554116 +0100
fa2969
@@ -68,7 +68,7 @@ int find_new_gid (bool sys_group,
fa2969
 			return -1;
fa2969
 		}
fa2969
 	} else {
fa2969
-		gid_min = (gid_t) getdef_ulong ("SYS_GID_MIN", 101UL);
fa2969
+		gid_min = (gid_t) 1;
fa2969
 		gid_max = (gid_t) getdef_ulong ("GID_MIN", 1000UL) - 1;
fa2969
 		gid_max = (gid_t) getdef_ulong ("SYS_GID_MAX", (unsigned long) gid_max);
fa2969
 		if (gid_max < gid_min) {
fa2969
@@ -100,6 +100,10 @@ int find_new_gid (bool sys_group,
fa2969
 		return 0;
fa2969
 	}
fa2969
 
fa2969
+        /* if we did not find free preffered system gid, we start to look for
fa2969
+         * one in the range assigned to dynamic system IDs */
fa2969
+        if (sys_group)
fa2969
+                gid_min = (gid_t) getdef_ulong ("SYS_GID_MIN", 101UL);
fa2969
 
fa2969
 	/*
fa2969
 	 * Search the entire group file,