diff options
-rw-r--r-- | block/blk-cgroup.c | 19 | ||||
-rw-r--r-- | block/blk-ioc.c | 68 | ||||
-rw-r--r-- | fs/ioprio.c | 2 | ||||
-rw-r--r-- | include/linux/iocontext.h | 7 |
4 files changed, 1 insertions, 95 deletions
diff --git a/block/blk-cgroup.c b/block/blk-cgroup.c index 30e07308db24..a74019b67311 100644 --- a/block/blk-cgroup.c +++ b/block/blk-cgroup.c | |||
@@ -47,8 +47,6 @@ static struct cgroup_subsys_state *blkiocg_create(struct cgroup_subsys *, | |||
47 | struct cgroup *); | 47 | struct cgroup *); |
48 | static int blkiocg_can_attach(struct cgroup_subsys *, struct cgroup *, | 48 | static int blkiocg_can_attach(struct cgroup_subsys *, struct cgroup *, |
49 | struct cgroup_taskset *); | 49 | struct cgroup_taskset *); |
50 | static void blkiocg_attach(struct cgroup_subsys *, struct cgroup *, | ||
51 | struct cgroup_taskset *); | ||
52 | static int blkiocg_pre_destroy(struct cgroup_subsys *, struct cgroup *); | 50 | static int blkiocg_pre_destroy(struct cgroup_subsys *, struct cgroup *); |
53 | static void blkiocg_destroy(struct cgroup_subsys *, struct cgroup *); | 51 | static void blkiocg_destroy(struct cgroup_subsys *, struct cgroup *); |
54 | static int blkiocg_populate(struct cgroup_subsys *, struct cgroup *); | 52 | static int blkiocg_populate(struct cgroup_subsys *, struct cgroup *); |
@@ -63,7 +61,6 @@ struct cgroup_subsys blkio_subsys = { | |||
63 | .name = "blkio", | 61 | .name = "blkio", |
64 | .create = blkiocg_create, | 62 | .create = blkiocg_create, |
65 | .can_attach = blkiocg_can_attach, | 63 | .can_attach = blkiocg_can_attach, |
66 | .attach = blkiocg_attach, | ||
67 | .pre_destroy = blkiocg_pre_destroy, | 64 | .pre_destroy = blkiocg_pre_destroy, |
68 | .destroy = blkiocg_destroy, | 65 | .destroy = blkiocg_destroy, |
69 | .populate = blkiocg_populate, | 66 | .populate = blkiocg_populate, |
@@ -1729,22 +1726,6 @@ static int blkiocg_can_attach(struct cgroup_subsys *ss, struct cgroup *cgrp, | |||
1729 | return ret; | 1726 | return ret; |
1730 | } | 1727 | } |
1731 | 1728 | ||
1732 | static void blkiocg_attach(struct cgroup_subsys *ss, struct cgroup *cgrp, | ||
1733 | struct cgroup_taskset *tset) | ||
1734 | { | ||
1735 | struct task_struct *task; | ||
1736 | struct io_context *ioc; | ||
1737 | |||
1738 | cgroup_taskset_for_each(task, cgrp, tset) { | ||
1739 | /* we don't lose anything even if ioc allocation fails */ | ||
1740 | ioc = get_task_io_context(task, GFP_ATOMIC, NUMA_NO_NODE); | ||
1741 | if (ioc) { | ||
1742 | ioc_cgroup_changed(ioc); | ||
1743 | put_io_context(ioc); | ||
1744 | } | ||
1745 | } | ||
1746 | } | ||
1747 | |||
1748 | static void blkcg_bypass_start(void) | 1729 | static void blkcg_bypass_start(void) |
1749 | __acquires(&all_q_mutex) | 1730 | __acquires(&all_q_mutex) |
1750 | { | 1731 | { |
diff --git a/block/blk-ioc.c b/block/blk-ioc.c index 439ec21fd787..3f3dd51a1280 100644 --- a/block/blk-ioc.c +++ b/block/blk-ioc.c | |||
@@ -388,74 +388,6 @@ struct io_cq *ioc_create_icq(struct io_context *ioc, struct request_queue *q, | |||
388 | return icq; | 388 | return icq; |
389 | } | 389 | } |
390 | 390 | ||
391 | void ioc_set_icq_flags(struct io_context *ioc, unsigned int flags) | ||
392 | { | ||
393 | struct io_cq *icq; | ||
394 | struct hlist_node *n; | ||
395 | |||
396 | hlist_for_each_entry(icq, n, &ioc->icq_list, ioc_node) | ||
397 | icq->flags |= flags; | ||
398 | } | ||
399 | |||
400 | /** | ||
401 | * ioc_ioprio_changed - notify ioprio change | ||
402 | * @ioc: io_context of interest | ||
403 | * @ioprio: new ioprio | ||
404 | * | ||
405 | * @ioc's ioprio has changed to @ioprio. Set %ICQ_IOPRIO_CHANGED for all | ||
406 | * icq's. iosched is responsible for checking the bit and applying it on | ||
407 | * request issue path. | ||
408 | */ | ||
409 | void ioc_ioprio_changed(struct io_context *ioc, int ioprio) | ||
410 | { | ||
411 | unsigned long flags; | ||
412 | |||
413 | spin_lock_irqsave(&ioc->lock, flags); | ||
414 | ioc->ioprio = ioprio; | ||
415 | ioc_set_icq_flags(ioc, ICQ_IOPRIO_CHANGED); | ||
416 | spin_unlock_irqrestore(&ioc->lock, flags); | ||
417 | } | ||
418 | |||
419 | /** | ||
420 | * ioc_cgroup_changed - notify cgroup change | ||
421 | * @ioc: io_context of interest | ||
422 | * | ||
423 | * @ioc's cgroup has changed. Set %ICQ_CGROUP_CHANGED for all icq's. | ||
424 | * iosched is responsible for checking the bit and applying it on request | ||
425 | * issue path. | ||
426 | */ | ||
427 | void ioc_cgroup_changed(struct io_context *ioc) | ||
428 | { | ||
429 | unsigned long flags; | ||
430 | |||
431 | spin_lock_irqsave(&ioc->lock, flags); | ||
432 | ioc_set_icq_flags(ioc, ICQ_CGROUP_CHANGED); | ||
433 | spin_unlock_irqrestore(&ioc->lock, flags); | ||
434 | } | ||
435 | EXPORT_SYMBOL(ioc_cgroup_changed); | ||
436 | |||
437 | /** | ||
438 | * icq_get_changed - fetch and clear icq changed mask | ||
439 | * @icq: icq of interest | ||
440 | * | ||
441 | * Fetch and clear ICQ_*_CHANGED bits from @icq. Grabs and releases | ||
442 | * @icq->ioc->lock. | ||
443 | */ | ||
444 | unsigned icq_get_changed(struct io_cq *icq) | ||
445 | { | ||
446 | unsigned int changed = 0; | ||
447 | unsigned long flags; | ||
448 | |||
449 | if (unlikely(icq->flags & ICQ_CHANGED_MASK)) { | ||
450 | spin_lock_irqsave(&icq->ioc->lock, flags); | ||
451 | changed = icq->flags & ICQ_CHANGED_MASK; | ||
452 | icq->flags &= ~ICQ_CHANGED_MASK; | ||
453 | spin_unlock_irqrestore(&icq->ioc->lock, flags); | ||
454 | } | ||
455 | return changed; | ||
456 | } | ||
457 | EXPORT_SYMBOL(icq_get_changed); | ||
458 | |||
459 | static int __init blk_ioc_init(void) | 391 | static int __init blk_ioc_init(void) |
460 | { | 392 | { |
461 | iocontext_cachep = kmem_cache_create("blkdev_ioc", | 393 | iocontext_cachep = kmem_cache_create("blkdev_ioc", |
diff --git a/fs/ioprio.c b/fs/ioprio.c index 0f1b9515213b..48644373de58 100644 --- a/fs/ioprio.c +++ b/fs/ioprio.c | |||
@@ -50,7 +50,7 @@ int set_task_ioprio(struct task_struct *task, int ioprio) | |||
50 | 50 | ||
51 | ioc = get_task_io_context(task, GFP_ATOMIC, NUMA_NO_NODE); | 51 | ioc = get_task_io_context(task, GFP_ATOMIC, NUMA_NO_NODE); |
52 | if (ioc) { | 52 | if (ioc) { |
53 | ioc_ioprio_changed(ioc, ioprio); | 53 | ioc->ioprio = ioprio; |
54 | put_io_context(ioc); | 54 | put_io_context(ioc); |
55 | } | 55 | } |
56 | 56 | ||
diff --git a/include/linux/iocontext.h b/include/linux/iocontext.h index 6f1a2608e91f..df38db2ef45b 100644 --- a/include/linux/iocontext.h +++ b/include/linux/iocontext.h | |||
@@ -6,11 +6,7 @@ | |||
6 | #include <linux/workqueue.h> | 6 | #include <linux/workqueue.h> |
7 | 7 | ||
8 | enum { | 8 | enum { |
9 | ICQ_IOPRIO_CHANGED = 1 << 0, | ||
10 | ICQ_CGROUP_CHANGED = 1 << 1, | ||
11 | ICQ_EXITED = 1 << 2, | 9 | ICQ_EXITED = 1 << 2, |
12 | |||
13 | ICQ_CHANGED_MASK = ICQ_IOPRIO_CHANGED | ICQ_CGROUP_CHANGED, | ||
14 | }; | 10 | }; |
15 | 11 | ||
16 | /* | 12 | /* |
@@ -152,9 +148,6 @@ void put_io_context_active(struct io_context *ioc); | |||
152 | void exit_io_context(struct task_struct *task); | 148 | void exit_io_context(struct task_struct *task); |
153 | struct io_context *get_task_io_context(struct task_struct *task, | 149 | struct io_context *get_task_io_context(struct task_struct *task, |
154 | gfp_t gfp_flags, int node); | 150 | gfp_t gfp_flags, int node); |
155 | void ioc_ioprio_changed(struct io_context *ioc, int ioprio); | ||
156 | void ioc_cgroup_changed(struct io_context *ioc); | ||
157 | unsigned int icq_get_changed(struct io_cq *icq); | ||
158 | #else | 151 | #else |
159 | struct io_context; | 152 | struct io_context; |
160 | static inline void put_io_context(struct io_context *ioc) { } | 153 | static inline void put_io_context(struct io_context *ioc) { } |