aboutsummaryrefslogtreecommitdiffstats
path: root/block/bio.c
diff options
context:
space:
mode:
authorTejun Heo <tj@kernel.org>2015-05-22 17:13:22 -0400
committerJens Axboe <axboe@fb.com>2015-06-02 10:33:34 -0400
commitec438699a9ae0856c2ce20a50dd39cdc7e92a732 (patch)
treef7406e5c235380474bf829639feed12bf0711101 /block/bio.c
parent496d5e7560dbb84399dbd92316fc33857aa83900 (diff)
cgroup, block: implement task_get_css() and use it in bio_associate_current()
bio_associate_current() currently open codes task_css() and css_tryget_online() to find and pin $current's blkcg css. Abstract it into task_get_css() which is implemented from cgroup side. As a task is always associated with an online css for every subsystem except while the css_set update is propagating, task_get_css() retries till css_tryget_online() succeeds. This is a cleanup and shouldn't lead to noticeable behavior changes. Signed-off-by: Tejun Heo <tj@kernel.org> Cc: Li Zefan <lizefan@huawei.com> Cc: Jens Axboe <axboe@kernel.dk> Cc: Vivek Goyal <vgoyal@redhat.com> Signed-off-by: Jens Axboe <axboe@fb.com>
Diffstat (limited to 'block/bio.c')
-rw-r--r--block/bio.c11
1 files changed, 1 insertions, 10 deletions
diff --git a/block/bio.c b/block/bio.c
index 259197d97de1..c4f87018fb79 100644
--- a/block/bio.c
+++ b/block/bio.c
@@ -2004,7 +2004,6 @@ EXPORT_SYMBOL(bioset_create_nobvec);
2004int bio_associate_current(struct bio *bio) 2004int bio_associate_current(struct bio *bio)
2005{ 2005{
2006 struct io_context *ioc; 2006 struct io_context *ioc;
2007 struct cgroup_subsys_state *css;
2008 2007
2009 if (bio->bi_ioc) 2008 if (bio->bi_ioc)
2010 return -EBUSY; 2009 return -EBUSY;
@@ -2013,17 +2012,9 @@ int bio_associate_current(struct bio *bio)
2013 if (!ioc) 2012 if (!ioc)
2014 return -ENOENT; 2013 return -ENOENT;
2015 2014
2016 /* acquire active ref on @ioc and associate */
2017 get_io_context_active(ioc); 2015 get_io_context_active(ioc);
2018 bio->bi_ioc = ioc; 2016 bio->bi_ioc = ioc;
2019 2017 bio->bi_css = task_get_css(current, blkio_cgrp_id);
2020 /* associate blkcg if exists */
2021 rcu_read_lock();
2022 css = task_css(current, blkio_cgrp_id);
2023 if (css && css_tryget_online(css))
2024 bio->bi_css = css;
2025 rcu_read_unlock();
2026
2027 return 0; 2018 return 0;
2028} 2019}
2029 2020