summaryrefslogtreecommitdiffstats
path: root/block/cfq-iosched.c
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2015-08-18 17:55:13 -0400
committerJens Axboe <axboe@fb.com>2015-08-18 18:49:17 -0400
commitb2ce2643cc705aa9043642d7b6248ccfd8e20629 (patch)
tree5a759c516fc27535b5f429b1cd369fd39764880e /block/cfq-iosched.c
parent4fb72036fbf9c28de7a64b1d3f19b4ce9da1c6bf (diff)
blk-throttle: clean up blkg_policy_data alloc/init/exit/free methods
With the recent addition of alloc and free methods, things became messier. This patch reorganizes them according to the followings. * ->pd_alloc_fn() Responsible for allocation and static initializations - the ones which can be done independent of where the pd might be attached. * ->pd_init_fn() Initializations which require the knowledge of where the pd is attached. * ->pd_free_fn() The counter part of pd_alloc_fn(). Static de-init and freeing. This leaves ->pd_exit_fn() without any users. Removed. While at it, collapse an one liner function throtl_pd_exit(), which has only one user, into its user. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Vivek Goyal <vgoyal@redhat.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block/cfq-iosched.c')
-rw-r--r--block/cfq-iosched.c15
1 files changed, 11 insertions, 4 deletions
diff --git a/block/cfq-iosched.c b/block/cfq-iosched.c
index 69ce2883099e..4b795c7250ef 100644
--- a/block/cfq-iosched.c
+++ b/block/cfq-iosched.c
@@ -1584,7 +1584,17 @@ static void cfq_cpd_init(const struct blkcg *blkcg)
1584 1584
1585static struct blkg_policy_data *cfq_pd_alloc(gfp_t gfp, int node) 1585static struct blkg_policy_data *cfq_pd_alloc(gfp_t gfp, int node)
1586{ 1586{
1587 return kzalloc_node(sizeof(struct cfq_group), gfp, node); 1587 struct cfq_group *cfqg;
1588
1589 cfqg = kzalloc_node(sizeof(*cfqg), gfp, node);
1590 if (!cfqg)
1591 return NULL;
1592
1593 cfq_init_cfqg_base(cfqg);
1594 cfqg_stats_init(&cfqg->stats);
1595 cfqg_stats_init(&cfqg->dead_stats);
1596
1597 return &cfqg->pd;
1588} 1598}
1589 1599
1590static void cfq_pd_init(struct blkcg_gq *blkg) 1600static void cfq_pd_init(struct blkcg_gq *blkg)
@@ -1592,11 +1602,8 @@ static void cfq_pd_init(struct blkcg_gq *blkg)
1592 struct cfq_group *cfqg = blkg_to_cfqg(blkg); 1602 struct cfq_group *cfqg = blkg_to_cfqg(blkg);
1593 struct cfq_group_data *cgd = blkcg_to_cfqgd(blkg->blkcg); 1603 struct cfq_group_data *cgd = blkcg_to_cfqgd(blkg->blkcg);
1594 1604
1595 cfq_init_cfqg_base(cfqg);
1596 cfqg->weight = cgd->weight; 1605 cfqg->weight = cgd->weight;
1597 cfqg->leaf_weight = cgd->leaf_weight; 1606 cfqg->leaf_weight = cgd->leaf_weight;
1598 cfqg_stats_init(&cfqg->stats);
1599 cfqg_stats_init(&cfqg->dead_stats);
1600} 1607}
1601 1608
1602static void cfq_pd_offline(struct blkcg_gq *blkg) 1609static void cfq_pd_offline(struct blkcg_gq *blkg)