diff options
author | Shaohua Li <shli@fb.com> | 2015-08-13 17:31:56 -0400 |
---|---|---|
committer | NeilBrown <neilb@suse.com> | 2015-10-24 02:16:18 -0400 |
commit | 3069aa8def32b0c2b83cd27d1c37ed30b47ce879 (patch) | |
tree | a2e8141984b338b15a0d940f416e48177acd2801 | |
parent | bac624f3f86a8c7db395c7f85ccad6a504b9c4b4 (diff) |
md: override md superblock recovery_offset for journal device
Journal device stores data in a log structure. We need record the log
start. Here we override md superblock recovery_offset for this purpose.
This field of a journal device is meaningless otherwise.
Signed-off-by: Shaohua Li <shli@fb.com>
Signed-off-by: NeilBrown <neilb@suse.com>
-rw-r--r-- | drivers/md/md.c | 6 | ||||
-rw-r--r-- | drivers/md/md.h | 8 | ||||
-rw-r--r-- | include/uapi/linux/raid/md_p.h | 5 |
3 files changed, 17 insertions, 2 deletions
diff --git a/drivers/md/md.c b/drivers/md/md.c index 391341a772c7..3592beb6931e 100644 --- a/drivers/md/md.c +++ b/drivers/md/md.c | |||
@@ -1646,6 +1646,7 @@ static int super_1_validate(struct mddev *mddev, struct md_rdev *rdev) | |||
1646 | return -EINVAL; | 1646 | return -EINVAL; |
1647 | } | 1647 | } |
1648 | set_bit(Journal, &rdev->flags); | 1648 | set_bit(Journal, &rdev->flags); |
1649 | rdev->journal_tail = le64_to_cpu(sb->journal_tail); | ||
1649 | break; | 1650 | break; |
1650 | default: | 1651 | default: |
1651 | rdev->saved_raid_disk = role; | 1652 | rdev->saved_raid_disk = role; |
@@ -1721,6 +1722,9 @@ static void super_1_sync(struct mddev *mddev, struct md_rdev *rdev) | |||
1721 | sb->feature_map |= | 1722 | sb->feature_map |= |
1722 | cpu_to_le32(MD_FEATURE_RECOVERY_BITMAP); | 1723 | cpu_to_le32(MD_FEATURE_RECOVERY_BITMAP); |
1723 | } | 1724 | } |
1725 | /* Note: recovery_offset and journal_tail share space */ | ||
1726 | if (test_bit(Journal, &rdev->flags)) | ||
1727 | sb->journal_tail = cpu_to_le64(rdev->journal_tail); | ||
1724 | if (test_bit(Replacement, &rdev->flags)) | 1728 | if (test_bit(Replacement, &rdev->flags)) |
1725 | sb->feature_map |= | 1729 | sb->feature_map |= |
1726 | cpu_to_le32(MD_FEATURE_REPLACEMENT); | 1730 | cpu_to_le32(MD_FEATURE_REPLACEMENT); |
@@ -8097,6 +8101,8 @@ static int remove_and_add_spares(struct mddev *mddev, | |||
8097 | continue; | 8101 | continue; |
8098 | if (test_bit(Faulty, &rdev->flags)) | 8102 | if (test_bit(Faulty, &rdev->flags)) |
8099 | continue; | 8103 | continue; |
8104 | if (test_bit(Journal, &rdev->flags)) | ||
8105 | continue; | ||
8100 | if (mddev->ro && | 8106 | if (mddev->ro && |
8101 | ! (rdev->saved_raid_disk >= 0 && | 8107 | ! (rdev->saved_raid_disk >= 0 && |
8102 | !test_bit(Bitmap_sync, &rdev->flags))) | 8108 | !test_bit(Bitmap_sync, &rdev->flags))) |
diff --git a/drivers/md/md.h b/drivers/md/md.h index 88dc6312f5d5..2b0f62fb6146 100644 --- a/drivers/md/md.h +++ b/drivers/md/md.h | |||
@@ -87,10 +87,16 @@ struct md_rdev { | |||
87 | * array and could again if we did a partial | 87 | * array and could again if we did a partial |
88 | * resync from the bitmap | 88 | * resync from the bitmap |
89 | */ | 89 | */ |
90 | sector_t recovery_offset;/* If this device has been partially | 90 | union { |
91 | sector_t recovery_offset;/* If this device has been partially | ||
91 | * recovered, this is where we were | 92 | * recovered, this is where we were |
92 | * up to. | 93 | * up to. |
93 | */ | 94 | */ |
95 | sector_t journal_tail; /* If this device is a journal device, | ||
96 | * this is the journal tail (journal | ||
97 | * recovery start point) | ||
98 | */ | ||
99 | }; | ||
94 | 100 | ||
95 | atomic_t nr_pending; /* number of pending requests. | 101 | atomic_t nr_pending; /* number of pending requests. |
96 | * only maintained for arrays that | 102 | * only maintained for arrays that |
diff --git a/include/uapi/linux/raid/md_p.h b/include/uapi/linux/raid/md_p.h index eaaab52077a3..a5f54ff26c20 100644 --- a/include/uapi/linux/raid/md_p.h +++ b/include/uapi/linux/raid/md_p.h | |||
@@ -258,7 +258,10 @@ struct mdp_superblock_1 { | |||
258 | __le64 data_offset; /* sector start of data, often 0 */ | 258 | __le64 data_offset; /* sector start of data, often 0 */ |
259 | __le64 data_size; /* sectors in this device that can be used for data */ | 259 | __le64 data_size; /* sectors in this device that can be used for data */ |
260 | __le64 super_offset; /* sector start of this superblock */ | 260 | __le64 super_offset; /* sector start of this superblock */ |
261 | __le64 recovery_offset;/* sectors before this offset (from data_offset) have been recovered */ | 261 | union { |
262 | __le64 recovery_offset;/* sectors before this offset (from data_offset) have been recovered */ | ||
263 | __le64 journal_tail;/* journal tail of journal device (from data_offset) */ | ||
264 | }; | ||
262 | __le32 dev_number; /* permanent identifier of this device - not role in raid */ | 265 | __le32 dev_number; /* permanent identifier of this device - not role in raid */ |
263 | __le32 cnt_corrected_read; /* number of read errors that were corrected by re-writing */ | 266 | __le32 cnt_corrected_read; /* number of read errors that were corrected by re-writing */ |
264 | __u8 device_uuid[16]; /* user-space setable, ignored by kernel */ | 267 | __u8 device_uuid[16]; /* user-space setable, ignored by kernel */ |