Skip to content

Commit

Permalink
blkcg: collapse blkcg_policy_ops into blkcg_policy
Browse files Browse the repository at this point in the history
There's no reason to keep blkcg_policy_ops separate.  Collapse it into
blkcg_policy.

This patch doesn't introduce any functional change.

Signed-off-by: Tejun Heo <tj@kernel.org>
Cc: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: Jens Axboe <axboe@kernel.dk>
  • Loading branch information
Tejun Heo authored and Jens Axboe committed Apr 20, 2012
1 parent f95a04a commit f9fcc2d
Showing 4 changed files with 24 additions and 28 deletions.
16 changes: 8 additions & 8 deletions block/blk-cgroup.c
Original file line number Diff line number Diff line change
@@ -78,8 +78,8 @@ static void blkg_free(struct blkcg_gq *blkg)
if (!pd)
continue;

if (pol && pol->ops.pd_exit_fn)
pol->ops.pd_exit_fn(blkg);
if (pol && pol->pd_exit_fn)
pol->pd_exit_fn(blkg);

kfree(pd);
}
@@ -132,7 +132,7 @@ static struct blkcg_gq *blkg_alloc(struct blkcg *blkcg, struct request_queue *q)
struct blkcg_policy *pol = blkcg_policy[i];

if (blkcg_policy_enabled(blkg->q, pol))
pol->ops.pd_init_fn(blkg);
pol->pd_init_fn(blkg);
}

return blkg;
@@ -305,8 +305,8 @@ static int blkcg_reset_stats(struct cgroup *cgroup, struct cftype *cftype,
struct blkcg_policy *pol = blkcg_policy[i];

if (blkcg_policy_enabled(blkg->q, pol) &&
pol->ops.pd_reset_stats_fn)
pol->ops.pd_reset_stats_fn(blkg);
pol->pd_reset_stats_fn)
pol->pd_reset_stats_fn(blkg);
}
}

@@ -758,7 +758,7 @@ int blkcg_activate_policy(struct request_queue *q,

blkg->pd[pol->plid] = pd;
pd->blkg = blkg;
pol->ops.pd_init_fn(blkg);
pol->pd_init_fn(blkg);

spin_unlock(&blkg->blkcg->lock);
}
@@ -804,8 +804,8 @@ void blkcg_deactivate_policy(struct request_queue *q,
/* grab blkcg lock too while removing @pd from @blkg */
spin_lock(&blkg->blkcg->lock);

if (pol->ops.pd_exit_fn)
pol->ops.pd_exit_fn(blkg);
if (pol->pd_exit_fn)
pol->pd_exit_fn(blkg);

kfree(blkg->pd[pol->plid]);
blkg->pd[pol->plid] = NULL;
12 changes: 5 additions & 7 deletions block/blk-cgroup.h
Original file line number Diff line number Diff line change
@@ -99,19 +99,17 @@ typedef void (blkcg_pol_init_pd_fn)(struct blkcg_gq *blkg);
typedef void (blkcg_pol_exit_pd_fn)(struct blkcg_gq *blkg);
typedef void (blkcg_pol_reset_pd_stats_fn)(struct blkcg_gq *blkg);

struct blkcg_policy_ops {
blkcg_pol_init_pd_fn *pd_init_fn;
blkcg_pol_exit_pd_fn *pd_exit_fn;
blkcg_pol_reset_pd_stats_fn *pd_reset_stats_fn;
};

struct blkcg_policy {
struct blkcg_policy_ops ops;
int plid;
/* policy specific private data size */
size_t pd_size;
/* cgroup files for the policy */
struct cftype *cftypes;

/* operations */
blkcg_pol_init_pd_fn *pd_init_fn;
blkcg_pol_exit_pd_fn *pd_exit_fn;
blkcg_pol_reset_pd_stats_fn *pd_reset_stats_fn;
};

extern struct blkcg blkcg_root;
13 changes: 6 additions & 7 deletions block/blk-throttle.c
Original file line number Diff line number Diff line change
@@ -1100,13 +1100,12 @@ static void throtl_shutdown_wq(struct request_queue *q)
}

static struct blkcg_policy blkcg_policy_throtl = {
.ops = {
.pd_init_fn = throtl_pd_init,
.pd_exit_fn = throtl_pd_exit,
.pd_reset_stats_fn = throtl_pd_reset_stats,
},
.pd_size = sizeof(struct throtl_grp),
.cftypes = throtl_files,
.pd_size = sizeof(struct throtl_grp),
.cftypes = throtl_files,

.pd_init_fn = throtl_pd_init,
.pd_exit_fn = throtl_pd_exit,
.pd_reset_stats_fn = throtl_pd_reset_stats,
};

bool blk_throtl_bio(struct request_queue *q, struct bio *bio)
11 changes: 5 additions & 6 deletions block/cfq-iosched.c
Original file line number Diff line number Diff line change
@@ -4165,12 +4165,11 @@ static struct elevator_type iosched_cfq = {

#ifdef CONFIG_CFQ_GROUP_IOSCHED
static struct blkcg_policy blkcg_policy_cfq = {
.ops = {
.pd_init_fn = cfq_pd_init,
.pd_reset_stats_fn = cfq_pd_reset_stats,
},
.pd_size = sizeof(struct cfq_group),
.cftypes = cfq_blkcg_files,
.pd_size = sizeof(struct cfq_group),
.cftypes = cfq_blkcg_files,

.pd_init_fn = cfq_pd_init,
.pd_reset_stats_fn = cfq_pd_reset_stats,
};
#endif

0 comments on commit f9fcc2d

Please sign in to comment.