diff options
Diffstat (limited to 'drivers/md')
-rw-r--r-- | drivers/md/dm.c | 24 |
1 files changed, 7 insertions, 17 deletions
diff --git a/drivers/md/dm.c b/drivers/md/dm.c index f913b507fc81..dac79d11458d 100644 --- a/drivers/md/dm.c +++ b/drivers/md/dm.c | |||
@@ -99,11 +99,6 @@ union map_info *dm_get_mapinfo(struct bio *bio) | |||
99 | /* | 99 | /* |
100 | * Work processed by per-device workqueue. | 100 | * Work processed by per-device workqueue. |
101 | */ | 101 | */ |
102 | struct dm_wq_req { | ||
103 | struct work_struct work; | ||
104 | struct mapped_device *md; | ||
105 | }; | ||
106 | |||
107 | struct mapped_device { | 102 | struct mapped_device { |
108 | struct rw_semaphore io_lock; | 103 | struct rw_semaphore io_lock; |
109 | struct mutex suspend_lock; | 104 | struct mutex suspend_lock; |
@@ -125,6 +120,7 @@ struct mapped_device { | |||
125 | */ | 120 | */ |
126 | atomic_t pending; | 121 | atomic_t pending; |
127 | wait_queue_head_t wait; | 122 | wait_queue_head_t wait; |
123 | struct work_struct work; | ||
128 | struct bio_list deferred; | 124 | struct bio_list deferred; |
129 | struct bio_list pushback; | 125 | struct bio_list pushback; |
130 | 126 | ||
@@ -1070,6 +1066,8 @@ out: | |||
1070 | 1066 | ||
1071 | static struct block_device_operations dm_blk_dops; | 1067 | static struct block_device_operations dm_blk_dops; |
1072 | 1068 | ||
1069 | static void dm_wq_work(struct work_struct *work); | ||
1070 | |||
1073 | /* | 1071 | /* |
1074 | * Allocate and initialise a blank device with a given minor. | 1072 | * Allocate and initialise a blank device with a given minor. |
1075 | */ | 1073 | */ |
@@ -1136,6 +1134,7 @@ static struct mapped_device *alloc_dev(int minor) | |||
1136 | 1134 | ||
1137 | atomic_set(&md->pending, 0); | 1135 | atomic_set(&md->pending, 0); |
1138 | init_waitqueue_head(&md->wait); | 1136 | init_waitqueue_head(&md->wait); |
1137 | INIT_WORK(&md->work, dm_wq_work); | ||
1139 | init_waitqueue_head(&md->eventq); | 1138 | init_waitqueue_head(&md->eventq); |
1140 | 1139 | ||
1141 | md->disk->major = _major; | 1140 | md->disk->major = _major; |
@@ -1426,26 +1425,17 @@ static void __merge_pushback_list(struct mapped_device *md) | |||
1426 | 1425 | ||
1427 | static void dm_wq_work(struct work_struct *work) | 1426 | static void dm_wq_work(struct work_struct *work) |
1428 | { | 1427 | { |
1429 | struct dm_wq_req *req = container_of(work, struct dm_wq_req, work); | 1428 | struct mapped_device *md = container_of(work, struct mapped_device, |
1430 | struct mapped_device *md = req->md; | 1429 | work); |
1431 | 1430 | ||
1432 | down_write(&md->io_lock); | 1431 | down_write(&md->io_lock); |
1433 | __flush_deferred_io(md); | 1432 | __flush_deferred_io(md); |
1434 | up_write(&md->io_lock); | 1433 | up_write(&md->io_lock); |
1435 | } | 1434 | } |
1436 | 1435 | ||
1437 | static void dm_wq_queue(struct mapped_device *md, struct dm_wq_req *req) | ||
1438 | { | ||
1439 | req->md = md; | ||
1440 | INIT_WORK(&req->work, dm_wq_work); | ||
1441 | queue_work(md->wq, &req->work); | ||
1442 | } | ||
1443 | |||
1444 | static void dm_queue_flush(struct mapped_device *md) | 1436 | static void dm_queue_flush(struct mapped_device *md) |
1445 | { | 1437 | { |
1446 | struct dm_wq_req req; | 1438 | queue_work(md->wq, &md->work); |
1447 | |||
1448 | dm_wq_queue(md, &req); | ||
1449 | flush_workqueue(md->wq); | 1439 | flush_workqueue(md->wq); |
1450 | } | 1440 | } |
1451 | 1441 | ||