]> git.karo-electronics.de Git - karo-tx-linux.git/commitdiff
device_cgroup: introduce dev_whitelist_clean()
authorAristeu Rozanski <aris@redhat.com>
Fri, 7 Sep 2012 00:25:04 +0000 (10:25 +1000)
committerStephen Rothwell <sfr@canb.auug.org.au>
Fri, 7 Sep 2012 05:36:34 +0000 (15:36 +1000)
This function cleans all the items in a whitelist and will be used by the next
patches.

Signed-off-by: Aristeu Rozanski <aris@redhat.com>
Cc: Tejun Heo <tj@kernel.org>
Cc: Li Zefan <lizefan@huawei.com>
Cc: James Morris <jmorris@namei.org>
Cc: Pavel Emelyanov <xemul@openvz.org>
Cc: Serge Hallyn <serge.hallyn@canonical.com>
Signed-off-by: Andrew Morton <akpm@linux-foundation.org>
security/device_cgroup.c

index 574acae77a7da3c1308cd6c155c481b3ebcccf8a..17271a742fdc49ce7c5c56d7a658bc12f3efb53d 100644 (file)
@@ -154,6 +154,22 @@ remove:
        }
 }
 
+/**
+ * dev_whitelist_clean - frees all entries of the whitelist
+ * @dev_cgroup: dev_cgroup with the whitelist to be cleaned
+ *
+ * called under devcgroup_mutex
+ */
+static void dev_whitelist_clean(struct dev_cgroup *dev_cgroup)
+{
+       struct dev_whitelist_item *wh, *tmp;
+
+       list_for_each_entry_safe(wh, tmp, &dev_cgroup->whitelist, list) {
+               list_del(&wh->list);
+               kfree(wh);
+       }
+}
+
 /*
  * called from kernel/cgroup.c with cgroup_lock() held.
  */
@@ -200,13 +216,9 @@ static struct cgroup_subsys_state *devcgroup_create(struct cgroup *cgroup)
 static void devcgroup_destroy(struct cgroup *cgroup)
 {
        struct dev_cgroup *dev_cgroup;
-       struct dev_whitelist_item *wh, *tmp;
 
        dev_cgroup = cgroup_to_devcgroup(cgroup);
-       list_for_each_entry_safe(wh, tmp, &dev_cgroup->whitelist, list) {
-               list_del(&wh->list);
-               kfree(wh);
-       }
+       dev_whitelist_clean(dev_cgroup);
        kfree(dev_cgroup);
 }