diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-21 20:08:06 -0500 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2012-12-21 20:08:06 -0500 |
commit | b49249d10324d0fd6fb29725c2807dfd80d0edbc (patch) | |
tree | 9a8fa724e6c9f9283530979c6e32a311c74999d5 /drivers/md/dm-linear.c | |
parent | 10532b560bacf23766f9c7dc09778b31b198ff45 (diff) | |
parent | 45e621d45e24ffc4cb2b2935e8438987b860063a (diff) |
Merge tag 'dm-3.8-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/agk/linux-dm
Pull dm update from Alasdair G Kergon:
"Miscellaneous device-mapper fixes, cleanups and performance
improvements.
Of particular note:
- Disable broken WRITE SAME support in all targets except linear and
striped. Use it when kcopyd is zeroing blocks.
- Remove several mempools from targets by moving the data into the
bio's new front_pad area(which dm calls 'per_bio_data').
- Fix a race in thin provisioning if discards are misused.
- Prevent userspace from interfering with the ioctl parameters and
use kmalloc for the data buffer if it's small instead of vmalloc.
- Throttle some annoying error messages when I/O fails."
* tag 'dm-3.8-fixes' of git://git.kernel.org/pub/scm/linux/kernel/git/agk/linux-dm: (36 commits)
dm stripe: add WRITE SAME support
dm: remove map_info
dm snapshot: do not use map_context
dm thin: dont use map_context
dm raid1: dont use map_context
dm flakey: dont use map_context
dm raid1: rename read_record to bio_record
dm: move target request nr to dm_target_io
dm snapshot: use per_bio_data
dm verity: use per_bio_data
dm raid1: use per_bio_data
dm: introduce per_bio_data
dm kcopyd: add WRITE SAME support to dm_kcopyd_zero
dm linear: add WRITE SAME support
dm: add WRITE SAME support
dm: prepare to support WRITE SAME
dm ioctl: use kmalloc if possible
dm ioctl: remove PF_MEMALLOC
dm persistent data: improve improve space map block alloc failure message
dm thin: use DMERR_LIMIT for errors
...
Diffstat (limited to 'drivers/md/dm-linear.c')
-rw-r--r-- | drivers/md/dm-linear.c | 6 |
1 files changed, 3 insertions, 3 deletions
diff --git a/drivers/md/dm-linear.c b/drivers/md/dm-linear.c index 1bf19a93eef0..328cad5617ab 100644 --- a/drivers/md/dm-linear.c +++ b/drivers/md/dm-linear.c | |||
@@ -55,6 +55,7 @@ static int linear_ctr(struct dm_target *ti, unsigned int argc, char **argv) | |||
55 | 55 | ||
56 | ti->num_flush_requests = 1; | 56 | ti->num_flush_requests = 1; |
57 | ti->num_discard_requests = 1; | 57 | ti->num_discard_requests = 1; |
58 | ti->num_write_same_requests = 1; | ||
58 | ti->private = lc; | 59 | ti->private = lc; |
59 | return 0; | 60 | return 0; |
60 | 61 | ||
@@ -87,8 +88,7 @@ static void linear_map_bio(struct dm_target *ti, struct bio *bio) | |||
87 | bio->bi_sector = linear_map_sector(ti, bio->bi_sector); | 88 | bio->bi_sector = linear_map_sector(ti, bio->bi_sector); |
88 | } | 89 | } |
89 | 90 | ||
90 | static int linear_map(struct dm_target *ti, struct bio *bio, | 91 | static int linear_map(struct dm_target *ti, struct bio *bio) |
91 | union map_info *map_context) | ||
92 | { | 92 | { |
93 | linear_map_bio(ti, bio); | 93 | linear_map_bio(ti, bio); |
94 | 94 | ||
@@ -155,7 +155,7 @@ static int linear_iterate_devices(struct dm_target *ti, | |||
155 | 155 | ||
156 | static struct target_type linear_target = { | 156 | static struct target_type linear_target = { |
157 | .name = "linear", | 157 | .name = "linear", |
158 | .version = {1, 1, 0}, | 158 | .version = {1, 2, 0}, |
159 | .module = THIS_MODULE, | 159 | .module = THIS_MODULE, |
160 | .ctr = linear_ctr, | 160 | .ctr = linear_ctr, |
161 | .dtr = linear_dtr, | 161 | .dtr = linear_dtr, |