cgroup: list_for_each cleanup
-------------------------- while() { list_entry(); ... } -------------------------- is equivalent to following code. -------------------------- list_for_each_entry(){ ... } -------------------------- later can review easily more. this patch is just clean up. it doesn't have any behavor change. Signed-off-by: KOSAKI Motohiro <kosaki.motohiro@jp.fujitsu.com> Cc: Paul Menage <menage@google.com> Cc: Li Zefan <lizf@cn.fujitsu.com> Signed-off-by: Andrew Morton <akpm@linux-foundation.org> Signed-off-by: Linus Torvalds <torvalds@linux-foundation.org>
This commit is contained in:
parent
f2992db2a4
commit
71cbb949d1
@ -241,17 +241,20 @@ static int use_task_css_set_links;
|
|||||||
*/
|
*/
|
||||||
static void unlink_css_set(struct css_set *cg)
|
static void unlink_css_set(struct css_set *cg)
|
||||||
{
|
{
|
||||||
|
struct cg_cgroup_link *link;
|
||||||
|
struct cg_cgroup_link *saved_link;
|
||||||
|
|
||||||
write_lock(&css_set_lock);
|
write_lock(&css_set_lock);
|
||||||
hlist_del(&cg->hlist);
|
hlist_del(&cg->hlist);
|
||||||
css_set_count--;
|
css_set_count--;
|
||||||
while (!list_empty(&cg->cg_links)) {
|
|
||||||
struct cg_cgroup_link *link;
|
list_for_each_entry_safe(link, saved_link, &cg->cg_links,
|
||||||
link = list_entry(cg->cg_links.next,
|
cg_link_list) {
|
||||||
struct cg_cgroup_link, cg_link_list);
|
|
||||||
list_del(&link->cg_link_list);
|
list_del(&link->cg_link_list);
|
||||||
list_del(&link->cgrp_link_list);
|
list_del(&link->cgrp_link_list);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
}
|
}
|
||||||
|
|
||||||
write_unlock(&css_set_lock);
|
write_unlock(&css_set_lock);
|
||||||
}
|
}
|
||||||
|
|
||||||
@ -363,15 +366,14 @@ static struct css_set *find_existing_css_set(
|
|||||||
static int allocate_cg_links(int count, struct list_head *tmp)
|
static int allocate_cg_links(int count, struct list_head *tmp)
|
||||||
{
|
{
|
||||||
struct cg_cgroup_link *link;
|
struct cg_cgroup_link *link;
|
||||||
|
struct cg_cgroup_link *saved_link;
|
||||||
int i;
|
int i;
|
||||||
INIT_LIST_HEAD(tmp);
|
INIT_LIST_HEAD(tmp);
|
||||||
for (i = 0; i < count; i++) {
|
for (i = 0; i < count; i++) {
|
||||||
link = kmalloc(sizeof(*link), GFP_KERNEL);
|
link = kmalloc(sizeof(*link), GFP_KERNEL);
|
||||||
if (!link) {
|
if (!link) {
|
||||||
while (!list_empty(tmp)) {
|
list_for_each_entry_safe(link, saved_link, tmp,
|
||||||
link = list_entry(tmp->next,
|
cgrp_link_list) {
|
||||||
struct cg_cgroup_link,
|
|
||||||
cgrp_link_list);
|
|
||||||
list_del(&link->cgrp_link_list);
|
list_del(&link->cgrp_link_list);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
}
|
}
|
||||||
@ -384,11 +386,10 @@ static int allocate_cg_links(int count, struct list_head *tmp)
|
|||||||
|
|
||||||
static void free_cg_links(struct list_head *tmp)
|
static void free_cg_links(struct list_head *tmp)
|
||||||
{
|
{
|
||||||
while (!list_empty(tmp)) {
|
struct cg_cgroup_link *link;
|
||||||
struct cg_cgroup_link *link;
|
struct cg_cgroup_link *saved_link;
|
||||||
link = list_entry(tmp->next,
|
|
||||||
struct cg_cgroup_link,
|
list_for_each_entry_safe(link, saved_link, tmp, cgrp_link_list) {
|
||||||
cgrp_link_list);
|
|
||||||
list_del(&link->cgrp_link_list);
|
list_del(&link->cgrp_link_list);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
}
|
}
|
||||||
@ -1093,6 +1094,8 @@ static void cgroup_kill_sb(struct super_block *sb) {
|
|||||||
struct cgroupfs_root *root = sb->s_fs_info;
|
struct cgroupfs_root *root = sb->s_fs_info;
|
||||||
struct cgroup *cgrp = &root->top_cgroup;
|
struct cgroup *cgrp = &root->top_cgroup;
|
||||||
int ret;
|
int ret;
|
||||||
|
struct cg_cgroup_link *link;
|
||||||
|
struct cg_cgroup_link *saved_link;
|
||||||
|
|
||||||
BUG_ON(!root);
|
BUG_ON(!root);
|
||||||
|
|
||||||
@ -1112,10 +1115,9 @@ static void cgroup_kill_sb(struct super_block *sb) {
|
|||||||
* root cgroup
|
* root cgroup
|
||||||
*/
|
*/
|
||||||
write_lock(&css_set_lock);
|
write_lock(&css_set_lock);
|
||||||
while (!list_empty(&cgrp->css_sets)) {
|
|
||||||
struct cg_cgroup_link *link;
|
list_for_each_entry_safe(link, saved_link, &cgrp->css_sets,
|
||||||
link = list_entry(cgrp->css_sets.next,
|
cgrp_link_list) {
|
||||||
struct cg_cgroup_link, cgrp_link_list);
|
|
||||||
list_del(&link->cg_link_list);
|
list_del(&link->cg_link_list);
|
||||||
list_del(&link->cgrp_link_list);
|
list_del(&link->cgrp_link_list);
|
||||||
kfree(link);
|
kfree(link);
|
||||||
@ -1756,15 +1758,11 @@ int cgroup_add_files(struct cgroup *cgrp,
|
|||||||
int cgroup_task_count(const struct cgroup *cgrp)
|
int cgroup_task_count(const struct cgroup *cgrp)
|
||||||
{
|
{
|
||||||
int count = 0;
|
int count = 0;
|
||||||
struct list_head *l;
|
struct cg_cgroup_link *link;
|
||||||
|
|
||||||
read_lock(&css_set_lock);
|
read_lock(&css_set_lock);
|
||||||
l = cgrp->css_sets.next;
|
list_for_each_entry(link, &cgrp->css_sets, cgrp_link_list) {
|
||||||
while (l != &cgrp->css_sets) {
|
|
||||||
struct cg_cgroup_link *link =
|
|
||||||
list_entry(l, struct cg_cgroup_link, cgrp_link_list);
|
|
||||||
count += atomic_read(&link->cg->ref.refcount);
|
count += atomic_read(&link->cg->ref.refcount);
|
||||||
l = l->next;
|
|
||||||
}
|
}
|
||||||
read_unlock(&css_set_lock);
|
read_unlock(&css_set_lock);
|
||||||
return count;
|
return count;
|
||||||
|
Loading…
Reference in New Issue
Block a user