diff options
author | Tejun Heo <tj@kernel.org> | 2015-05-22 17:13:22 -0400 |
---|---|---|
committer | Jens Axboe <axboe@fb.com> | 2015-06-02 10:33:34 -0400 |
commit | ec438699a9ae0856c2ce20a50dd39cdc7e92a732 (patch) | |
tree | f7406e5c235380474bf829639feed12bf0711101 /block/bio.c | |
parent | 496d5e7560dbb84399dbd92316fc33857aa83900 (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.c | 11 |
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); | |||
2004 | int bio_associate_current(struct bio *bio) | 2004 | int 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 | ||