]> git.ipfire.org Git - thirdparty/kernel/linux.git/commitdiff
md: merge mddev faillast_dev into mddev_flags
authorYu Kuai <yukuai@fnnas.com>
Wed, 14 Jan 2026 17:12:31 +0000 (01:12 +0800)
committerYu Kuai <yukuai@fnnas.com>
Mon, 26 Jan 2026 05:10:24 +0000 (13:10 +0800)
There is not need to use a separate field in struct mddev, there are no
functional changes.

Link: https://lore.kernel.org/linux-raid/20260114171241.3043364-4-yukuai@fnnas.com
Signed-off-by: Yu Kuai <yukuai@fnnas.com>
Reviewed-by: Li Nan <linan122@huawei.com>
drivers/md/md.c
drivers/md/md.h
drivers/md/raid0.c
drivers/md/raid1.c
drivers/md/raid10.c
drivers/md/raid5.c

index bf7666e227a146da17cfabac0841ef3be504ad5d..b955eba7f461baa57aaa06f69560f79ad00ff1c5 100644 (file)
@@ -5864,11 +5864,11 @@ __ATTR(consistency_policy, S_IRUGO | S_IWUSR, consistency_policy_show,
 
 static ssize_t fail_last_dev_show(struct mddev *mddev, char *page)
 {
-       return sprintf(page, "%d\n", mddev->fail_last_dev);
+       return sprintf(page, "%d\n", test_bit(MD_FAILLAST_DEV, &mddev->flags));
 }
 
 /*
- * Setting fail_last_dev to true to allow last device to be forcibly removed
+ * Setting MD_FAILLAST_DEV to allow last device to be forcibly removed
  * from RAID1/RAID10.
  */
 static ssize_t
@@ -5881,8 +5881,10 @@ fail_last_dev_store(struct mddev *mddev, const char *buf, size_t len)
        if (ret)
                return ret;
 
-       if (value != mddev->fail_last_dev)
-               mddev->fail_last_dev = value;
+       if (value)
+               set_bit(MD_FAILLAST_DEV, &mddev->flags);
+       else
+               clear_bit(MD_FAILLAST_DEV, &mddev->flags);
 
        return len;
 }
index b4c9aa600edd9fdb04b671d816e651dc5f34bf9b..297a104fba887a82eba8cca4be03cc250e720714 100644 (file)
@@ -341,6 +341,7 @@ struct md_cluster_operations;
  * @MD_BROKEN: This is used to stop writes and mark array as failed.
  * @MD_DELETED: This device is being deleted
  * @MD_HAS_SUPERBLOCK: There is persistence sb in member disks.
+ * @MD_FAILLAST_DEV: Allow last rdev to be removed.
  *
  * change UNSUPPORTED_MDDEV_FLAGS for each array type if new flag is added
  */
@@ -358,6 +359,7 @@ enum mddev_flags {
        MD_DO_DELETE,
        MD_DELETED,
        MD_HAS_SUPERBLOCK,
+       MD_FAILLAST_DEV,
 };
 
 enum mddev_sb_flags {
@@ -625,7 +627,6 @@ struct mddev {
        /* The sequence number for sync thread */
        atomic_t sync_seq;
 
-       bool    fail_last_dev:1;
        bool    serialize_policy:1;
 };
 
index 985c377356ebd27b22197a22fff2157252282239..4d567fcf6a7ca7ff28338e2dafb6592cc745727c 100644 (file)
@@ -27,7 +27,8 @@ module_param(default_layout, int, 0644);
         (1L << MD_JOURNAL_CLEAN) |     \
         (1L << MD_FAILFAST_SUPPORTED) |\
         (1L << MD_HAS_PPL) |           \
-        (1L << MD_HAS_MULTIPLE_PPLS))
+        (1L << MD_HAS_MULTIPLE_PPLS) | \
+        (1L << MD_FAILLAST_DEV))
 
 /*
  * inform the user of the raid configuration
index 57d50465eed1b76ca29f596ddc432ba02783302e..98b5c93810bb93b9c0598d9911cdb0f9948d0885 100644 (file)
@@ -1746,7 +1746,7 @@ static void raid1_status(struct seq_file *seq, struct mddev *mddev)
  *     - &mddev->degraded is bumped.
  *
  * @rdev is marked as &Faulty excluding case when array is failed and
- * &mddev->fail_last_dev is off.
+ * MD_FAILLAST_DEV is not set.
  */
 static void raid1_error(struct mddev *mddev, struct md_rdev *rdev)
 {
@@ -1759,7 +1759,7 @@ static void raid1_error(struct mddev *mddev, struct md_rdev *rdev)
            (conf->raid_disks - mddev->degraded) == 1) {
                set_bit(MD_BROKEN, &mddev->flags);
 
-               if (!mddev->fail_last_dev) {
+               if (!test_bit(MD_FAILLAST_DEV, &mddev->flags)) {
                        conf->recovery_disabled = mddev->recovery_disabled;
                        spin_unlock_irqrestore(&conf->device_lock, flags);
                        return;
index 84be4cc7e87399ecb3b686301c630b25d4d58ee7..09328e032f14a4b612992607575a39f297f4c87c 100644 (file)
@@ -1990,7 +1990,7 @@ static int enough(struct r10conf *conf, int ignore)
  *     - &mddev->degraded is bumped.
  *
  * @rdev is marked as &Faulty excluding case when array is failed and
- * &mddev->fail_last_dev is off.
+ * MD_FAILLAST_DEV is not set.
  */
 static void raid10_error(struct mddev *mddev, struct md_rdev *rdev)
 {
@@ -2002,7 +2002,7 @@ static void raid10_error(struct mddev *mddev, struct md_rdev *rdev)
        if (test_bit(In_sync, &rdev->flags) && !enough(conf, rdev->raid_disk)) {
                set_bit(MD_BROKEN, &mddev->flags);
 
-               if (!mddev->fail_last_dev) {
+               if (!test_bit(MD_FAILLAST_DEV, &mddev->flags)) {
                        spin_unlock_irqrestore(&conf->device_lock, flags);
                        return;
                }
index a85878b009f9a403ff69b35d225b5a52eddc9fac..055293e56a7e2c9f95a21d1d8d185673f043bf24 100644 (file)
 #include "md-bitmap.h"
 #include "raid5-log.h"
 
-#define UNSUPPORTED_MDDEV_FLAGS        (1L << MD_FAILFAST_SUPPORTED)
+#define UNSUPPORTED_MDDEV_FLAGS                \
+       ((1L << MD_FAILFAST_SUPPORTED) |        \
+        (1L << MD_FAILLAST_DEV))
+
 
 #define cpu_to_group(cpu) cpu_to_node(cpu)
 #define ANY_GROUP NUMA_NO_NODE