Donate to e Foundation | Murena handsets with /e/OS | Own a part of Murena! Learn more

Commit f9fcc2d3 authored by Tejun Heo's avatar Tejun Heo Committed by Jens Axboe
Browse files

blkcg: collapse blkcg_policy_ops into blkcg_policy



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: default avatarTejun Heo <tj@kernel.org>
Cc: Vivek Goyal <vgoyal@redhat.com>
Signed-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent f95a04af
Loading
Loading
Loading
Loading
+8 −8
Original line number Diff line number Diff line
@@ -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;
+5 −7
Original line number Diff line number Diff line
@@ -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;
+6 −7
Original line number Diff line number Diff line
@@ -1100,13 +1100,12 @@ static void throtl_shutdown_wq(struct request_queue *q)
}

static struct blkcg_policy blkcg_policy_throtl = {
	.ops = {
	.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,
	},
	.pd_size = sizeof(struct throtl_grp),
	.cftypes = throtl_files,
};

bool blk_throtl_bio(struct request_queue *q, struct bio *bio)
+5 −6
Original line number Diff line number Diff line
@@ -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_init_fn		= cfq_pd_init,
	.pd_reset_stats_fn	= cfq_pd_reset_stats,
};
#endif