1
0
mirror of git://sourceware.org/git/lvm2.git synced 2025-01-04 09:18:36 +03:00

device_id: ignore leading and trailing spaces for sys_wwid and sys_serial

Leading and trailing underscores are also ignored to handle device ids
written by previous versions which replaced all spaces with underscores.
This commit is contained in:
David Teigland 2023-06-15 13:58:48 -05:00
parent f0b48a23d9
commit 228a8e8c1f
4 changed files with 313 additions and 119 deletions

View File

@ -239,6 +239,7 @@ int dev_mpath_init(const char *config_wwids_file);
void dev_mpath_exit(void); void dev_mpath_exit(void);
int parse_vpd_ids(const unsigned char *vpd_data, int vpd_datalen, struct dm_list *ids); int parse_vpd_ids(const unsigned char *vpd_data, int vpd_datalen, struct dm_list *ids);
int format_t10_id(const unsigned char *in, int in_bytes, unsigned char *out, int out_bytes); int format_t10_id(const unsigned char *in, int in_bytes, unsigned char *out, int out_bytes);
int format_general_id(const char *in, int in_bytes, unsigned char *out, int out_bytes);
int parse_vpd_serial(const unsigned char *in, char *out, int outsize); int parse_vpd_serial(const unsigned char *in, char *out, int outsize);
/* dev_util */ /* dev_util */

View File

