123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657 |
- // SPDX-License-Identifier: GPL-2.0
- #include "blk-cgroup.h"
- /**
- * blkcg_set_fc_appid - set the fc_app_id field associted to blkcg
- * @app_id: application identifier
- * @cgrp_id: cgroup id
- * @app_id_len: size of application identifier
- */
- int blkcg_set_fc_appid(char *app_id, u64 cgrp_id, size_t app_id_len)
- {
- struct cgroup *cgrp;
- struct cgroup_subsys_state *css;
- struct blkcg *blkcg;
- int ret = 0;
- if (app_id_len > FC_APPID_LEN)
- return -EINVAL;
- cgrp = cgroup_get_from_id(cgrp_id);
- if (IS_ERR(cgrp))
- return PTR_ERR(cgrp);
- css = cgroup_get_e_css(cgrp, &io_cgrp_subsys);
- if (!css) {
- ret = -ENOENT;
- goto out_cgrp_put;
- }
- blkcg = css_to_blkcg(css);
- /*
- * There is a slight race condition on setting the appid.
- * Worst case an I/O may not find the right id.
- * This is no different from the I/O we let pass while obtaining
- * the vmid from the fabric.
- * Adding the overhead of a lock is not necessary.
- */
- strlcpy(blkcg->fc_app_id, app_id, app_id_len);
- css_put(css);
- out_cgrp_put:
- cgroup_put(cgrp);
- return ret;
- }
- EXPORT_SYMBOL_GPL(blkcg_set_fc_appid);
- /**
- * blkcg_get_fc_appid - get the fc app identifier associated with a bio
- * @bio: target bio
- *
- * On success return the fc_app_id, on failure return NULL
- */
- char *blkcg_get_fc_appid(struct bio *bio)
- {
- if (!bio->bi_blkg || bio->bi_blkg->blkcg->fc_app_id[0] == '\0')
- return NULL;
- return bio->bi_blkg->blkcg->fc_app_id;
- }
- EXPORT_SYMBOL_GPL(blkcg_get_fc_appid);
|