Blame SOURCES/libcgroup-0.37-chmod.patch

da3e87
diff -up libcgroup-0.40.rc1/src/api.c.chmod libcgroup-0.40.rc1/src/api.c
da3e87
--- libcgroup-0.40.rc1/src/api.c.chmod	2013-08-26 17:30:03.588276405 +0200
da3e87
+++ libcgroup-0.40.rc1/src/api.c	2013-08-26 17:30:23.104126917 +0200
da3e87
@@ -156,6 +156,10 @@ static int cg_chown_file(FTS *fts, FTSEN
da3e87
 	return ret;
da3e87
 }
da3e87
 
da3e87
+int cg_chmod_file(FTS *fts, FTSENT *ent, mode_t dir_mode,
da3e87
+	int dirm_change, mode_t file_mode, int filem_change,
da3e87
+	int owner_is_umask);
da3e87
+
da3e87
 /*
da3e87
  * TODO: Need to decide a better place to put this function.
da3e87
  */
da3e87
@@ -163,6 +167,8 @@ static int cg_chown_recursive(char **pat
da3e87
 {
da3e87
 	int ret = 0;
da3e87
 	FTS *fts;
da3e87
+	/* mode 664 */
da3e87
+	mode_t mode = S_IRUSR | S_IWUSR | S_IRGRP | S_IWGRP | S_IROTH;
da3e87
 
da3e87
 	cgroup_dbg("chown: path is %s\n", *path);
da3e87
 	fts = fts_open(path, FTS_PHYSICAL | FTS_NOCHDIR |
da3e87
@@ -180,6 +186,7 @@ static int cg_chown_recursive(char **pat
da3e87
 			cgroup_warn("Warning: fts_read failed\n");
da3e87
 			break;
da3e87
 		}
da3e87
+		cg_chmod_file(fts, ent, mode, 0, mode, 1, 1);
da3e87
 		ret = cg_chown_file(fts, ent, owner, group);
da3e87
 	}
da3e87
 	fts_close(fts);