diff options
author | Tejun Heo <tj@kernel.org> | 2015-08-18 17:55:13 -0400 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2015-08-18 18:49:17 -0400 |
commit | b2ce2643cc705aa9043642d7b6248ccfd8e20629 (patch) | |
tree | 5a759c516fc27535b5f429b1cd369fd39764880e /block/cfq-iosched.c | |
parent | 4fb72036fbf9c28de7a64b1d3f19b4ce9da1c6bf (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.c | 15 |
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 | ||
1585 | static struct blkg_policy_data *cfq_pd_alloc(gfp_t gfp, int node) | 1585 | static 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 | ||
1590 | static void cfq_pd_init(struct blkcg_gq *blkg) | 1600 | static 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 | ||
1602 | static void cfq_pd_offline(struct blkcg_gq *blkg) | 1609 | static void cfq_pd_offline(struct blkcg_gq *blkg) |