Commit e5de34db authored by Jan Höppner's avatar Jan Höppner Committed by Jens Axboe

s390/dasd: Simplify uid string generation

There are two variants of the device uid string. One containing the
virtual device unit information table (vduit) identifying the device as
a virtual device located on a real device in a z/VM environment. The
other variant does not contain those additional information.

Simplify the string generation with a shorter check of an existing vduit
embedded in the snprintf() calls.
Signed-off-by: default avatarJan Höppner <hoeppner@linux.ibm.com>
Reviewed-by: default avatarStefan Haberland <sth@linux.ibm.com>
Signed-off-by: default avatarStefan Haberland <sth@linux.ibm.com>
Link: https://lore.kernel.org/r/20240208164248.540985-2-sth@linux.ibm.comSigned-off-by: default avatarJens Axboe <axboe@kernel.dk>
parent 052618c7
...@@ -1412,15 +1412,9 @@ dasd_uid_show(struct device *dev, struct device_attribute *attr, char *buf) ...@@ -1412,15 +1412,9 @@ dasd_uid_show(struct device *dev, struct device_attribute *attr, char *buf)
break; break;
} }
if (strlen(uid.vduit) > 0) snprintf(uid_string, sizeof(uid_string), "%s.%s.%04x.%s%s%s",
snprintf(uid_string, sizeof(uid_string), uid.vendor, uid.serial, uid.ssid, ua_string,
"%s.%s.%04x.%s.%s", uid.vduit[0] ? "." : "", uid.vduit);
uid.vendor, uid.serial, uid.ssid, ua_string,
uid.vduit);
else
snprintf(uid_string, sizeof(uid_string),
"%s.%s.%04x.%s",
uid.vendor, uid.serial, uid.ssid, ua_string);
} }
dasd_put_device(device); dasd_put_device(device);
......
...@@ -1072,22 +1072,14 @@ static void dasd_eckd_read_fc_security(struct dasd_device *device) ...@@ -1072,22 +1072,14 @@ static void dasd_eckd_read_fc_security(struct dasd_device *device)
} }
} }
static void dasd_eckd_get_uid_string(struct dasd_conf *conf, static void dasd_eckd_get_uid_string(struct dasd_conf *conf, char *print_uid)
char *print_uid)
{ {
struct dasd_uid uid; struct dasd_uid uid;
create_uid(conf, &uid); create_uid(conf, &uid);
if (strlen(uid.vduit) > 0) snprintf(print_uid, DASD_UID_STRLEN, "%s.%s.%04x.%02x%s%s",
snprintf(print_uid, DASD_UID_STRLEN, uid.vendor, uid.serial, uid.ssid, uid.real_unit_addr,
"%s.%s.%04x.%02x.%s", uid.vduit[0] ? "." : "", uid.vduit);
uid.vendor, uid.serial, uid.ssid,
uid.real_unit_addr, uid.vduit);
else
snprintf(print_uid, DASD_UID_STRLEN,
"%s.%s.%04x.%02x",
uid.vendor, uid.serial, uid.ssid,
uid.real_unit_addr);
} }
static int dasd_eckd_check_cabling(struct dasd_device *device, static int dasd_eckd_check_cabling(struct dasd_device *device,
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment