234 lines
8.4 KiB
Diff
234 lines
8.4 KiB
Diff
|
From a4101cc9bf1d18b698ead344e6be6fe311fda41d Mon Sep 17 00:00:00 2001
|
||
|
From: Hannes Reinecke <hare@suse.de>
|
||
|
Date: Thu, 5 Oct 2017 09:59:41 +0200
|
||
|
Subject: [PATCH] dasdfmt: Fixup device name handling
|
||
|
|
||
|
get_device_name() contains a chunk of unreachable code, as the
|
||
|
'name' argument is never filled with any value.
|
||
|
So turn things around to have get_device_name() always fill the
|
||
|
'name' argument with the real device name, and remove the
|
||
|
devname entry from the dasdfmt_info_t structure.
|
||
|
|
||
|
Signed-off-by: Hannes Reinecke <hare@suse.com>
|
||
|
---
|
||
|
dasdfmt/dasdfmt.c | 70 ++++++++++++++++++++++++-------------------------------
|
||
|
dasdfmt/dasdfmt.h | 1 -
|
||
|
2 files changed, 30 insertions(+), 41 deletions(-)
|
||
|
|
||
|
diff --git a/dasdfmt/dasdfmt.c b/dasdfmt/dasdfmt.c
|
||
|
index 4cf423d..3da7902 100644
|
||
|
--- a/dasdfmt/dasdfmt.c
|
||
|
+++ b/dasdfmt/dasdfmt.c
|
||
|
@@ -456,7 +456,7 @@ static void program_interrupt_signal(int sig)
|
||
|
/*
|
||
|
* check given device name for blanks and some special characters
|
||
|
*/
|
||
|
-static void get_device_name(dasdfmt_info_t *info, char *name, int argc,
|
||
|
+static void get_device_name(dasdfmt_info_t *info, char *devname, int argc,
|
||
|
char *argv[])
|
||
|
{
|
||
|
struct util_proc_dev_entry dev_entry;
|
||
|
@@ -470,32 +470,20 @@ static void get_device_name(dasdfmt_info_t *info, char *name, int argc,
|
||
|
ERRMSG_EXIT(EXIT_MISUSE, "%s: No device specified!\n",
|
||
|
prog_name);
|
||
|
|
||
|
- if (info->device_id < argc) {
|
||
|
- strcpy(info->devname, argv[info->device_id]);
|
||
|
- } else {
|
||
|
- if ((strchr(name, ' ') != NULL) || (strchr(name, '#') != NULL) ||
|
||
|
- (strchr(name, '[') != NULL) || (strchr(name, ']') != NULL) ||
|
||
|
- (strchr(name, '!') != NULL) || (strchr(name, '>') != NULL) ||
|
||
|
- (strchr(name, '(') != NULL) || (strchr(name, '<') != NULL) ||
|
||
|
- (strchr(name, ')') != NULL) || (strchr(name, ':') != NULL) ||
|
||
|
- (strchr(name, '&') != NULL) || (strchr(name, ';') != NULL))
|
||
|
- ERRMSG_EXIT(EXIT_MISUSE, "%s: Your filename contains "
|
||
|
- "blanks or special characters!\n",
|
||
|
- prog_name);
|
||
|
-
|
||
|
- strncpy(info->devname, name, PATH_MAX - 1);
|
||
|
- info->devname[PATH_MAX - 1] = '\0';
|
||
|
- }
|
||
|
+ if (strlen(argv[info->device_id]) >= PATH_MAX)
|
||
|
+ ERRMSG_EXIT(EXIT_MISUSE, "%s: device name too long!\n",
|
||
|
+ prog_name);
|
||
|
+ strcpy(devname, argv[info->device_id]);
|
||
|
|
||
|
- if (stat(info->devname, &dev_stat) != 0)
|
||
|
+ if (stat(devname, &dev_stat) != 0)
|
||
|
ERRMSG_EXIT(EXIT_MISUSE, "%s: Could not get information for "
|
||
|
- "device node %s: %s\n", prog_name, info->devname,
|
||
|
+ "device node %s: %s\n", prog_name, devname,
|
||
|
strerror(errno));
|
||
|
|
||
|
if (minor(dev_stat.st_rdev) & PARTN_MASK) {
|
||
|
ERRMSG_EXIT(EXIT_MISUSE, "%s: Unable to format partition %s. "
|
||
|
"Please specify a device.\n", prog_name,
|
||
|
- info->devname);
|
||
|
+ devname);
|
||
|
}
|
||
|
|
||
|
if (util_proc_dev_get_entry(dev_stat.st_rdev, 1, &dev_entry) == 0) {
|
||
|
@@ -505,7 +493,7 @@ static void get_device_name(dasdfmt_info_t *info, char *name, int argc,
|
||
|
prog_name, dev_entry.name);
|
||
|
} else {
|
||
|
printf("%s WARNING: Unable to get driver name for device node %s",
|
||
|
- prog_name, info->devname);
|
||
|
+ prog_name, devname);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@@ -586,7 +574,7 @@ static void check_layout(dasdfmt_info_t *info, unsigned int intensity)
|
||
|
/*
|
||
|
* check for disk type and set some variables (e.g. usage count)
|
||
|
*/
|
||
|
-static void check_disk(dasdfmt_info_t *info)
|
||
|
+static void check_disk(dasdfmt_info_t *info, char *devname)
|
||
|
{
|
||
|
int ro, errno_save;
|
||
|
|
||
|
@@ -609,13 +597,13 @@ static void check_disk(dasdfmt_info_t *info)
|
||
|
if (strncmp(info->dasd_info.type, "ECKD", 4) != 0) {
|
||
|
ERRMSG_EXIT(EXIT_FAILURE,
|
||
|
"%s: Unsupported disk type\n%s is not an "
|
||
|
- "ECKD disk!\n", prog_name, info->devname);
|
||
|
+ "ECKD disk!\n", prog_name, devname);
|
||
|
}
|
||
|
|
||
|
- if (dasd_sys_raw_track_access(info->devname)) {
|
||
|
+ if (dasd_sys_raw_track_access(devname)) {
|
||
|
ERRMSG_EXIT(EXIT_FAILURE,
|
||
|
"%s: Device '%s' is in raw-track access mode\n",
|
||
|
- prog_name, info->devname);
|
||
|
+ prog_name, devname);
|
||
|
}
|
||
|
}
|
||
|
|
||
|
@@ -935,7 +923,8 @@ static format_data_t ask_user_for_blksize(format_data_t params)
|
||
|
/*
|
||
|
* print all information needed to format the device
|
||
|
*/
|
||
|
-static void dasdfmt_print_info(dasdfmt_info_t *info, volume_label_t *vlabel,
|
||
|
+static void dasdfmt_print_info(dasdfmt_info_t *info, char *devname,
|
||
|
+ volume_label_t *vlabel,
|
||
|
unsigned int cylinders, unsigned int heads,
|
||
|
format_data_t *p)
|
||
|
{
|
||
|
@@ -945,7 +934,7 @@ static void dasdfmt_print_info(dasdfmt_info_t *info, volume_label_t *vlabel,
|
||
|
cylinders, heads, (cylinders * heads));
|
||
|
|
||
|
printf("\nI am going to format the device ");
|
||
|
- printf("%s in the following way:\n", info->devname);
|
||
|
+ printf("%s in the following way:\n", devname);
|
||
|
printf(" Device number of device : 0x%x\n", info->dasd_info.devno);
|
||
|
printf(" Labelling device : %s\n",
|
||
|
(info->writenolabel) ? "no" : "yes");
|
||
|
@@ -1376,7 +1365,8 @@ static void dasdfmt_quick_format(dasdfmt_info_t *info, unsigned int cylinders,
|
||
|
disk_disabled = 0;
|
||
|
}
|
||
|
|
||
|
-static void do_format_dasd(dasdfmt_info_t *info, volume_label_t *vlabel,
|
||
|
+static void do_format_dasd(dasdfmt_info_t *info, char *devname,
|
||
|
+ volume_label_t *vlabel,
|
||
|
format_data_t *p, unsigned int cylinders,
|
||
|
unsigned int heads)
|
||
|
{
|
||
|
@@ -1399,19 +1389,19 @@ static void do_format_dasd(dasdfmt_info_t *info, volume_label_t *vlabel,
|
||
|
}
|
||
|
|
||
|
if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
||
|
- dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
||
|
+ dasdfmt_print_info(info, devname, vlabel, cylinders, heads, p);
|
||
|
|
||
|
- count = u2s_get_host_access_count(info->devname);
|
||
|
+ count = u2s_get_host_access_count(devname);
|
||
|
if (info->force_host) {
|
||
|
if (count > 1) {
|
||
|
ERRMSG_EXIT(EXIT_FAILURE,
|
||
|
"\n%s: Disk %s is online on OS instances in %d different LPARs.\n"
|
||
|
"Note: Your installation might include z/VM systems that are configured to\n"
|
||
|
"automatically vary on disks, regardless of whether they are subsequently used.\n\n",
|
||
|
- prog_name, info->devname, count);
|
||
|
+ prog_name, devname, count);
|
||
|
} else if (count < 0) {
|
||
|
ERRMSG("\nHosts access information not available for disk %s.\n\n",
|
||
|
- info->devname);
|
||
|
+ devname);
|
||
|
return;
|
||
|
}
|
||
|
} else if (count > 1)
|
||
|
@@ -1420,7 +1410,7 @@ static void do_format_dasd(dasdfmt_info_t *info, volume_label_t *vlabel,
|
||
|
"Ensure that the disk is not being used by a system outside your LPAR.\n"
|
||
|
"Note: Your installation might include z/VM systems that are configured to\n"
|
||
|
"automatically vary on disks, regardless of whether they are subsequently used.\n",
|
||
|
- info->devname, count);
|
||
|
+ devname, count);
|
||
|
|
||
|
if (!info->testmode) {
|
||
|
if (!info->withoutprompt) {
|
||
|
@@ -1471,7 +1461,6 @@ int main(int argc, char *argv[])
|
||
|
{
|
||
|
dasdfmt_info_t info = {
|
||
|
.dasd_info = {0},
|
||
|
- {0}
|
||
|
};
|
||
|
volume_label_t vlabel;
|
||
|
char old_volser[7];
|
||
|
@@ -1648,10 +1637,10 @@ int main(int argc, char *argv[])
|
||
|
|
||
|
get_device_name(&info, dev_filename, argc, argv);
|
||
|
|
||
|
- filedes = open(info.devname, O_RDWR);
|
||
|
+ filedes = open(dev_filename, O_RDWR);
|
||
|
if (filedes == -1)
|
||
|
ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
||
|
- prog_name, info.devname, strerror(errno));
|
||
|
+ prog_name, dev_filename, strerror(errno));
|
||
|
|
||
|
get_device_info(&info);
|
||
|
|
||
|
@@ -1675,16 +1664,16 @@ int main(int argc, char *argv[])
|
||
|
exit(1);
|
||
|
}
|
||
|
|
||
|
- if (dasdfmt_get_volser(info.devname,
|
||
|
+ if (dasdfmt_get_volser(dev_filename,
|
||
|
&info.dasd_info, old_volser) == 0)
|
||
|
vtoc_volume_label_set_volser(&vlabel, old_volser);
|
||
|
else
|
||
|
ERRMSG_EXIT(EXIT_FAILURE,
|
||
|
"%s: VOLSER not found on device %s\n",
|
||
|
- prog_name, info.devname);
|
||
|
+ prog_name, dev_filename);
|
||
|
}
|
||
|
|
||
|
- check_disk(&info);
|
||
|
+ check_disk(&info, dev_filename);
|
||
|
|
||
|
if (check_param(str, ERR_LENGTH, &format_params) < 0)
|
||
|
ERRMSG_EXIT(EXIT_MISUSE, "%s: %s\n", prog_name, str);
|
||
|
@@ -1695,7 +1684,8 @@ int main(int argc, char *argv[])
|
||
|
if (info.check)
|
||
|
check_disk_format(&info, cylinders, heads, &format_params);
|
||
|
else
|
||
|
- do_format_dasd(&info, &vlabel, &format_params, cylinders, heads);
|
||
|
+ do_format_dasd(&info, dev_filename, &vlabel,
|
||
|
+ &format_params, cylinders, heads);
|
||
|
|
||
|
if (close(filedes) != 0)
|
||
|
ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
||
|
diff --git a/dasdfmt/dasdfmt.h b/dasdfmt/dasdfmt.h
|
||
|
index 7c6f0bd..9ce3b92 100644
|
||
|
--- a/dasdfmt/dasdfmt.h
|
||
|
+++ b/dasdfmt/dasdfmt.h
|
||
|
@@ -291,7 +291,6 @@ typedef struct bootstrap2 {
|
||
|
|
||
|
typedef struct dasdfmt_info {
|
||
|
dasd_information2_t dasd_info;
|
||
|
- char devname[PATH_MAX];
|
||
|
int verbosity;
|
||
|
int testmode;
|
||
|
int withoutprompt;
|
||
|
--
|
||
|
1.7.12.4
|
||
|
|