diff options
author | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-24 12:28:01 -0400 |
---|---|---|
committer | Linus Torvalds <torvalds@linux-foundation.org> | 2015-04-24 12:28:01 -0400 |
commit | 474095e46cd14421821da3201a9fd6a4c070996b (patch) | |
tree | 7203d36f53c376a96099ed0310787b1fb0c4f7a5 /include | |
parent | d56a669ca59c37ed0a7282a251b2f2f22533343a (diff) | |
parent | 9ffc8f7cb9647b13dfe4d1ad0d5e1427bb8b46d6 (diff) |
Merge tag 'md/4.1' of git://neil.brown.name/md
Pull md updates from Neil Brown:
"More updates that usual this time. A few have performance impacts
which hould mostly be positive, but RAID5 (in particular) can be very
work-load ensitive... We'll have to wait and see.
Highlights:
- "experimental" code for managing md/raid1 across a cluster using
DLM. Code is not ready for general use and triggers a WARNING if
used. However it is looking good and mostly done and having in
mainline will help co-ordinate development.
- RAID5/6 can now batch multiple (4K wide) stripe_heads so as to
handle a full (chunk wide) stripe as a single unit.
- RAID6 can now perform read-modify-write cycles which should help
performance on larger arrays: 6 or more devices.
- RAID5/6 stripe cache now grows and shrinks dynamically. The value
set is used as a minimum.
- Resync is now allowed to go a little faster than the 'mininum' when
there is competing IO. How much faster depends on the speed of the
devices, so the effective minimum should scale with device speed to
some extent"
* tag 'md/4.1' of git://neil.brown.name/md: (58 commits)
md/raid5: don't do chunk aligned read on degraded array.
md/raid5: allow the stripe_cache to grow and shrink.
md/raid5: change ->inactive_blocked to a bit-flag.
md/raid5: move max_nr_stripes management into grow_one_stripe and drop_one_stripe
md/raid5: pass gfp_t arg to grow_one_stripe()
md/raid5: introduce configuration option rmw_level
md/raid5: activate raid6 rmw feature
md/raid6 algorithms: xor_syndrome() for SSE2
md/raid6 algorithms: xor_syndrome() for generic int
md/raid6 algorithms: improve test program
md/raid6 algorithms: delta syndrome functions
raid5: handle expansion/resync case with stripe batching
raid5: handle io error of batch list
RAID5: batch adjacent full stripe write
raid5: track overwrite disk count
raid5: add a new flag to track if a stripe can be batched
raid5: use flex_array for scribble data
md raid0: access mddev->queue (request queue member) conditionally because it is not set when accessed from dm-raid
md: allow resync to go faster when there is competing IO.
md: remove 'go_faster' option from ->sync_request()
...
Diffstat (limited to 'include')
-rw-r--r-- | include/linux/async_tx.h | 3 | ||||
-rw-r--r-- | include/linux/raid/pq.h | 1 | ||||
-rw-r--r-- | include/uapi/linux/raid/md_p.h | 7 | ||||
-rw-r--r-- | include/uapi/linux/raid/md_u.h | 1 |
4 files changed, 12 insertions, 0 deletions
diff --git a/include/linux/async_tx.h b/include/linux/async_tx.h index 179b38ffd351..388574ea38ed 100644 --- a/include/linux/async_tx.h +++ b/include/linux/async_tx.h | |||
@@ -60,12 +60,15 @@ struct dma_chan_ref { | |||
60 | * dependency chain | 60 | * dependency chain |
61 | * @ASYNC_TX_FENCE: specify that the next operation in the dependency | 61 | * @ASYNC_TX_FENCE: specify that the next operation in the dependency |
62 | * chain uses this operation's result as an input | 62 | * chain uses this operation's result as an input |
63 | * @ASYNC_TX_PQ_XOR_DST: do not overwrite the syndrome but XOR it with the | ||
64 | * input data. Required for rmw case. | ||
63 | */ | 65 | */ |
64 | enum async_tx_flags { | 66 | enum async_tx_flags { |
65 | ASYNC_TX_XOR_ZERO_DST = (1 << 0), | 67 | ASYNC_TX_XOR_ZERO_DST = (1 << 0), |
66 | ASYNC_TX_XOR_DROP_DST = (1 << 1), | 68 | ASYNC_TX_XOR_DROP_DST = (1 << 1), |
67 | ASYNC_TX_ACK = (1 << 2), | 69 | ASYNC_TX_ACK = (1 << 2), |
68 | ASYNC_TX_FENCE = (1 << 3), | 70 | ASYNC_TX_FENCE = (1 << 3), |
71 | ASYNC_TX_PQ_XOR_DST = (1 << 4), | ||
69 | }; | 72 | }; |
70 | 73 | ||
71 | /** | 74 | /** |
diff --git a/include/linux/raid/pq.h b/include/linux/raid/pq.h index 73069cb6c54a..a7a06d1dcf9c 100644 --- a/include/linux/raid/pq.h +++ b/include/linux/raid/pq.h | |||
@@ -72,6 +72,7 @@ extern const char raid6_empty_zero_page[PAGE_SIZE]; | |||
72 | /* Routine choices */ | 72 | /* Routine choices */ |
73 | struct raid6_calls { | 73 | struct raid6_calls { |
74 | void (*gen_syndrome)(int, size_t, void **); | 74 | void (*gen_syndrome)(int, size_t, void **); |
75 | void (*xor_syndrome)(int, int, int, size_t, void **); | ||
75 | int (*valid)(void); /* Returns 1 if this routine set is usable */ | 76 | int (*valid)(void); /* Returns 1 if this routine set is usable */ |
76 | const char *name; /* Name of this routine set */ | 77 | const char *name; /* Name of this routine set */ |
77 | int prefer; /* Has special performance attribute */ | 78 | int prefer; /* Has special performance attribute */ |
diff --git a/include/uapi/linux/raid/md_p.h b/include/uapi/linux/raid/md_p.h index 49f4210d4394..2ae6131e69a5 100644 --- a/include/uapi/linux/raid/md_p.h +++ b/include/uapi/linux/raid/md_p.h | |||
@@ -78,6 +78,12 @@ | |||
78 | #define MD_DISK_ACTIVE 1 /* disk is running or spare disk */ | 78 | #define MD_DISK_ACTIVE 1 /* disk is running or spare disk */ |
79 | #define MD_DISK_SYNC 2 /* disk is in sync with the raid set */ | 79 | #define MD_DISK_SYNC 2 /* disk is in sync with the raid set */ |
80 | #define MD_DISK_REMOVED 3 /* disk is in sync with the raid set */ | 80 | #define MD_DISK_REMOVED 3 /* disk is in sync with the raid set */ |
81 | #define MD_DISK_CLUSTER_ADD 4 /* Initiate a disk add across the cluster | ||
82 | * For clustered enviroments only. | ||
83 | */ | ||
84 | #define MD_DISK_CANDIDATE 5 /* disk is added as spare (local) until confirmed | ||
85 | * For clustered enviroments only. | ||
86 | */ | ||
81 | 87 | ||
82 | #define MD_DISK_WRITEMOSTLY 9 /* disk is "write-mostly" is RAID1 config. | 88 | #define MD_DISK_WRITEMOSTLY 9 /* disk is "write-mostly" is RAID1 config. |
83 | * read requests will only be sent here in | 89 | * read requests will only be sent here in |
@@ -101,6 +107,7 @@ typedef struct mdp_device_descriptor_s { | |||
101 | #define MD_SB_CLEAN 0 | 107 | #define MD_SB_CLEAN 0 |
102 | #define MD_SB_ERRORS 1 | 108 | #define MD_SB_ERRORS 1 |
103 | 109 | ||
110 | #define MD_SB_CLUSTERED 5 /* MD is clustered */ | ||
104 | #define MD_SB_BITMAP_PRESENT 8 /* bitmap may be present nearby */ | 111 | #define MD_SB_BITMAP_PRESENT 8 /* bitmap may be present nearby */ |
105 | 112 | ||
106 | /* | 113 | /* |
diff --git a/include/uapi/linux/raid/md_u.h b/include/uapi/linux/raid/md_u.h index 74e7c60c4716..1cb8aa6850b5 100644 --- a/include/uapi/linux/raid/md_u.h +++ b/include/uapi/linux/raid/md_u.h | |||
@@ -62,6 +62,7 @@ | |||
62 | #define STOP_ARRAY _IO (MD_MAJOR, 0x32) | 62 | #define STOP_ARRAY _IO (MD_MAJOR, 0x32) |
63 | #define STOP_ARRAY_RO _IO (MD_MAJOR, 0x33) | 63 | #define STOP_ARRAY_RO _IO (MD_MAJOR, 0x33) |
64 | #define RESTART_ARRAY_RW _IO (MD_MAJOR, 0x34) | 64 | #define RESTART_ARRAY_RW _IO (MD_MAJOR, 0x34) |
65 | #define CLUSTERED_DISK_NACK _IO (MD_MAJOR, 0x35) | ||
65 | 66 | ||
66 | /* 63 partitions with the alternate major number (mdp) */ | 67 | /* 63 partitions with the alternate major number (mdp) */ |
67 | #define MdpMinorShift 6 | 68 | #define MdpMinorShift 6 |