aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorShaohua Li <shli@fb.com>2015-08-13 17:31:56 -0400
committerNeilBrown <neilb@suse.com>2015-10-24 02:16:18 -0400
commit3069aa8def32b0c2b83cd27d1c37ed30b47ce879 (patch)
treea2e8141984b338b15a0d940f416e48177acd2801
parentbac624f3f86a8c7db395c7f85ccad6a504b9c4b4 (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.c6
-rw-r--r--drivers/md/md.h8
-rw-r--r--include/uapi/linux/raid/md_p.h5
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 */