forked from pool/mdadm
138 lines
5.2 KiB
Diff
138 lines
5.2 KiB
Diff
|
From c24620685185eb7a159a8563b60a5e062b03b12e Mon Sep 17 00:00:00 2001
|
||
|
From: Pawel Baldysiak <pawel.baldysiak@intel.com>
|
||
|
Date: Thu, 28 Sep 2017 14:41:09 +0200
|
||
|
Subject: [PATCH] imsm: Add support for multiple ppls
|
||
|
Git-commit: c24620685185eb7a159a8563b60a5e062b03b12e
|
||
|
Patch-mainline: mdadm-4.0+
|
||
|
References: bsc#1069165, bsc#1069167, bsc#1068030
|
||
|
|
||
|
Add interpreting new rwh_policy bits. Set PPL size as 1MB.
|
||
|
If new array with ppl is created - use new implementation of ppl by
|
||
|
default.
|
||
|
|
||
|
Signed-off-by: Pawel Baldysiak <pawel.baldysiak@intel.com>
|
||
|
Signed-off-by: Artur Paszkiewicz <artur.paszkiewicz@intel.com>
|
||
|
Signed-off-by: Jes Sorensen <jsorensen@fb.com>
|
||
|
Signed-off-by: Coly Li <colyli@suse.de>
|
||
|
|
||
|
---
|
||
|
super-intel.c | 37 +++++++++++++++++++++++++++----------
|
||
|
1 file changed, 27 insertions(+), 10 deletions(-)
|
||
|
|
||
|
diff --git a/super-intel.c b/super-intel.c
|
||
|
index e3dcd3d..347838e 100644
|
||
|
--- a/super-intel.c
|
||
|
+++ b/super-intel.c
|
||
|
@@ -92,6 +92,9 @@
|
||
|
#define NUM_BLOCKS_DIRTY_STRIPE_REGION 2056
|
||
|
#define SECT_PER_MB_SHIFT 11
|
||
|
#define MAX_SECTOR_SIZE 4096
|
||
|
+#define MULTIPLE_PPL_AREA_SIZE_IMSM (1024 * 1024) /* Size of the whole
|
||
|
+ * mutliple PPL area
|
||
|
+ */
|
||
|
|
||
|
/* Disk configuration info. */
|
||
|
#define IMSM_MAX_DEVICES 255
|
||
|
@@ -207,6 +210,9 @@ struct imsm_dev {
|
||
|
#define RWH_OFF 0
|
||
|
#define RWH_DISTRIBUTED 1
|
||
|
#define RWH_JOURNALING_DRIVE 2
|
||
|
+#define RWH_MULTIPLE_DISTRIBUTED 3
|
||
|
+#define RWH_MULTIPLE_PPLS_JOURNALING_DRIVE 4
|
||
|
+#define RWH_MULTIPLE_OFF 5
|
||
|
__u8 rwh_policy; /* Raid Write Hole Policy */
|
||
|
__u8 jd_serial[MAX_RAID_SERIAL_LEN]; /* Journal Drive serial number */
|
||
|
__u8 filler1;
|
||
|
@@ -284,7 +290,7 @@ static char *map_state_str[] = { "normal", "uninitialized", "degraded", "failed"
|
||
|
* already been migrated and must
|
||
|
* be recovered from checkpoint area */
|
||
|
|
||
|
-#define PPL_ENTRY_SPACE (128 * 1024) /* Size of the PPL, without the header */
|
||
|
+#define PPL_ENTRY_SPACE (128 * 1024) /* Size of single PPL, without the header */
|
||
|
|
||
|
struct migr_record {
|
||
|
__u32 rec_status; /* Status used to determine how to restart
|
||
|
@@ -1539,12 +1545,16 @@ static void print_imsm_dev(struct intel_super *super,
|
||
|
printf(" Dirty State : %s\n", (dev->vol.dirty & RAIDVOL_DIRTY) ?
|
||
|
"dirty" : "clean");
|
||
|
printf(" RWH Policy : ");
|
||
|
- if (dev->rwh_policy == RWH_OFF)
|
||
|
+ if (dev->rwh_policy == RWH_OFF || dev->rwh_policy == RWH_MULTIPLE_OFF)
|
||
|
printf("off\n");
|
||
|
else if (dev->rwh_policy == RWH_DISTRIBUTED)
|
||
|
printf("PPL distributed\n");
|
||
|
else if (dev->rwh_policy == RWH_JOURNALING_DRIVE)
|
||
|
printf("PPL journaling drive\n");
|
||
|
+ else if (dev->rwh_policy == RWH_MULTIPLE_DISTRIBUTED)
|
||
|
+ printf("Multiple distributed PPLs\n");
|
||
|
+ else if (dev->rwh_policy == RWH_MULTIPLE_PPLS_JOURNALING_DRIVE)
|
||
|
+ printf("Multiple PPLs on journaling drive\n");
|
||
|
else
|
||
|
printf("<unknown:%d>\n", dev->rwh_policy);
|
||
|
}
|
||
|
@@ -3294,10 +3304,16 @@ static void getinfo_super_imsm_volume(struct supertype *st, struct mdinfo *info,
|
||
|
memset(info->uuid, 0, sizeof(info->uuid));
|
||
|
info->recovery_start = MaxSector;
|
||
|
|
||
|
- if (info->array.level == 5 && dev->rwh_policy == RWH_DISTRIBUTED) {
|
||
|
+ if (info->array.level == 5 &&
|
||
|
+ (dev->rwh_policy == RWH_DISTRIBUTED ||
|
||
|
+ dev->rwh_policy == RWH_MULTIPLE_DISTRIBUTED)) {
|
||
|
info->consistency_policy = CONSISTENCY_POLICY_PPL;
|
||
|
info->ppl_sector = get_ppl_sector(super, super->current_vol);
|
||
|
- info->ppl_size = (PPL_HEADER_SIZE + PPL_ENTRY_SPACE) >> 9;
|
||
|
+ if (dev->rwh_policy == RWH_MULTIPLE_DISTRIBUTED)
|
||
|
+ info->ppl_size = MULTIPLE_PPL_AREA_SIZE_IMSM >> 9;
|
||
|
+ else
|
||
|
+ info->ppl_size = (PPL_HEADER_SIZE + PPL_ENTRY_SPACE)
|
||
|
+ >> 9;
|
||
|
} else if (info->array.level <= 0) {
|
||
|
info->consistency_policy = CONSISTENCY_POLICY_NONE;
|
||
|
} else {
|
||
|
@@ -5390,9 +5406,9 @@ static int init_super_imsm_volume(struct supertype *st, mdu_array_info_t *info,
|
||
|
dev->my_vol_raid_dev_num = mpb->num_raid_devs_created;
|
||
|
|
||
|
if (s->consistency_policy <= CONSISTENCY_POLICY_RESYNC) {
|
||
|
- dev->rwh_policy = RWH_OFF;
|
||
|
+ dev->rwh_policy = RWH_MULTIPLE_OFF;
|
||
|
} else if (s->consistency_policy == CONSISTENCY_POLICY_PPL) {
|
||
|
- dev->rwh_policy = RWH_DISTRIBUTED;
|
||
|
+ dev->rwh_policy = RWH_MULTIPLE_DISTRIBUTED;
|
||
|
} else {
|
||
|
free(dev);
|
||
|
free(dv);
|
||
|
@@ -7403,9 +7419,9 @@ static int update_subarray_imsm(struct supertype *st, char *subarray,
|
||
|
return 2;
|
||
|
|
||
|
if (strcmp(update, "ppl") == 0)
|
||
|
- new_policy = RWH_DISTRIBUTED;
|
||
|
+ new_policy = RWH_MULTIPLE_DISTRIBUTED;
|
||
|
else
|
||
|
- new_policy = RWH_OFF;
|
||
|
+ new_policy = RWH_MULTIPLE_OFF;
|
||
|
|
||
|
if (st->update_tail) {
|
||
|
struct imsm_update_rwh_policy *u = xmalloc(sizeof(*u));
|
||
|
@@ -8205,7 +8221,8 @@ skip_mark_checkpoint:
|
||
|
dev->vol.dirty = RAIDVOL_CLEAN;
|
||
|
} else {
|
||
|
dev->vol.dirty = RAIDVOL_DIRTY;
|
||
|
- if (dev->rwh_policy == RWH_DISTRIBUTED)
|
||
|
+ if (dev->rwh_policy == RWH_DISTRIBUTED ||
|
||
|
+ dev->rwh_policy == RWH_MULTIPLE_DISTRIBUTED)
|
||
|
dev->vol.dirty |= RAIDVOL_DSRECORD_VALID;
|
||
|
}
|
||
|
super->updates_pending++;
|
||
|
@@ -8759,7 +8776,7 @@ static struct mdinfo *imsm_activate_spare(struct active_array *a,
|
||
|
di->bb.supported = 1;
|
||
|
if (a->info.consistency_policy == CONSISTENCY_POLICY_PPL) {
|
||
|
di->ppl_sector = get_ppl_sector(super, inst);
|
||
|
- di->ppl_size = (PPL_HEADER_SIZE + PPL_ENTRY_SPACE) >> 9;
|
||
|
+ di->ppl_size = MULTIPLE_PPL_AREA_SIZE_IMSM >> 9;
|
||
|
}
|
||
|
super->random = random32();
|
||
|
di->next = rv;
|
||
|
--
|
||
|
2.13.6
|
||
|
|