@ -185,6 +185,71 @@ void free_dids(struct dm_list *ids)
} }
} }
/* More than one _ in a row is replaced with one _ */
static void _reduce_repeating_underscores(char *buf, int bufsize)
{
char *tmpbuf;
int us = 0, i, j = 0;
if (!(tmpbuf = strndup(buf, bufsize-1)))
return;
memset(buf, 0, bufsize);
for (i = 0; i < strlen(tmpbuf); i++) {
if (tmpbuf[i] == '_')
us++;
else
us = 0;
if (us == 1)
buf[j++] = '_';
else if (us > 1)
continue;
else
buf[j++] = tmpbuf[i];
if (j == bufsize)
break;
}
buf[bufsize-1] = '\0';
free(tmpbuf);
}
static void _remove_leading_underscores(char *buf, int bufsize)
{
char *tmpbuf;
int i, j = 0;
if (buf[0] != '_')
return;
if (!(tmpbuf = strndup(buf, bufsize-1)))
return;
memset(buf, 0, bufsize);
for (i = 0; i < strlen(tmpbuf); i++) {
if (!j && tmpbuf[i] == '_')
continue;
buf[j++] = tmpbuf[i];
if (j == bufsize)
break;
}
free(tmpbuf);
}
static void _remove_trailing_underscores(char *buf, int bufsize)
{
char *end;
end = buf + strlen(buf) - 1;
while ((end > buf) && (*end == '_'))
end--;
end[1] = '\0';
}
static int _read_sys_block(struct cmd_context *cmd, struct device *dev, static int _read_sys_block(struct cmd_context *cmd, struct device *dev,
const char *suffix, char *sysbuf, int sysbufsize, const char *suffix, char *sysbuf, int sysbufsize,
int binary, int *retlen) int binary, int *retlen)
@ -406,7 +471,7 @@ struct dev_wwid *dev_add_wwid(char *id, int id_type, struct dm_list *ids)
int dev_read_vpd_wwids(struct cmd_context *cmd, struct device *dev) int dev_read_vpd_wwids(struct cmd_context *cmd, struct device *dev)
{ {
unsigned char vpd_data[VPD_SIZE] = { 0 }; char vpd_data[VPD_SIZE] = { 0 };
int vpd_datalen = 0; int vpd_datalen = 0;
dev->flags |= DEV_ADDED_VPD_WWIDS; dev->flags |= DEV_ADDED_VPD_WWIDS;
@ -417,36 +482,47 @@ int dev_read_vpd_wwids(struct cmd_context *cmd, struct device *dev)
return 0; return 0;
/* adds dev_wwid entry to dev->wwids for each id in vpd data */ /* adds dev_wwid entry to dev->wwids for each id in vpd data */
parse_vpd_ids(vpd_data, vpd_datalen, &dev->wwids); parse_vpd_ids((const unsigned char *)vpd_data, vpd_datalen, &dev->wwids);
return 1; return 1;
} }
int dev_read_sys_wwid(struct cmd_context *cmd, struct device *dev, int dev_read_sys_wwid(struct cmd_context *cmd, struct device *dev,
char *buf, int bufsize, struct dev_wwid **dw_out) char *outbuf, int outbufsize, struct dev_wwid **dw_out)
{ {
char tmpbuf[DEV_WWID_SIZE]; char buf[DEV_WWID_SIZE] = { 0 };
struct dev_wwid *dw; struct dev_wwid *dw;
int ret; int is_t10 = 0;
int i, ret;
dev->flags |= DEV_ADDED_SYS_WWID; dev->flags |= DEV_ADDED_SYS_WWID;
ret = read_sys_block(cmd, dev, "device/wwid", buf, bufsize); ret = read_sys_block(cmd, dev, "device/wwid", buf, sizeof(buf));
if (!ret || !buf[0]) { if (!ret || !buf[0]) {
/* the wwid file is not under device for nvme devs */ /* the wwid file is not under device for nvme devs */
ret = read_sys_block(cmd, dev, "wwid", buf, bufsize); ret = read_sys_block(cmd, dev, "wwid", buf, sizeof(buf));
} }
if (!ret || !buf[0]) if (!ret || !buf[0])
return 0; return 0;
/* in t10 id, replace characters like space and quote */ for (i = 0; i < sizeof(buf) - 4; i++) {
if (!strncmp(buf, "t10.", 4)) { if (buf[i] == ' ')
if (bufsize < DEV_WWID_SIZE) continue;
return 0; if (!strncmp(&buf[i], "t10", 3))
memcpy(tmpbuf, buf, DEV_WWID_SIZE); is_t10 = 1;
memset(buf, 0, bufsize); break;
format_t10_id((const unsigned char *)tmpbuf, DEV_WWID_SIZE, (unsigned char *)buf, bufsize);
} }
/*
* Remove leading and trailing spaces.
* Replace internal spaces with underscores.
* t10 wwids have multiple sequential spaces
* replaced by a single underscore.
*/
if (is_t10)
format_t10_id((const unsigned char *)buf, sizeof(buf), (unsigned char *)outbuf, outbufsize);
else
format_general_id((const char *)buf, sizeof(buf), (unsigned char *)outbuf, outbufsize);
/* Note, if wwids are also read from vpd, this same wwid will be added again. */ /* Note, if wwids are also read from vpd, this same wwid will be added again. */
if (!(dw = dev_add_wwid(buf, 0, &dev->wwids))) if (!(dw = dev_add_wwid(buf, 0, &dev->wwids)))
@ -457,9 +533,9 @@ int dev_read_sys_wwid(struct cmd_context *cmd, struct device *dev,
} }
static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev, static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev,
char *buf, int bufsize) char *outbuf, int outbufsize)
{ {
unsigned char vpd_data[VPD_SIZE] = { 0 }; char buf[VPD_SIZE] = { 0 };
const char *devname; const char *devname;
int vpd_datalen = 0; int vpd_datalen = 0;
@ -471,13 +547,16 @@ static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev,
* (Only virtio disks /dev/vdx are known to use /sys/class/block/vdx/serial.) * (Only virtio disks /dev/vdx are known to use /sys/class/block/vdx/serial.)
*/ */
read_sys_block(cmd, dev, "device/serial", buf, bufsize); read_sys_block(cmd, dev, "device/serial", buf, sizeof(buf));
if (buf[0]) if (buf[0]) {
format_general_id((const char *)buf, sizeof(buf), (unsigned char *)outbuf, outbufsize);
if (outbuf[0])
return 1; return 1;
}
if (read_sys_block_binary(cmd, dev, "device/vpd_pg80", (char *)vpd_data, VPD_SIZE, &vpd_datalen) && vpd_datalen) { if (read_sys_block_binary(cmd, dev, "device/vpd_pg80", buf, VPD_SIZE, &vpd_datalen) && vpd_datalen) {
parse_vpd_serial(vpd_data, buf, bufsize); parse_vpd_serial((const unsigned char *)buf, outbuf, outbufsize);
if (buf[0]) if (outbuf[0])
return 1; return 1;
} }
@ -505,11 +584,12 @@ static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev,
if (dm_snprintf(path, sizeof(path), "%s/class/block/%s/serial", sysfs_dir, vdx) < 0) if (dm_snprintf(path, sizeof(path), "%s/class/block/%s/serial", sysfs_dir, vdx) < 0)
return 0; return 0;
ret = get_sysfs_value(path, buf, bufsize, 0); ret = get_sysfs_value(path, buf, sizeof(buf), 0);
if (ret && !buf[0]) if (ret && !buf[0])
ret = 0; ret = 0;
if (ret) { if (ret) {
buf[bufsize - 1] = '\0'; format_general_id((const char *)buf, sizeof(buf), (unsigned char *)outbuf, outbufsize);
if (buf[0])
return 1; return 1;
} }
} }
@ -520,6 +600,7 @@ static int _dev_read_sys_serial(struct cmd_context *cmd, struct device *dev,
const char *device_id_system_read(struct cmd_context *cmd, struct device *dev, uint16_t idtype) const char *device_id_system_read(struct cmd_context *cmd, struct device *dev, uint16_t idtype)
{ {
char sysbuf[PATH_MAX] = { 0 }; char sysbuf[PATH_MAX] = { 0 };
char sysbuf2[PATH_MAX] = { 0 };
const char *idname = NULL; const char *idname = NULL;
struct dev_wwid *dw; struct dev_wwid *dw;
int i; int i;
@ -584,16 +665,45 @@ const char *device_id_system_read(struct cmd_context *cmd, struct device *dev, u
return NULL; return NULL;
} }
/* wwids are already munged if needed */ /*
if (idtype != DEV_ID_TYPE_SYS_WWID) { * Replace all spaces, quotes, control chars with underscores.
* sys_wwid, sys_serial, and wwid_* have already been handled,
* and with slightly different replacement (see format_t10_id,
* format_general_id.)
*/
if ((idtype != DEV_ID_TYPE_SYS_WWID) &&
(idtype != DEV_ID_TYPE_SYS_SERIAL) &&
(idtype != DEV_ID_TYPE_WWID_NAA) &&
(idtype != DEV_ID_TYPE_WWID_EUI) &&
(idtype != DEV_ID_TYPE_WWID_T10)) {
for (i = 0; i < strlen(sysbuf); i++) { for (i = 0; i < strlen(sysbuf); i++) {
if (sysbuf[i] == '"') if ((sysbuf[i] == '"') ||
continue; isblank(sysbuf[i]) ||
if (isblank(sysbuf[i]) || isspace(sysbuf[i]) || iscntrl(sysbuf[i])) isspace(sysbuf[i]) ||
iscntrl(sysbuf[i]))
sysbuf[i] = '_'; sysbuf[i] = '_';
} }
} }
/*
* Reduce actual leading and trailing underscores for sys_wwid
* and sys_serial, since underscores were previously used as
* replacements for leading/trailing spaces which are now ignored.
* Also reduce any actual repeated underscores in t10 wwid since
* multiple repeated spaces were also once replaced by underscores.
*/
if ((idtype == DEV_ID_TYPE_SYS_WWID) ||
(idtype == DEV_ID_TYPE_SYS_SERIAL)) {
memcpy(sysbuf2, sysbuf, sizeof(sysbuf2));
_remove_leading_underscores(sysbuf2, sizeof(sysbuf2));
_remove_trailing_underscores(sysbuf2, sizeof(sysbuf2));
if (idtype == DEV_ID_TYPE_SYS_WWID && !strncmp(sysbuf2, "t10", 3) && strstr(sysbuf2, "__"))
_reduce_repeating_underscores(sysbuf2, sizeof(sysbuf2));
if (memcmp(sysbuf, sysbuf2, sizeof(sysbuf)))
log_debug("device_id_system_read reduced underscores %s to %s", sysbuf, sysbuf2);
memcpy(sysbuf, sysbuf2, sizeof(sysbuf));
}
if (!sysbuf[0]) if (!sysbuf[0])
goto bad; goto bad;
@ -1728,40 +1838,6 @@ static int _match_dm_devnames(struct cmd_context *cmd, struct device *dev,
return 0; return 0;
} }
/* More than one _ in a row is replaced with one _ */
static void _reduce_repeating_underscores(char *in, int in_len, char *out, int out_size)
{
int us = 0, i, j = 0;
for (i = 0; i < in_len; i++) {
if (in[i] == '_')
us++;
else
us = 0;
if (us == 1)
out[j++] = '_';
else if (us > 1)
continue;
else
out[j++] = in[i];
if (j == out_size)
break;
}
}
/* Remove any _ at the end of the string. */
static void _remove_trailing_underscores(char *buf)
{
char *end;
end = buf + strlen(buf) - 1;
while ((end > buf) && (*end == '_'))
end--;
end[1] = '\0';
}
/* /*
* du is a devices file entry. dev is any device on the system. * du is a devices file entry. dev is any device on the system.
* check if du is for dev by comparing the device's ids to du->idname. * check if du is for dev by comparing the device's ids to du->idname.
@ -1775,8 +1851,7 @@ static void _remove_trailing_underscores(char *buf)
static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct device *dev) static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct device *dev)
{ {
char du_t10[DEV_WWID_SIZE] = { 0 }; char du_idname[PATH_MAX];
char id_t10[DEV_WWID_SIZE];
struct dev_id *id; struct dev_id *id;
const char *idname; const char *idname;
int part; int part;
@ -1827,20 +1902,30 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
} }
/* /*
* Devices file entries with IDTYPE=sys_wwid and a T10 WWID * sys_wwid and sys_serial were saved in the past with leading and
* for IDNAME were saved in the past with each space replaced * trailing spaces replaced with underscores, and t10 wwids also had
* by one _. Now we convert multiple spaces to a single _. * repeated internal spaces replaced with one underscore each. Now we
* So, convert a df entry with the old style to the new shorter * ignore leading and trailing spaces and replace multiple repeated
* style to compare. Also, in past versions, trailing spaces * spaces with one underscore in t10 wwids. In order to handle
* in the wwid would be replaced by _, but now trailing spaces * system.devices entries created by older versions, modify the IDNAME
* are ignored. This means devices file entries created by * value that's read (du->idname) to remove leading and trailing
* past versions may have _ at the end of the IDNAME string. * underscores, and reduce repeated underscores to one in t10 wwids.
* So, exclude trailing underscores when comparing a t10 wwid *
* from a device with a t10 wwid in the devices file. * Example: wwid is reported as " t10.123 456 " (without quotes)
* Previous versions would save this in system.devices as: __t10.123__456__
* Current versions will save this in system.devices as: t10.123_456
* device_id_system_read() now returns: t10.123_456
* When this code reads __t10.123__456__ from system.devices, that
* string is modified to t10.123_456 so that it will match the value
* returned from device_id_system_read().
*/ */
if (du->idtype == DEV_ID_TYPE_SYS_WWID && !strncmp(du->idname, "t10", 3) && strchr(du->idname, '_')) { strncpy(du_idname, du->idname, PATH_MAX-1);
_reduce_repeating_underscores(du->idname, strlen(du->idname), du_t10, sizeof(du_t10) - 1); if (((du->idtype == DEV_ID_TYPE_SYS_WWID) || (du->idtype == DEV_ID_TYPE_SYS_SERIAL)) &&
_remove_trailing_underscores(du_t10); strchr(du_idname, '_')) {
_remove_leading_underscores(du_idname, sizeof(du_idname));
_remove_trailing_underscores(du_idname, sizeof(du_idname));
if (du->idtype == DEV_ID_TYPE_SYS_WWID && !strncmp(du_idname, "t10", 3) && strstr(du_idname, "__"))
_reduce_repeating_underscores(du_idname, sizeof(du_idname));
} }
/* /*
@ -1848,21 +1933,14 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
* (and saved on dev->ids to avoid rereading.) * (and saved on dev->ids to avoid rereading.)
*/ */
dm_list_iterate_items(id, &dev->ids) { dm_list_iterate_items(id, &dev->ids) {
if (!id->idname)
continue;
if (id->idtype == du->idtype) { if (id->idtype == du->idtype) {
/* /*
* For t10 wwids, remove actual trailing underscores from the dev wwid * dm names can have different forms, so matching names
* (in id->idname), because all trailing underscores were removed from * is not always a direct comparison.
* the du->idname read from the devices file. i.e. no trailing _ are
* used in t10 wwid comparisons.
*/ */
if ((id->idtype == DEV_ID_TYPE_SYS_WWID) &&
id->idname && !strncmp(id->idname, "t10", 3) && du_t10[0]) {
memset(id_t10, 0, sizeof(id_t10));
strncpy(id_t10, id->idname, DEV_WWID_SIZE-1);
_remove_trailing_underscores(id_t10);
}
if ((id->idtype == DEV_ID_TYPE_DEVNAME) && _match_dm_devnames(cmd, dev, id, du)) { if ((id->idtype == DEV_ID_TYPE_DEVNAME) && _match_dm_devnames(cmd, dev, id, du)) {
/* dm devs can have differing names that we know still match */ /* dm devs can have differing names that we know still match */
du->dev = dev; du->dev = dev;
@ -1871,22 +1949,16 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
log_debug("Match device_id %s %s to %s: dm names", log_debug("Match device_id %s %s to %s: dm names",
idtype_to_str(du->idtype), du->idname, dev_name(dev)); idtype_to_str(du->idtype), du->idname, dev_name(dev));
return 1; return 1;
}
} else if (id->idname && !strcmp(id->idname, du->idname)) { if (!strcmp(id->idname, du_idname)) {
du->dev = dev; du->dev = dev;
dev->id = id; dev->id = id;
dev->flags |= DEV_MATCHED_USE_ID; dev->flags |= DEV_MATCHED_USE_ID;
log_debug("Match device_id %s %s to %s", log_debug("Match device_id %s %s to %s",
idtype_to_str(du->idtype), du->idname, dev_name(dev)); idtype_to_str(du->idtype), du_idname, dev_name(dev));
return 1; return 1;
} else if ((id->idtype == DEV_ID_TYPE_SYS_WWID) && du_t10[0] && id_t10[0] && !strcmp(id_t10, du_t10)) {
du->dev = dev;
dev->id = id;
dev->flags |= DEV_MATCHED_USE_ID;
log_debug("Match device_id %s %s to %s",
idtype_to_str(du->idtype), du->idname, dev_name(dev));
return 1;
} else { } else {
/* /*
log_debug("Mismatch device_id %s %s to %s: idname %s", log_debug("Mismatch device_id %s %s to %s: idname %s",
@ -1913,12 +1985,12 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
id->dev = dev; id->dev = dev;
dm_list_add(&dev->ids, &id->list); dm_list_add(&dev->ids, &id->list);
if (idname && !strcmp(idname, du->idname)) { if (idname && !strcmp(idname, du_idname)) {
du->dev = dev; du->dev = dev;
dev->id = id; dev->id = id;
dev->flags |= DEV_MATCHED_USE_ID; dev->flags |= DEV_MATCHED_USE_ID;
log_debug("Match device_id %s %s to %s", log_debug("Match device_id %s %s to %s",
idtype_to_str(du->idtype), du->idname, dev_name(dev)); idtype_to_str(du->idtype), idname, dev_name(dev));
return 1; return 1;
} }
@ -1944,7 +2016,7 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
dev_read_vpd_wwids(cmd, dev); dev_read_vpd_wwids(cmd, dev);
dm_list_iterate_items(dw, &dev->wwids) { dm_list_iterate_items(dw, &dev->wwids) {
if (!strcmp(dw->id, du->idname)) { if (!strcmp(dw->id, du_idname)) {
if (!(id = zalloc(sizeof(struct dev_id)))) if (!(id = zalloc(sizeof(struct dev_id))))
return_0; return_0;
/* wwid types are 1,2,3 and idtypes are DEV_ID_TYPE_ */ /* wwid types are 1,2,3 and idtypes are DEV_ID_TYPE_ */
@ -1956,7 +2028,7 @@ static int _match_du_to_dev(struct cmd_context *cmd, struct dev_use *du, struct
dev->id = id; dev->id = id;
dev->flags |= DEV_MATCHED_USE_ID; dev->flags |= DEV_MATCHED_USE_ID;
log_print_unless_silent("Match device_id %s %s to vpd_pg83 %s %s.", log_print_unless_silent("Match device_id %s %s to vpd_pg83 %s %s.",
idtype_to_str(du->idtype), du->idname, idtype_to_str(du->idtype), du_idname,
idtype_to_str(id->idtype), dev_name(dev)); idtype_to_str(id->idtype), dev_name(dev));
du->idtype = id->idtype; du->idtype = id->idtype;
return 1; return 1;

View File

@ -36,7 +36,57 @@
#include <assert.h> #include <assert.h>
/* /*
* Remove leading spaces.
* Remove trailing spaces.
* Replace each space with underscore.
* Skip quotes, non-ascii, non-printable.
*/
int format_general_id(const char *in, int in_bytes, unsigned char *out, int out_bytes)
{
const char *end;
int end_bytes = strlen(in);
int retlen = 0;
int j = 0;
int i;
if (!end_bytes)
return 0;
end = in + end_bytes - 1;
while ((end > in) && (*end == ' ')) {
end--;
end_bytes--;
}
for (i = 0; i < end_bytes; i++) {
if (!in[i])
break;
if (j >= (out_bytes - 2))
break;
/* skip leading spaces */
if (!retlen && (in[i] == ' '))
continue;
/* skip non-ascii non-printable characters */
if (!isascii(in[i]) || !isprint(in[i]))
continue;
/* skip quote */
if (in[i] == '"')
continue;
/* replace each space with _ */
if (in[i] == ' ')
out[j++] = '_';
else
out[j++] = in[i];
retlen++;
}
return retlen;
}
/*
* Remove leading spaces.
* Remove trailing spaces.
* Replace series of spaces with a single _. * Replace series of spaces with a single _.
* Skip quotes, non-ascii, non-printable.
*/ */
int format_t10_id(const unsigned char *in, int in_bytes, unsigned char *out, int out_bytes) int format_t10_id(const unsigned char *in, int in_bytes, unsigned char *out, int out_bytes)
{ {

View File

@ -223,8 +223,8 @@ cleanup_sysfs
# Test t10 wwid containing quote # Test t10 wwid containing quote
rm $DF rm $DF
aux wipefs_a "$DEV1" aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/ mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo "t10.ATA_2.5\"_SATA_SSD_1112-A___111111111111" > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid echo "t10.ATA_2.5\"_SATA_SSD_1112-A___111111111111" > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
lvmdevices --adddev "$DEV1" lvmdevices --adddev "$DEV1"
cat $DF cat $DF
vgcreate $vg "$DEV1" vgcreate $vg "$DEV1"
@ -241,19 +241,19 @@ grep sys_wwid $DF
grep 2.5_SATA_SSD $DF grep 2.5_SATA_SSD $DF
lvremove -y $vg lvremove -y $vg
vgremove $vg vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs cleanup_sysfs
# Test t10 wwid with trailing space and line feed at the end # Test t10 wwid with trailing space and line feed at the end
rm $DF rm $DF
aux wipefs_a "$DEV1" aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/ mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \ echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \
2048 4152 4444 4953 4b20 2020 2020 2020 \ 2048 4152 4444 4953 4b20 2020 2020 2020 \
2020 2020 2020 2020 2020 2020 2020 2020 \ 2020 2020 2020 2020 2020 2020 2020 2020 \
2020 2020 5642 3963 3130 6433 3138 2d31 \ 2020 2020 5642 3963 3130 6433 3138 2d31 \
3838 6439 6562 6320 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid 3838 6439 6562 6320 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
lvmdevices --adddev "$DEV1" lvmdevices --adddev "$DEV1"
cat $DF cat $DF
vgcreate $vg "$DEV1" vgcreate $vg "$DEV1"
@ -266,19 +266,19 @@ grep sys_wwid out
grep sys_wwid $DF grep sys_wwid $DF
lvremove -y $vg lvremove -y $vg
vgremove $vg vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs cleanup_sysfs
# Test t10 wwid with trailing space at the end that was created by 9.0/9.1 # Test t10 wwid with trailing space at the end that was created by 9.0/9.1
rm $DF rm $DF
aux wipefs_a "$DEV1" aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/ mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \ echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \
2048 4152 4444 4953 4b20 2020 2020 2020 \ 2048 4152 4444 4953 4b20 2020 2020 2020 \
2020 2020 2020 2020 2020 2020 2020 2020 \ 2020 2020 2020 2020 2020 2020 2020 2020 \
2020 2020 5642 3963 3130 6433 3138 2d31 \ 2020 2020 5642 3963 3130 6433 3138 2d31 \
3838 6439 6562 6320 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid 3838 6439 6562 6320 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
lvmdevices --adddev "$DEV1" lvmdevices --adddev "$DEV1"
cat $DF cat $DF
vgcreate $vg "$DEV1" vgcreate $vg "$DEV1"
@ -311,20 +311,20 @@ pvs
pvs -o+deviceidtype,deviceid "$DEV1" pvs -o+deviceidtype,deviceid "$DEV1"
lvremove -y $vg lvremove -y $vg
vgremove $vg vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs cleanup_sysfs
# test a t10 wwid that has actual trailing underscore which # test a t10 wwid that has actual trailing underscore which
# is followed by a trailing space. # is followed by a trailing space.
rm $DF rm $DF
aux wipefs_a "$DEV1" aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/ mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \ echo -n "7431 302e 4154 4120 2020 2020 5642 4f58 \
2048 4152 4444 4953 4b20 2020 2020 2020 \ 2048 4152 4444 4953 4b20 2020 2020 2020 \
2020 2020 2020 2020 2020 2020 2020 2020 \ 2020 2020 2020 2020 2020 2020 2020 2020 \
2020 2020 5642 3963 3130 6433 3138 2d31 \ 2020 2020 5642 3963 3130 6433 3138 2d31 \
3838 6439 6562 5f20 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid 3838 6439 6562 5f20 0a" | xxd -r -p > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid cat $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
# The wwid has an actual underscore char (5f) followed by a space char (20) # The wwid has an actual underscore char (5f) followed by a space char (20)
# 9.1 converts the trailing space to an underscore # 9.1 converts the trailing space to an underscore
T10_WWID_RHEL91="t10.ATA_____VBOX_HARDDISK___________________________VB9c10d318-188d9eb__" T10_WWID_RHEL91="t10.ATA_____VBOX_HARDDISK___________________________VB9c10d318-188d9eb__"
@ -352,9 +352,80 @@ pvs
pvs -o+deviceidtype,deviceid "$DEV1" pvs -o+deviceidtype,deviceid "$DEV1"
lvremove -y $vg lvremove -y $vg
vgremove $vg vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/wwid rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs cleanup_sysfs
#
# Test trailing/leading/center spaces in sys_wwid and sys_serial device
# ids, and that old system.devices files that have trailing/leading
# underscores are understood.
#
rm $DF
aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n " s123 456 " > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/serial
lvmdevices --adddev "$DEV1"
cat $DF
grep "IDNAME=s123__456 DEVNAME" $DF
vgcreate $vg "$DEV1"
PVID1=`pvs "$DEV1" --noheading -o uuid | tr -d - | awk '{print $1}'`
cat $DF | grep -v IDNAME > $DFTMP
cat $DFTMP
echo "IDTYPE=sys_serial IDNAME=__s123__456__ DEVNAME=${DEV1} PVID=${PVID1}" >> $DFTMP
cp $DFTMP $DF
cat $DF
vgs
pvs -o+deviceidtype,deviceid "$DEV1"
lvremove -y $vg
vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/serial
cleanup_sysfs
rm $DF
aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n " t10.123 456 " > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
lvmdevices --adddev "$DEV1"
cat $DF
grep "IDNAME=t10.123_456 DEVNAME" $DF
vgcreate $vg "$DEV1"
PVID1=`pvs "$DEV1" --noheading -o uuid | tr -d - | awk '{print $1}'`
cat $DF | grep -v IDNAME > $DFTMP
cat $DFTMP
echo "IDTYPE=sys_wwid IDNAME=__t10.123__456__ DEVNAME=${DEV1} PVID=${PVID1}" >> $DFTMP
cp $DFTMP $DF
cat $DF
vgs
pvs -o+deviceidtype,deviceid "$DEV1"
lvremove -y $vg
vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs
rm $DF
aux wipefs_a "$DEV1"
mkdir -p $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device
echo -n " naa.123 456 " > $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
lvmdevices --adddev "$DEV1"
cat $DF
grep "IDNAME=naa.123__456 DEVNAME" $DF
vgcreate $vg "$DEV1"
PVID1=`pvs "$DEV1" --noheading -o uuid | tr -d - | awk '{print $1}'`
cat $DF | grep -v IDNAME > $DFTMP
cat $DFTMP
echo "IDTYPE=sys_wwid IDNAME=__naa.123__456__ DEVNAME=${DEV1} PVID=${PVID1}" >> $DFTMP
cp $DFTMP $DF
cat $DF
vgs
pvs -o+deviceidtype,deviceid "$DEV1"
lvremove -y $vg
vgremove $vg
rm $SYS_DIR/dev/block/$MAJOR1:$MINOR1/device/wwid
cleanup_sysfs
# TODO: lvmdevices --adddev <dev> --deviceidtype <type> --deviceid <val> # TODO: lvmdevices --adddev <dev> --deviceidtype <type> --deviceid <val>
# This would let the user specify the second naa wwid. # This would let the user specify the second naa wwid.