Blame SOURCES/libcgroup-0.37-chmod.patch

308897
diff -up libcgroup-0.41/src/api.c.chmod libcgroup-0.41/src/api.c
308897
--- libcgroup-0.41/src/api.c.chmod	2014-01-13 15:05:56.000000000 +0100
308897
+++ libcgroup-0.41/src/api.c	2014-01-13 20:41:55.255577622 +0100
308897
@@ -153,6 +153,10 @@ static int cg_chown_file(FTS *fts, FTSEN
308897
 	return ret;
308897
 }
308897
 
308897
+int cg_chmod_file(FTS *fts, FTSENT *ent, mode_t dir_mode,
308897
+	int dirm_change, mode_t file_mode, int filem_change,
308897
+	int owner_is_umask);
308897
+
308897
 /*
308897
  * TODO: Need to decide a better place to put this function.
308897
  */
308897
@@ -160,6 +164,8 @@ static int cg_chown_recursive(char **pat
308897
 {
308897
 	int ret = 0;
308897
 	FTS *fts;
308897
+	/* mode 664 */
308897
+	mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH;
308897
 
308897
 	cgroup_dbg("chown: path is %s\n", *path);
308897
 	fts = fts_open(path, FTS_PHYSICAL | FTS_NOCHDIR |
308897
@@ -177,6 +183,7 @@ static int cg_chown_recursive(char **pat
308897
 			cgroup_warn("Warning: fts_read failed\n");
308897
 			break;
308897
 		}
308897
+		cg_chmod_file(fts, ent, mode, 0, mode, 1, 1);
308897
 		ret = cg_chown_file(fts, ent, owner, group);
308897
 	}
308897
 	fts_close(fts);