Accepting request 531962 from Base:System
Upgrade to version 2.1.0 per Fate#323291. OBS-URL: https://build.opensuse.org/request/show/531962 OBS-URL: https://build.opensuse.org/package/show/openSUSE:Factory/s390-tools?expand=0&rev=8
This commit is contained in:
commit
24761c730a
@ -8,7 +8,7 @@
|
|||||||
-# on device add set request queue scheduler to deadline
|
-# on device add set request queue scheduler to deadline
|
||||||
-SUBSYSTEM!="block", GOTO="sched_end"
|
-SUBSYSTEM!="block", GOTO="sched_end"
|
||||||
-
|
-
|
||||||
-ACTION!="add", GOTO="sched_end"
|
-ACTION!="change", GOTO="sched_end"
|
||||||
-KERNEL=="dasd*[!0-9]", WAIT_FOR="queue/scheduler", ATTR{queue/scheduler}="deadline"
|
-KERNEL=="dasd*[!0-9]", TEST=="queue/scheduler", ATTR{queue/scheduler}="deadline"
|
||||||
-
|
-
|
||||||
-LABEL="sched_end"
|
-LABEL="sched_end"
|
||||||
|
56
boot.cpi
56
boot.cpi
@ -1,56 +0,0 @@
|
|||||||
#!/bin/sh
|
|
||||||
#
|
|
||||||
# Copyright (c) 2001-2002 SuSE Linux AG, Nuernberg, Germany.
|
|
||||||
# Copyright (c) 2008 SuSE LINUX Products GmbH, Nuernberg, Germany.
|
|
||||||
# All rights reserved.
|
|
||||||
#
|
|
||||||
# /etc/init.d/boot.cpi
|
|
||||||
#
|
|
||||||
### BEGIN INIT INFO
|
|
||||||
# Provides: boot.cpi
|
|
||||||
# Required-Start: boot.rootfsck
|
|
||||||
# Required-Stop: $null
|
|
||||||
# Should-Start:
|
|
||||||
# X-Start-Before:
|
|
||||||
# Default-Start: B S
|
|
||||||
# Default-Stop:
|
|
||||||
# Description: Set Control Program Identification data
|
|
||||||
# Short-Description: Set Control Program Identification data
|
|
||||||
### END INIT INFO
|
|
||||||
|
|
||||||
. /etc/rc.status
|
|
||||||
. /etc/sysconfig/cpi
|
|
||||||
|
|
||||||
rc_reset
|
|
||||||
|
|
||||||
case "$1" in
|
|
||||||
start|restart|reload)
|
|
||||||
if test "$CPI_SET" == "yes"; then
|
|
||||||
if test ! -e /sys/firmware/cpi; then
|
|
||||||
echo -n "sclp_cpi interface not found"
|
|
||||||
rc_status -s
|
|
||||||
rc_exit
|
|
||||||
fi
|
|
||||||
echo "$CPI_SYSTEM_NAME" >/sys/firmware/cpi/system_name
|
|
||||||
echo "$CPI_SYSPLEX_NAME" >/sys/firmware/cpi/sysplex_name
|
|
||||||
echo "LINUX " >/sys/firmware/cpi/system_type
|
|
||||||
awk "BEGIN { split(\"`uname -r`\",x,\".\"); printf(\"0x0000000000%02x%02x%02x\", x[1],x[2],x[3]) }" >/sys/firmware/cpi/system_level
|
|
||||||
echo 1 >/sys/firmware/cpi/set 2>/dev/null
|
|
||||||
rc_status -v -r
|
|
||||||
else
|
|
||||||
rc_status -u
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
stop)
|
|
||||||
rc_status -s
|
|
||||||
;;
|
|
||||||
status)
|
|
||||||
rc_status -s
|
|
||||||
;;
|
|
||||||
*)
|
|
||||||
echo "Usage: $0 {start|stop|status|restart|reload}"
|
|
||||||
exit 1
|
|
||||||
;;
|
|
||||||
esac
|
|
||||||
|
|
||||||
rc_exit
|
|
@ -23,49 +23,44 @@ diff --git a/dasdfmt/dasdfmt.c b/dasdfmt/dasdfmt.c
|
|||||||
index e1877ac..f03cbad 100644
|
index e1877ac..f03cbad 100644
|
||||||
--- a/dasdfmt/dasdfmt.c
|
--- a/dasdfmt/dasdfmt.c
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
+++ b/dasdfmt/dasdfmt.c
|
||||||
@@ -270,7 +270,7 @@ static void init_info(dasdfmt_info_t *info)
|
@@ -588,7 +616,7 @@
|
||||||
|
*/
|
||||||
static void check_disk(dasdfmt_info_t *info)
|
static void check_disk(dasdfmt_info_t *info)
|
||||||
{
|
{
|
||||||
dasd_information_t dasd_info;
|
|
||||||
- int ro, errno_save;
|
- int ro, errno_save;
|
||||||
+ int ro, errno_save, i = 0;
|
+ int ro, errno_save, i = 0;
|
||||||
|
|
||||||
if (ioctl(filedes, BLKROGET, &ro) != 0) {
|
if (ioctl(filedes, BLKROGET, &ro) != 0) {
|
||||||
errno_save = errno;
|
errno_save = errno;
|
||||||
@@ -283,7 +283,7 @@ static void check_disk(dasdfmt_info_t *info)
|
@@ -602,9 +630,27 @@
|
||||||
if (ro) {
|
if (ro)
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "Disk is read only!\n");
|
ERRMSG_EXIT(EXIT_FAILURE, "Disk is read only!\n");
|
||||||
}
|
|
||||||
-
|
|
||||||
+retry:
|
|
||||||
if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0) {
|
|
||||||
errno_save = errno;
|
|
||||||
close(filedes);
|
|
||||||
@@ -294,8 +294,23 @@ static void check_disk(dasdfmt_info_t *info)
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!info->force)
|
- if (!info->force)
|
||||||
- if (dasd_info.open_count > 1)
|
+ if (!info->force) {
|
||||||
+ /*
|
+ /*
|
||||||
+ * udev strikes again.
|
+ * udev strikes again.
|
||||||
+ * Modern udev will issue a 'change' event whenever
|
+ * Modern udev will issue a 'change' event whenever
|
||||||
+ * a device opened with O_RDWR is closed again.
|
+ * a device opened with O_RDWR is closed again.
|
||||||
+ * On the ground that program _might_ have changed
|
+ * On the grounds that program _might_ have changed
|
||||||
+ * the partition table.
|
+ * the partition table.
|
||||||
+ * And confusing the hell out ouf anyone else.
|
+ * And confusing the hell out ouf anyone else.
|
||||||
+ * Bah.
|
+ * Bah.
|
||||||
+ */
|
+ */
|
||||||
+ if (dasd_info.open_count > 1) {
|
+ for ( i = 0 ; i < 6 ; i++ ) {
|
||||||
+ if (i < 5) {
|
+ if (info->dasd_info.open_count > 1) {
|
||||||
+ ++i;
|
+ get_device_info(info);
|
||||||
+ sleep(1);
|
+ sleep(1);
|
||||||
+ goto retry;
|
|
||||||
+ }
|
+ }
|
||||||
|
+ else break;
|
||||||
|
+
|
||||||
|
+ }
|
||||||
|
if (info->dasd_info.open_count > 1)
|
||||||
ERRMSG_EXIT(EXIT_BUSY, "Disk in use!\n");
|
ERRMSG_EXIT(EXIT_BUSY, "Disk in use!\n");
|
||||||
+ }
|
+ }
|
||||||
|
|
||||||
info->usage_count = dasd_info.open_count;
|
if (strncmp(info->dasd_info.type, "ECKD", 4) != 0) {
|
||||||
info->devno = dasd_info.devno;
|
ERRMSG_EXIT(EXIT_FAILURE,
|
||||||
--
|
--
|
||||||
1.8.4.5
|
1.8.4.5
|
||||||
|
|
||||||
|
2
mkdump.8
2
mkdump.8
@ -6,7 +6,7 @@ mkdump \- Preparing disks for use as S/390 dump device.
|
|||||||
.B mkdump
|
.B mkdump
|
||||||
[\fIOPTIONS\fR] [\fIDEVICE\fR]...
|
[\fIOPTIONS\fR] [\fIDEVICE\fR]...
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
mkdump 2.0.2
|
mkdump 2.0.3
|
||||||
.PP
|
.PP
|
||||||
Prepare one or more volumes for use as S/390 dump device. Supported devices
|
Prepare one or more volumes for use as S/390 dump device. Supported devices
|
||||||
are ECKD DASD and SCSI over zFCP disks, while multi\-volumes are limited to DASD.
|
are ECKD DASD and SCSI over zFCP disks, while multi\-volumes are limited to DASD.
|
||||||
|
20
mkdump.pl
20
mkdump.pl
@ -4,7 +4,8 @@
|
|||||||
# mkdump.pl - Preparing disks for use as S/390 dump device
|
# mkdump.pl - Preparing disks for use as S/390 dump device
|
||||||
#
|
#
|
||||||
# Copyright (c) 2011 Tim Hardeck, SUSE LINUX Products GmbH
|
# Copyright (c) 2011 Tim Hardeck, SUSE LINUX Products GmbH
|
||||||
# bases on mkdump.sh (c) 2004 Hannes Reinecke, SuSE AG
|
# Copyright (c) 2017 SUSE LINUX GmbH, Nuernberg, Germany.
|
||||||
|
# Based on mkdump.sh (c) 2004 Hannes Reinecke, SuSE AG
|
||||||
#
|
#
|
||||||
# License:
|
# License:
|
||||||
#
|
#
|
||||||
@ -30,7 +31,7 @@ use warnings;
|
|||||||
use Fcntl;
|
use Fcntl;
|
||||||
use Getopt::Long;
|
use Getopt::Long;
|
||||||
|
|
||||||
my $VERSION = "2.0.2";
|
my $VERSION = "2.0.3";
|
||||||
|
|
||||||
my $BLKID = "/sbin/blkid";
|
my $BLKID = "/sbin/blkid";
|
||||||
my $PARTED = "/usr/sbin/parted";
|
my $PARTED = "/usr/sbin/parted";
|
||||||
@ -41,7 +42,6 @@ my $ZIPL = "/sbin/zipl";
|
|||||||
my $UDEVADM = "/sbin/udevadm";
|
my $UDEVADM = "/sbin/udevadm";
|
||||||
my $ZGETDUMP = "/sbin/zgetdump";
|
my $ZGETDUMP = "/sbin/zgetdump";
|
||||||
|
|
||||||
my $MNTPOINT = "/var/run/mkdump." . getppid();
|
|
||||||
# temporary DASD device configuration file for Zipl
|
# temporary DASD device configuration file for Zipl
|
||||||
my $MDPATH = "/tmp/mvdump.conf";
|
my $MDPATH = "/tmp/mvdump.conf";
|
||||||
# zFCP dump dir, without a leading '/'
|
# zFCP dump dir, without a leading '/'
|
||||||
@ -57,11 +57,6 @@ sub cleanup
|
|||||||
if (-e $MDPATH) {
|
if (-e $MDPATH) {
|
||||||
system("rm -f $MDPATH");
|
system("rm -f $MDPATH");
|
||||||
}
|
}
|
||||||
# zFCP
|
|
||||||
if (-d $MNTPOINT) {
|
|
||||||
system("umount $MNTPOINT");
|
|
||||||
system("rmdir $MNTPOINT");
|
|
||||||
}
|
|
||||||
}
|
}
|
||||||
|
|
||||||
sub exit_with
|
sub exit_with
|
||||||
@ -230,15 +225,10 @@ sub print_device
|
|||||||
$output .= "\t$adapter\t$wwpn\t$lun";
|
$output .= "\t$adapter\t$wwpn\t$lun";
|
||||||
|
|
||||||
# check for dump record
|
# check for dump record
|
||||||
system("mkdir -p $MNTPOINT");
|
if (system("$ZGETDUMP -d ${device} >/dev/null 2>&1") == 0) {
|
||||||
if (get_partition_num($device) == 1 and system("mount -o ro ${device}1 $MNTPOINT 2>/dev/null") == 0) {
|
|
||||||
if ( -r "$MNTPOINT/bootmap" and -d "$MNTPOINT/$ZFCP_DUMP_DIR") {
|
|
||||||
$dump_device = 1;
|
$dump_device = 1;
|
||||||
$output .= "\tdumpdevice";
|
$output .= "\tdumpdevice";
|
||||||
}
|
}
|
||||||
system("umount $MNTPOINT");
|
|
||||||
}
|
|
||||||
system("rmdir $MNTPOINT");
|
|
||||||
}
|
}
|
||||||
if ($only_dump_disks) {
|
if ($only_dump_disks) {
|
||||||
if ($dump_device) {
|
if ($dump_device) {
|
||||||
@ -324,7 +314,7 @@ sub prepare_dasd
|
|||||||
# check formatting
|
# check formatting
|
||||||
for my $device (@devices) {
|
for my $device (@devices) {
|
||||||
# determine disk layout
|
# determine disk layout
|
||||||
my ($fmtstr) = `$DASDVIEW -x -f $device` =~ /(\w\w\w) formatted/;
|
my ($fmtstr) = `$DASDVIEW -x $device` =~ /(\w\w\w) formatted/;
|
||||||
|
|
||||||
SWITCH:
|
SWITCH:
|
||||||
for($fmtstr) {
|
for($fmtstr) {
|
||||||
|
@ -1,3 +0,0 @@
|
|||||||
version https://git-lfs.github.com/spec/v1
|
|
||||||
oid sha256:6f4e9d6f27cfad77ff84ac7a332a7fb2e17b620b3c2da4fc2ba47d2c77c94287
|
|
||||||
size 814967
|
|
3
s390-tools-2.1.0.tar.gz
Normal file
3
s390-tools-2.1.0.tar.gz
Normal file
@ -0,0 +1,3 @@
|
|||||||
|
version https://git-lfs.github.com/spec/v1
|
||||||
|
oid sha256:b5ce3fa0de074dfe7d16c74771fcb5092c4a6f575168bf4e13f88275a6370122
|
||||||
|
size 1046910
|
@ -19,25 +19,7 @@ diff --git a/fdasd/fdasd.c b/fdasd/fdasd.c
|
|||||||
index 4503d3e..f04dc3d 100644
|
index 4503d3e..f04dc3d 100644
|
||||||
--- a/fdasd/fdasd.c
|
--- a/fdasd/fdasd.c
|
||||||
+++ b/fdasd/fdasd.c
|
+++ b/fdasd/fdasd.c
|
||||||
@@ -826,7 +826,7 @@ fdasd_check_conffile_input (fdasd_anchor_t *anc,
|
@@ -1247,9 +1247,12 @@
|
||||||
* Verifies the specified block device.
|
|
||||||
*/
|
|
||||||
static void
|
|
||||||
-fdasd_verify_device (fdasd_anchor_t *anc, char *name)
|
|
||||||
+fdasd_verify_device (fdasd_anchor_t *anc, char *name)
|
|
||||||
{
|
|
||||||
struct stat dst;
|
|
||||||
char err_str[ERROR_STRING_SIZE];
|
|
||||||
@@ -847,7 +847,7 @@ fdasd_verify_device (fdasd_anchor_t *anc, char *name)
|
|
||||||
fdasd_error(anc, device_verification_failed, err_str);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (minor (dst.st_rdev) & PARTN_MASK) {
|
|
||||||
+ if (!anc->force_virtual && minor (dst.st_rdev) & PARTN_MASK) {
|
|
||||||
snprintf(err_str, ERROR_STRING_SIZE,
|
|
||||||
"Partition '%s' (%d/%d) detected where device is "
|
|
||||||
"required\n", name,
|
|
||||||
@@ -1156,9 +1156,12 @@ fdasd_reread_partition_table (fdasd_anchor_t *anc)
|
|
||||||
}
|
}
|
||||||
|
|
||||||
if (ioctl(fd, BLKRRPART, NULL) != 0) {
|
if (ioctl(fd, BLKRRPART, NULL) != 0) {
|
||||||
@ -53,5 +35,3 @@ index 4503d3e..f04dc3d 100644
|
|||||||
}
|
}
|
||||||
close(fd);
|
close(fd);
|
||||||
}
|
}
|
||||||
--
|
|
||||||
1.8.5.2
|
|
||||||
|
@ -10,12 +10,12 @@
|
|||||||
- [-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
|
- [-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
|
||||||
+ [-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR] [-P maxpar]
|
+ [-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR] [-P maxpar]
|
||||||
.br
|
.br
|
||||||
- [-L] [-V] [-F] [-k] [-C] \fIdevice\fR
|
- [-L] [-V] [-F] [-k] [-C] [-M \fImode\fR] \fIdevice\fR
|
||||||
+ [-L] [-V] [-F] [-k] [-C] \fIdevice\fR ...
|
+ [-L] [-V] [-F] [-k] [-C] [-M \fImode\fR] \fIdevice\fR ...
|
||||||
|
|
||||||
.SH DESCRIPTION
|
.SH DESCRIPTION
|
||||||
\fBdasdfmt\fR formats a DASD (ECKD) disk drive to prepare it
|
\fBdasdfmt\fR formats a DASD (ECKD) disk drive to prepare it
|
||||||
@@ -91,7 +91,7 @@
|
@@ -95,7 +95,7 @@
|
||||||
running in background or redirecting the output to a file.
|
running in background or redirecting the output to a file.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
@ -24,7 +24,7 @@
|
|||||||
Print one line for each formatted cylinder showing the number of the
|
Print one line for each formatted cylinder showing the number of the
|
||||||
cylinder and percentage of formatting process.
|
cylinder and percentage of formatting process.
|
||||||
Intended to be used by higher level interfaces.
|
Intended to be used by higher level interfaces.
|
||||||
@@ -123,6 +123,20 @@
|
@@ -152,6 +152,20 @@
|
||||||
and always be a power of two. The recommended blocksize is 4096 bytes.
|
and always be a power of two. The recommended blocksize is 4096 bytes.
|
||||||
|
|
||||||
.TP
|
.TP
|
||||||
@ -47,7 +47,7 @@
|
|||||||
to disk after formatting. If no label is specified, a sensible default
|
to disk after formatting. If no label is specified, a sensible default
|
||||||
--- s390-tools-1.34.0/dasdfmt/dasdfmt.h 2016-04-14 16:43:51.000000000 -0400
|
--- s390-tools-1.34.0/dasdfmt/dasdfmt.h 2016-04-14 16:43:51.000000000 -0400
|
||||||
+++ s390-tools-1.34.0/dasdfmt/dasdfmt.h 2016-04-14 16:35:01.000000000 -0400
|
+++ s390-tools-1.34.0/dasdfmt/dasdfmt.h 2016-04-14 16:35:01.000000000 -0400
|
||||||
@@ -195,6 +195,7 @@
|
@@ -260,6 +260,7 @@
|
||||||
#define LABEL_LENGTH 14
|
#define LABEL_LENGTH 14
|
||||||
#define VLABEL_CHARS 84
|
#define VLABEL_CHARS 84
|
||||||
#define LINE_LENGTH 80
|
#define LINE_LENGTH 80
|
||||||
|
@ -1,13 +1,16 @@
|
|||||||
--- s390-tools-1.24.1/zipl/boot/menu.c 2013-12-18 11:11:45.000000000 -0500
|
--- s390-tools-1.24.1/zipl/boot/menu.c 2013-12-18 11:11:45.000000000 -0500
|
||||||
+++ s390-tools-1.24.1/zipl/boot/menu.c 2013-12-18 11:59:18.000000000 -0500
|
+++ s390-tools-1.24.1/zipl/boot/menu.c 2013-12-18 11:59:18.000000000 -0500
|
||||||
@@ -166,7 +166,9 @@
|
@@ -167,8 +167,11 @@
|
||||||
|
/* print config list */
|
||||||
menu_list();
|
menu_list();
|
||||||
|
|
||||||
if (is_zvm())
|
- if (is_zvm())
|
||||||
- printf("Note: VM users please use '#cp vi vmsg <input>'\n");
|
- printf("Note: VM users please use '#cp vi vmsg <input>'\n");
|
||||||
|
+ if (is_zvm()) {
|
||||||
+ printf(" \n");
|
+ printf(" \n");
|
||||||
+ printf("Note: VM users please use '#cp vi vmsg <input> <kernel-parameters>'\n");
|
+ printf("Note: VM users please use '#cp vi vmsg <input> <kernel-parameters>'\n");
|
||||||
+ printf(" \n");
|
+ printf(" \n");
|
||||||
|
+ }
|
||||||
|
|
||||||
value = menu_read();
|
value = menu_read();
|
||||||
|
|
||||||
|
@ -1,35 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 141695] chiucvallow: correct verification return code
|
|
||||||
From: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: chiucvallow: correct verification return code
|
|
||||||
Symptom: When running test_chiucvallow.sh, the script is
|
|
||||||
failing to validate filter files with special
|
|
||||||
characters.
|
|
||||||
because the chiucvallow.in -V is
|
|
||||||
Problem: The chiucvallow -V is returning code 2 and for
|
|
||||||
this reason, the script gives an error message,
|
|
||||||
but the filter file is validated successfully
|
|
||||||
manually.
|
|
||||||
Solution: Correct the return code of chiucvallow to handle
|
|
||||||
verification failures correctly.
|
|
||||||
Reproduction: See Symptom.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 141695
|
|
||||||
|
|
||||||
Signed-off-by: Hendrik Brueckner <brueckner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
iucvterm/bin/chiucvallow.in | 3 ++-
|
|
||||||
1 file changed, 2 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/iucvterm/bin/chiucvallow.in
|
|
||||||
+++ b/iucvterm/bin/chiucvallow.in
|
|
||||||
@@ -115,7 +115,8 @@ verify_filter(){
|
|
||||||
|
|
||||||
printf "\n$PRG: Verification summary: verified=%d failed=%d size=%d bytes\n" \
|
|
||||||
$count $failed $fsize
|
|
||||||
- return 2
|
|
||||||
+
|
|
||||||
+ test $failed -eq 0 || return 2
|
|
||||||
}
|
|
||||||
|
|
||||||
#
|
|
@ -1,49 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 143839] chreipl/virtio: fix chreipl node for virtio-blk disks
|
|
||||||
From: Christian Borntraeger <borntraeger@de.ibm.com>
|
|
||||||
|
|
||||||
Description: chreipl/virtio: fix chreipl node for virtio-blk disks
|
|
||||||
Symptom: chreipl node <mount point> for a virtio-blk disk fails:
|
|
||||||
Could not find DASD CCW device "virtio1"
|
|
||||||
Problem: The sysfs walking code to resolve the device is not
|
|
||||||
handling virtio devices correctly.
|
|
||||||
Solution: Use the realpath of the device to get the busid for all
|
|
||||||
supported devices.
|
|
||||||
Reproduction: Run chreipl node <mountpoint> with virtio-blk devices as
|
|
||||||
backing for mount point.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 143839
|
|
||||||
|
|
||||||
Signed-off-by: Christian Borntraeger <borntraeger@de.ibm.com>
|
|
||||||
---
|
|
||||||
ipl_tools/ccw.c | 12 +++++-------
|
|
||||||
1 file changed, 5 insertions(+), 7 deletions(-)
|
|
||||||
|
|
||||||
--- a/ipl_tools/ccw.c
|
|
||||||
+++ b/ipl_tools/ccw.c
|
|
||||||
@@ -76,21 +76,19 @@ out_fclose:
|
|
||||||
static int ccw_busid_get_sysfs_new(const char *device, char *busid)
|
|
||||||
{
|
|
||||||
char path[PATH_MAX], buf[4096];
|
|
||||||
- char *ptr;
|
|
||||||
|
|
||||||
memset(buf, 0, sizeof(buf));
|
|
||||||
snprintf(path, sizeof(path), "/sys/block/%s/device", device);
|
|
||||||
- if (readlink(path, buf, sizeof(buf) - 1) == -1)
|
|
||||||
+ if (realpath(path, buf) == NULL)
|
|
||||||
return -1;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* The output has the following format:
|
|
||||||
- * ../../../0.0.4e13
|
|
||||||
+ * /sys/devices/css0/0.0.0119/0.0.3f19/block/dasda
|
|
||||||
+ * /sys/devices/css0/0.0.0000/0.0.0000/virtio0/block/vda
|
|
||||||
*/
|
|
||||||
- ptr = strrchr(buf, '/');
|
|
||||||
- if (!ptr)
|
|
||||||
- ERR_EXIT("Could not read \"%s\"", path);
|
|
||||||
- strncpy(busid, ptr + 1, 9);
|
|
||||||
+ if (sscanf(buf, "/sys/devices/css0/%*[0-9a-f.]/%[0-9a-f.]", busid) != 1)
|
|
||||||
+ return -1;
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
@ -1,32 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 147113] chzdev: Disable root device update mechanism
|
|
||||||
From: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: chzdev: Disable root device update mechanism
|
|
||||||
Symptom: chzdev reports problems updating /etc/zipl.conf and running
|
|
||||||
zipl.
|
|
||||||
Problem: When chzdev changes the root device persistent configuration,
|
|
||||||
it performs additional steps to ensure that these changes are
|
|
||||||
correctly applied. Example for such steps are: updating the
|
|
||||||
initial RAM disk, modifying the zipl.conf configuration file
|
|
||||||
and running zipl. As these steps are incompatible with the target
|
|
||||||
distribution, they fail.
|
|
||||||
Solution: Suppress chzdev's root device update mechanism.
|
|
||||||
Reproduction: chzdev --enable --persistent --by-path /
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 147113
|
|
||||||
|
|
||||||
Signed-off-by: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
zdev/src/chzdev.c | 1 +
|
|
||||||
1 file changed, 1 insertion(+)
|
|
||||||
|
|
||||||
--- a/zdev/src/chzdev.c
|
|
||||||
+++ b/zdev/src/chzdev.c
|
|
||||||
@@ -233,6 +233,7 @@ static void init_options(struct options
|
|
||||||
opts->settings = strlist_new();
|
|
||||||
opts->remove = strlist_new();
|
|
||||||
opts->base = strlist_new();
|
|
||||||
+ opts->no_root_check = 1;
|
|
||||||
}
|
|
||||||
|
|
||||||
/* Release memory used in options data structure. */
|
|
@ -1,744 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1213] dasd: add query host access to volume support
|
|
||||||
From: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasd: add query host access to volume support
|
|
||||||
Description: With this feature, applications can query if a DASD volume is
|
|
||||||
online to another operating system instances by checking the
|
|
||||||
online status of all attached hosts from the storage server.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1213
|
|
||||||
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.8 | 7 ++
|
|
||||||
dasdfmt/dasdfmt.c | 38 ++++++++++++--
|
|
||||||
dasdfmt/dasdfmt.h | 4 +
|
|
||||||
fdasd/fdasd.8 | 9 ++-
|
|
||||||
fdasd/fdasd.c | 32 ++++++++++++
|
|
||||||
fdasd/fdasd.h | 28 +++++-----
|
|
||||||
include/libzds.h | 1
|
|
||||||
include/u2s.h | 5 +
|
|
||||||
libu2s/u2s.c | 43 ++++++++++++++++
|
|
||||||
libzds/Makefile | 2
|
|
||||||
libzds/libzds.c | 46 +++++++++++++++--
|
|
||||||
zconf/lsdasd | 139 +++++++++++++++++++++++++++++++++++++++++++++++++++++-
|
|
||||||
zconf/lsdasd.8 | 5 +
|
|
||||||
zdsfs/zdsfs.1 | 4 +
|
|
||||||
zdsfs/zdsfs.c | 18 ++++++
|
|
||||||
15 files changed, 345 insertions(+), 36 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.8
|
|
||||||
+++ b/dasdfmt/dasdfmt.8
|
|
||||||
@@ -7,7 +7,7 @@ dasdfmt \- formatting of DASD (ECKD) dis
|
|
||||||
.br
|
|
||||||
[-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
|
|
||||||
.br
|
|
||||||
- [-L] [-V] [-F] [-k] \fIdevice\fR
|
|
||||||
+ [-L] [-V] [-F] [-k] [-C] \fIdevice\fR
|
|
||||||
|
|
||||||
.SH DESCRIPTION
|
|
||||||
\fBdasdfmt\fR formats a DASD (ECKD) disk drive to prepare it
|
|
||||||
@@ -70,6 +70,11 @@ Print version number and exit.
|
|
||||||
Formats the device without checking, if the device is in use.
|
|
||||||
|
|
||||||
.TP
|
|
||||||
+\fB-C\fR or \fB--check_host_count\fR
|
|
||||||
+Force dasdfmt to check the host access open count to ensure the device
|
|
||||||
+is not online on another operating system instance
|
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
\fB-d\fR \fIlayout\fR or \fB--disk_layout\fR=\fIlayout\fR
|
|
||||||
Formats the device with compatible disk layout or linux disk layout.
|
|
||||||
\fIlayout\fR is either \fIcdl\fR for the compatible disk layout
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -18,6 +18,8 @@
|
|
||||||
#include "util_proc.h"
|
|
||||||
#include "dasd_sys.h"
|
|
||||||
|
|
||||||
+#define BUSIDSIZE 8
|
|
||||||
+
|
|
||||||
/* Full tool name */
|
|
||||||
static const char tool_name[] = "dasdfmt: zSeries DASD format program";
|
|
||||||
|
|
||||||
@@ -46,7 +48,7 @@ print_version (void)
|
|
||||||
*/
|
|
||||||
static void exit_usage(int exitcode)
|
|
||||||
{
|
|
||||||
- printf("Usage: %s [-htvypPLVFk]\n"
|
|
||||||
+ printf("Usage: %s [-htvypPLVFkC]\n"
|
|
||||||
" [-l <volser> | --label=<volser>]\n"
|
|
||||||
" [-b <blocksize> | --blocksize=<blocksize>]\n"
|
|
||||||
" [-d <disk layout> | --disk_layout=<disk layout>]\n"
|
|
||||||
@@ -65,6 +67,9 @@ static void exit_usage(int exitcode)
|
|
||||||
" -v means verbose mode\n"
|
|
||||||
" -F means don't check if the device is in use\n"
|
|
||||||
" -k means keep volume serial\n"
|
|
||||||
+ " -C or --check_host_count means force dasdfmt to check\n"
|
|
||||||
+ " the host access open count to ensure the device\n"
|
|
||||||
+ " is not online on another operating system instance\n"
|
|
||||||
" --norecordzero prevent storage server from modifying"
|
|
||||||
" record 0\n\n"
|
|
||||||
" <volser> is the volume identifier, which is converted\n"
|
|
||||||
@@ -190,7 +195,6 @@ static void get_device_name(dasdfmt_info
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* initialize the dasdfmt info structure
|
|
||||||
*/
|
|
||||||
@@ -214,6 +218,7 @@ static void init_info(dasdfmt_info_t *in
|
|
||||||
info->node_specified = 0;
|
|
||||||
info->device_id = 0;
|
|
||||||
info->keep_volser = 0;
|
|
||||||
+ info->force_host = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -776,6 +781,7 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
dasd_information_t dasd_info;
|
|
||||||
struct dasd_eckd_characteristics *characteristics;
|
|
||||||
unsigned int cylinders, heads;
|
|
||||||
+ int count;
|
|
||||||
|
|
||||||
if (info->verbosity > 0) printf("Retrieving disk geometry...\n");
|
|
||||||
|
|
||||||
@@ -835,6 +841,27 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
if ((info->verbosity > 0) || (!info->withoutprompt))
|
|
||||||
dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
|
||||||
|
|
||||||
+ count = u2s_get_host_access_count(info->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);
|
|
||||||
+ } else if (count < 0) {
|
|
||||||
+ ERRMSG("\nHosts access information not available for disk %s.\n\n",
|
|
||||||
+ info->devname);
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ } else if (count > 1)
|
|
||||||
+ ERRMSG("\nWARNING:\n"
|
|
||||||
+ "Disk %s is online on operating system instances in %d different LPARs.\n"
|
|
||||||
+ "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);
|
|
||||||
+
|
|
||||||
if (!info->testmode) {
|
|
||||||
if (!info->withoutprompt) {
|
|
||||||
printf("\n--->> ATTENTION! <<---\n");
|
|
||||||
@@ -916,10 +943,6 @@ int main(int argc,char *argv[])
|
|
||||||
info.force=1;
|
|
||||||
break;
|
|
||||||
|
|
||||||
- case 'C':
|
|
||||||
- format_params.intensity |= DASD_FMT_INT_COMPAT;
|
|
||||||
- break;
|
|
||||||
-
|
|
||||||
case 'd' :
|
|
||||||
if (strncmp(optarg,"cdl",3)==0)
|
|
||||||
{
|
|
||||||
@@ -1017,6 +1040,9 @@ int main(int argc,char *argv[])
|
|
||||||
case 'k' :
|
|
||||||
info.keep_volser=1;
|
|
||||||
break;
|
|
||||||
+ case 'C':
|
|
||||||
+ info.force_host = 1;
|
|
||||||
+ break;
|
|
||||||
case -1:
|
|
||||||
/* End of options string - start of devices list */
|
|
||||||
info.device_id = optind;
|
|
||||||
--- a/dasdfmt/dasdfmt.h
|
|
||||||
+++ b/dasdfmt/dasdfmt.h
|
|
||||||
@@ -214,7 +214,7 @@ typedef struct format_data_t {
|
|
||||||
if (*endptr) ERRMSG_EXIT(EXIT_MISUSE,"%s: " str " " \
|
|
||||||
"is in invalid format\n",prog_name);}
|
|
||||||
|
|
||||||
-#define dasdfmt_getopt_string "b:n:l:f:d:m:r:hpPLtyvVFk"
|
|
||||||
+#define dasdfmt_getopt_string "b:n:l:f:d:m:r:hpPLtyvVFkC"
|
|
||||||
|
|
||||||
static struct option dasdfmt_getopt_long_options[]=
|
|
||||||
{
|
|
||||||
@@ -233,6 +233,7 @@ static struct option dasdfmt_getopt_long
|
|
||||||
{ "help", 0, 0, 'h'},
|
|
||||||
{ "keep_volser", 0, 0, 'k'},
|
|
||||||
{ "norecordzero", 0, 0, 'z'},
|
|
||||||
+ { "check_host_count", 0, 0, 'C'},
|
|
||||||
{0, 0, 0, 0}
|
|
||||||
};
|
|
||||||
|
|
||||||
@@ -265,6 +266,7 @@ typedef struct dasdfmt_info {
|
|
||||||
int node_specified;
|
|
||||||
int device_id;
|
|
||||||
int keep_volser;
|
|
||||||
+ int force_host;
|
|
||||||
} dasdfmt_info_t;
|
|
||||||
|
|
||||||
|
|
||||||
--- a/fdasd/fdasd.8
|
|
||||||
+++ b/fdasd/fdasd.8
|
|
||||||
@@ -4,11 +4,11 @@ fdasd \- partitioning tool.
|
|
||||||
.SH SYNOPSIS
|
|
||||||
interactive mode:
|
|
||||||
.br
|
|
||||||
- \fBfdasd\fR [-s] [-r] \fIdevice\fR
|
|
||||||
+ \fBfdasd\fR [-s] [-r] [-C] \fIdevice\fR
|
|
||||||
.br
|
|
||||||
command line mode:
|
|
||||||
.br
|
|
||||||
- \fBfdasd\fR [-s] [-r] {-a[-k|-l \fIvolser\fR]|-i|-p|-c \fIconf_file\fR}
|
|
||||||
+ \fBfdasd\fR [-s] [-r] [-C] {-a[-k|-l \fIvolser\fR]|-i|-p|-c \fIconf_file\fR}
|
|
||||||
[-f \fI[type,blocksize]\fR] \fIdevice\fR
|
|
||||||
.br
|
|
||||||
help:
|
|
||||||
@@ -131,6 +131,11 @@ In combination with the -s option fdasd
|
|
||||||
partition table.
|
|
||||||
|
|
||||||
.TP
|
|
||||||
+\fB-C\fR or \fB--check_host_count\fR
|
|
||||||
+Force fdasd to check the host access open count to ensure the device
|
|
||||||
+is not online on another operating system instance
|
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
\fB-f\fR \fI[type,blocksize]\fR or \fB--force\fR \fI[type,blocksize]\fR
|
|
||||||
Force fdasd to work on non DASD devices.
|
|
||||||
.br
|
|
||||||
--- a/fdasd/fdasd.c
|
|
||||||
+++ b/fdasd/fdasd.c
|
|
||||||
@@ -369,7 +369,10 @@ fdasd_usage (void)
|
|
||||||
" found in CONFIGFILE\n"
|
|
||||||
"-i, --volser Print volume serial\n"
|
|
||||||
"-p, --table Print partition table\n"
|
|
||||||
- "-f, --force Force fdasd to work on non DASD devices\n");
|
|
||||||
+ "-f, --force Force fdasd to work on non DASD devices\n"
|
|
||||||
+ "-C, --check_host_count Force fdasd to check the host access\n"
|
|
||||||
+ " open count to ensure the device is not\n"
|
|
||||||
+ " online on another operating system instance\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -572,6 +575,9 @@ fdasd_parse_options (fdasd_anchor_t *anc
|
|
||||||
anc->force_virtual++;
|
|
||||||
fdasd_parse_force_options(anc, optarg);
|
|
||||||
break;
|
|
||||||
+ case 'C':
|
|
||||||
+ anc->force_host++;
|
|
||||||
+ break;
|
|
||||||
case -1:
|
|
||||||
/* End of options string - start of devices list */
|
|
||||||
break;
|
|
||||||
@@ -824,6 +830,7 @@ fdasd_verify_device (fdasd_anchor_t *anc
|
|
||||||
{
|
|
||||||
struct stat dst;
|
|
||||||
char err_str[ERROR_STRING_SIZE];
|
|
||||||
+ int count;
|
|
||||||
|
|
||||||
if ((stat(name, &dst)) < 0 ) {
|
|
||||||
snprintf(err_str, ERROR_STRING_SIZE,
|
|
||||||
@@ -856,6 +863,29 @@ fdasd_verify_device (fdasd_anchor_t *anc
|
|
||||||
fdasd_error(anc, device_verification_failed, err_str);
|
|
||||||
}
|
|
||||||
|
|
||||||
+ count = u2s_get_host_access_count(name);
|
|
||||||
+ if (anc->force_host) {
|
|
||||||
+ if (count > 1) {
|
|
||||||
+ snprintf(err_str, ERROR_STRING_SIZE,
|
|
||||||
+ "Disk %s is online on operating system 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",
|
|
||||||
+ name, count);
|
|
||||||
+ fdasd_error(anc, device_verification_failed, err_str);
|
|
||||||
+ } else if (count < 0) {
|
|
||||||
+ snprintf(err_str, ERROR_STRING_SIZE,
|
|
||||||
+ "Hosts access information not available for disk %s.\n",
|
|
||||||
+ name);
|
|
||||||
+ fdasd_error(anc, device_verification_failed, err_str);
|
|
||||||
+ }
|
|
||||||
+ } else if (count > 1)
|
|
||||||
+ printf("\nWARNING:\n"
|
|
||||||
+ "Disk %s is online on operating system instances in %d different LPARs.\n"
|
|
||||||
+ "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\n",
|
|
||||||
+ name, count);
|
|
||||||
+
|
|
||||||
if (anc->verbose)
|
|
||||||
printf("Verification successful for '%s' (%d/%d)\n", name,
|
|
||||||
(unsigned short) major(dst.st_rdev),
|
|
||||||
--- a/fdasd/fdasd.h
|
|
||||||
+++ b/fdasd/fdasd.h
|
|
||||||
@@ -157,22 +157,23 @@ struct dasd_eckd_characteristics {
|
|
||||||
#define PARTITION_GPFS 5
|
|
||||||
|
|
||||||
static struct option fdasd_long_options[] = {
|
|
||||||
- { "version", no_argument, NULL, 'v'},
|
|
||||||
- { "auto", no_argument, NULL, 'a'},
|
|
||||||
- { "silent", no_argument, NULL, 's'},
|
|
||||||
- { "verbose", no_argument, NULL, 'r'},
|
|
||||||
- { "label", required_argument, NULL, 'l'},
|
|
||||||
- { "config", required_argument, NULL, 'c'},
|
|
||||||
- { "help", no_argument, NULL, 'h'},
|
|
||||||
- { "table", no_argument, NULL, 'p'},
|
|
||||||
- { "volser", no_argument, NULL, 'i'},
|
|
||||||
- { "keep_volser", no_argument, NULL, 'k'},
|
|
||||||
- { "force", optional_argument, NULL, 'f'},
|
|
||||||
- { 0, 0, 0, 0 }
|
|
||||||
+ { "version", no_argument, NULL, 'v'},
|
|
||||||
+ { "auto", no_argument, NULL, 'a'},
|
|
||||||
+ { "silent", no_argument, NULL, 's'},
|
|
||||||
+ { "verbose", no_argument, NULL, 'r'},
|
|
||||||
+ { "label", required_argument, NULL, 'l'},
|
|
||||||
+ { "config", required_argument, NULL, 'c'},
|
|
||||||
+ { "help", no_argument, NULL, 'h'},
|
|
||||||
+ { "table", no_argument, NULL, 'p'},
|
|
||||||
+ { "volser", no_argument, NULL, 'i'},
|
|
||||||
+ { "keep_volser", no_argument, NULL, 'k'},
|
|
||||||
+ { "force", optional_argument, NULL, 'f'},
|
|
||||||
+ { "check_host_count", no_argument, NULL, 'C'},
|
|
||||||
+ { 0, 0, 0, 0 }
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Command line option abbreviations */
|
|
||||||
-static const char option_string[] = "vasrl:c:hpikf::";
|
|
||||||
+static const char option_string[] = "vasrl:c:hpikf::C";
|
|
||||||
|
|
||||||
struct fdasd_options {
|
|
||||||
char *device;
|
|
||||||
@@ -214,6 +215,7 @@ typedef struct fdasd_anchor {
|
|
||||||
int print_volser;
|
|
||||||
int keep_volser;
|
|
||||||
int force_virtual;
|
|
||||||
+ int force_host;
|
|
||||||
int big_disk;
|
|
||||||
int silent;
|
|
||||||
int verbose;
|
|
||||||
--- a/include/libzds.h
|
|
||||||
+++ b/include/libzds.h
|
|
||||||
@@ -803,6 +803,7 @@ int lzds_zdsroot_extract_datasets_from_d
|
|
||||||
void lzds_DS1RECFM_to_recfm(char DS1RECFM, char *buffer);
|
|
||||||
|
|
||||||
|
|
||||||
+int lzds_analyse_open_count(struct zdsroot *root, int warn);
|
|
||||||
|
|
||||||
/** @} */ /* end of group libzds_functions_helper */
|
|
||||||
|
|
||||||
--- a/include/u2s.h
|
|
||||||
+++ b/include/u2s.h
|
|
||||||
@@ -13,7 +13,8 @@
|
|
||||||
|
|
||||||
#define U2S_BUS_ID_SIZE 32
|
|
||||||
|
|
||||||
-int
|
|
||||||
-u2s_getbusid(char * devicenode, char * busid);
|
|
||||||
+int u2s_getbusid(char *, char *);
|
|
||||||
+int u2s_read_attribute(char *, char *, char *, size_t);
|
|
||||||
+int u2s_get_host_access_count(char *);
|
|
||||||
|
|
||||||
#endif /* U2S_H */
|
|
||||||
--- a/libu2s/u2s.c
|
|
||||||
+++ b/libu2s/u2s.c
|
|
||||||
@@ -17,6 +17,7 @@
|
|
||||||
#include <fcntl.h>
|
|
||||||
#include <sys/sysmacros.h>
|
|
||||||
#include <dirent.h>
|
|
||||||
+#include <stdlib.h>
|
|
||||||
|
|
||||||
#include "u2s.h"
|
|
||||||
|
|
||||||
@@ -282,3 +283,45 @@ int u2s_getbusid(char *devicenode, char
|
|
||||||
|
|
||||||
return rc;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * Attempts to find the sysfs entry for the given busid and reads
|
|
||||||
+ * the contents of a specified attribute to the buffer
|
|
||||||
+ */
|
|
||||||
+int u2s_read_attribute(char *busid, char *attribute, char *buffer,
|
|
||||||
+ size_t count)
|
|
||||||
+{
|
|
||||||
+ char path[100];
|
|
||||||
+ int rc, fd;
|
|
||||||
+ ssize_t rcount;
|
|
||||||
+
|
|
||||||
+ rc = 0;
|
|
||||||
+ snprintf(path, sizeof(path), "/sys/bus/ccw/devices/%s/%s",
|
|
||||||
+ busid, attribute);
|
|
||||||
+ fd = open(path, O_RDONLY);
|
|
||||||
+ if (fd < 0)
|
|
||||||
+ return errno;
|
|
||||||
+ rcount = read(fd, buffer, count);
|
|
||||||
+ if (rcount < 0)
|
|
||||||
+ rc = errno;
|
|
||||||
+ close(fd);
|
|
||||||
+ return rc;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+int u2s_get_host_access_count(char *devicenode)
|
|
||||||
+{
|
|
||||||
+ char busid[BUSIDSIZE];
|
|
||||||
+ unsigned long value;
|
|
||||||
+ char buffer[10];
|
|
||||||
+ char *endp;
|
|
||||||
+
|
|
||||||
+ u2s_getbusid(devicenode, busid);
|
|
||||||
+ u2s_read_attribute(busid, "host_access_count", buffer, sizeof(buffer));
|
|
||||||
+
|
|
||||||
+ value = strtoul(buffer, &endp, 0);
|
|
||||||
+
|
|
||||||
+ if (endp == buffer)
|
|
||||||
+ return -EINVAL;
|
|
||||||
+
|
|
||||||
+ return value;
|
|
||||||
+}
|
|
||||||
--- a/libzds/Makefile
|
|
||||||
+++ b/libzds/Makefile
|
|
||||||
@@ -8,7 +8,7 @@ CFLAGS += -D_FILE_OFFSET_BITS=64
|
|
||||||
|
|
||||||
all: libzds.a
|
|
||||||
|
|
||||||
-libzds.a: libzds.o $(rootdir)/libutil/util_list.o $(rootdir)/libvtoc/vtoc.o
|
|
||||||
+libzds.a: libzds.o $(rootdir)/libutil/util_list.o $(rootdir)/libvtoc/vtoc.o $(rootdir)/libu2s/u2s.o
|
|
||||||
|
|
||||||
libzds.o: ../include/libzds.h
|
|
||||||
|
|
||||||
--- a/libzds/libzds.c
|
|
||||||
+++ b/libzds/libzds.c
|
|
||||||
@@ -29,6 +29,7 @@
|
|
||||||
#include "libzds.h"
|
|
||||||
|
|
||||||
#include "util.h"
|
|
||||||
+#include "u2s.h"
|
|
||||||
|
|
||||||
#include <malloc.h>
|
|
||||||
#include <linux/types.h>
|
|
||||||
@@ -72,6 +73,8 @@ struct errorlog {
|
|
||||||
*/
|
|
||||||
#define ERRORMSG 240
|
|
||||||
|
|
||||||
+#define BUSIDSIZE 8
|
|
||||||
+
|
|
||||||
/**
|
|
||||||
* @brief An internal structure that represents an entry in the error log.
|
|
||||||
*/
|
|
||||||
@@ -3760,15 +3763,46 @@ void lzds_DS1RECFM_to_recfm(char DS1RECF
|
|
||||||
*/
|
|
||||||
}
|
|
||||||
|
|
||||||
+int lzds_analyse_open_count(struct zdsroot *root, int warn)
|
|
||||||
+{
|
|
||||||
+ struct dasd *dasd;
|
|
||||||
+ int value;
|
|
||||||
+ int rc = 0;
|
|
||||||
|
|
||||||
+ util_list_iterate(root->dasdlist, dasd) {
|
|
||||||
+ value = u2s_get_host_access_count(dasd->device);
|
|
||||||
|
|
||||||
+ if (value < 0) {
|
|
||||||
+ fprintf(stderr,
|
|
||||||
+ "Hosts access information not available for disk %s.\n",
|
|
||||||
+ dasd->device);
|
|
||||||
+ rc = value;
|
|
||||||
+ continue;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
+ if (value == 1)
|
|
||||||
+ continue;
|
|
||||||
|
|
||||||
+ if (warn)
|
|
||||||
+ fprintf(stderr,
|
|
||||||
+ "\nWARNING:\n"
|
|
||||||
+ "Disk %s is online on operating system instances in %d different LPARs.\n"
|
|
||||||
+ "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",
|
|
||||||
+ dasd->device, value);
|
|
||||||
+ else {
|
|
||||||
+ fprintf(stderr,
|
|
||||||
+ "\nERROR:\n"
|
|
||||||
+ "Disk %s is online on operating system instances in %d different LPARs.\n"
|
|
||||||
+ "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",
|
|
||||||
+ dasd->device, value);
|
|
||||||
+ rc = -EACCES;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
|
|
||||||
-
|
|
||||||
-
|
|
||||||
-
|
|
||||||
-
|
|
||||||
-
|
|
||||||
-
|
|
||||||
+ return rc;
|
|
||||||
+}
|
|
||||||
|
|
||||||
--- a/zconf/lsdasd
|
|
||||||
+++ b/zconf/lsdasd
|
|
||||||
@@ -30,6 +30,8 @@ function PrintUsage() {
|
|
||||||
Print old version of lsdasd output.
|
|
||||||
-l|--long
|
|
||||||
Print extended information about DASDs.
|
|
||||||
+ -H|--host-access-list
|
|
||||||
+ Print information about hosts accessing DASDs.
|
|
||||||
-v|--verbose
|
|
||||||
For compatibility/future use. Currently ignored.
|
|
||||||
--version
|
|
||||||
@@ -115,6 +117,33 @@ function listDASDDeviceDirectories() {
|
|
||||||
}
|
|
||||||
|
|
||||||
#------------------------------------------------------------------------------
|
|
||||||
+# find dasd directory in debugfs
|
|
||||||
+#------------------------------------------------------------------------------
|
|
||||||
+function findDASDDebugfsDirectorie() {
|
|
||||||
+ local mntentries
|
|
||||||
+
|
|
||||||
+ while read -a mntentries
|
|
||||||
+ do
|
|
||||||
+ if [[ "${mntentries[2]}" == "debugfs" ]]
|
|
||||||
+ then
|
|
||||||
+ DASD_DBF_DIR="${mntentries[1]}"
|
|
||||||
+ break;
|
|
||||||
+ fi
|
|
||||||
+ done < /etc/mtab
|
|
||||||
+ if [[ "$DASD_DBF_DIR" == "" ]]
|
|
||||||
+ then
|
|
||||||
+ echo "$CMD: No debugfs mount point found" >&2
|
|
||||||
+ exit 1
|
|
||||||
+ fi
|
|
||||||
+ DASD_DBF_DIR="$DASD_DBF_DIR/dasd"
|
|
||||||
+ if [[ ! -d "$DASD_DBF_DIR" ]]
|
|
||||||
+ then
|
|
||||||
+ echo "$CMD: Default DASD debugfs directory $DASD_DBF_DIR does not exist" >&2
|
|
||||||
+ exit 1
|
|
||||||
+ fi
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+#------------------------------------------------------------------------------
|
|
||||||
# gather device data and call appropriate output function
|
|
||||||
#------------------------------------------------------------------------------
|
|
||||||
function gatherDeviceData() {
|
|
||||||
@@ -197,6 +226,8 @@ function gatherDeviceData() {
|
|
||||||
extended
|
|
||||||
elif [[ "$PRINTUID" == "true" ]]; then
|
|
||||||
uid
|
|
||||||
+ elif [[ "$OUTPUT" == "host" ]]; then
|
|
||||||
+ host
|
|
||||||
else
|
|
||||||
newoutput
|
|
||||||
fi
|
|
||||||
@@ -527,6 +558,104 @@ function extended()
|
|
||||||
"${HPF_PATHS[@]}" ;
|
|
||||||
}
|
|
||||||
|
|
||||||
+function host()
|
|
||||||
+{
|
|
||||||
+findDASDDebugfsDirectorie
|
|
||||||
+
|
|
||||||
+if [[ ! -f "$DASD_DBF_DIR/$BUSID/host_access_list" ]]
|
|
||||||
+then
|
|
||||||
+ printf "\n%s: hosts access information not available\n" "$BUSID"
|
|
||||||
+ return
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
+local temp=`mktemp /tmp/lsdasd.XXXXXX`
|
|
||||||
+if test -w $temp ; then :; else
|
|
||||||
+ printf "\nCreating temporary file failed\n"
|
|
||||||
+ return
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
+cat $DASD_DBF_DIR/$BUSID/host_access_list > $temp 2> /dev/null
|
|
||||||
+ret=$?
|
|
||||||
+if [[ $ret -ne 0 ]]
|
|
||||||
+then
|
|
||||||
+ printf "%s: hosts access information not available\n" "$BUSID"
|
|
||||||
+ rm -f $temp
|
|
||||||
+ return $ret
|
|
||||||
+fi
|
|
||||||
+
|
|
||||||
+unset index
|
|
||||||
+unset array
|
|
||||||
+declare -a array
|
|
||||||
+
|
|
||||||
+index=(pgid status_flags sysplex_name supported_cylinder timestamp)
|
|
||||||
+
|
|
||||||
+for element in ${index[@]}
|
|
||||||
+do
|
|
||||||
+ count=0
|
|
||||||
+
|
|
||||||
+ declare -a $element
|
|
||||||
+ OLDIFS=$IFS
|
|
||||||
+ IFS=$'\n'
|
|
||||||
+ for value in `grep $element $temp`
|
|
||||||
+ do
|
|
||||||
+ (( ++count ))
|
|
||||||
+ value=$(echo -e $value | cut -d ' ' -f2)
|
|
||||||
+ eval $element[$count]=$value
|
|
||||||
+ done
|
|
||||||
+ IFS=$OLDIFS
|
|
||||||
+done
|
|
||||||
+
|
|
||||||
+printf "Host information for %s\n" "$BUSID";
|
|
||||||
+printf "Path-Group-ID LPAR CPU FL Status Sysplex Max_Cyls Time\n";
|
|
||||||
+printf "================================================================================\n";
|
|
||||||
+
|
|
||||||
+# mask bits for online and reserved state
|
|
||||||
+online_reserved_mask=0xE0
|
|
||||||
+
|
|
||||||
+# print name value lists
|
|
||||||
+for i in `seq 1 $count`;
|
|
||||||
+do
|
|
||||||
+ # get flags field
|
|
||||||
+ value=${status_flags[$i]}
|
|
||||||
+ # mark as hex value
|
|
||||||
+ value=0x$value
|
|
||||||
+ # mask online and reserved bits
|
|
||||||
+ value=$(($value & $online_reserved_mask))
|
|
||||||
+
|
|
||||||
+ case $value in
|
|
||||||
+ 0 ) # 0x00
|
|
||||||
+ STATE="OFF"
|
|
||||||
+ ;;
|
|
||||||
+ 32 ) # 0x20
|
|
||||||
+ STATE="OFF-RSV"
|
|
||||||
+ ;;
|
|
||||||
+ 64 ) # 0x40
|
|
||||||
+ STATE="ON"
|
|
||||||
+ ;;
|
|
||||||
+ 96 ) # 0x60
|
|
||||||
+ STATE="ON-RSV"
|
|
||||||
+ ;;
|
|
||||||
+ * )
|
|
||||||
+ STATE="-"
|
|
||||||
+ ;;
|
|
||||||
+ esac
|
|
||||||
+
|
|
||||||
+ printf "%22s %02s %07s %02s %-6s %-8s %11u %10lu\n" \
|
|
||||||
+ "${pgid[$i]}" \
|
|
||||||
+ "${pgid[$i]:4:2}" \
|
|
||||||
+ "${pgid[$i]:6:4}" \
|
|
||||||
+ "${status_flags[$i]}" \
|
|
||||||
+ "$STATE" \
|
|
||||||
+ "${sysplex_name[$i]}" \
|
|
||||||
+ "${supported_cylinder[$i]}" \
|
|
||||||
+ "${timestamp[$i]}" \
|
|
||||||
+ ;
|
|
||||||
+done
|
|
||||||
+printf "\n";
|
|
||||||
+
|
|
||||||
+rm -f $temp
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
function uid()
|
|
||||||
{
|
|
||||||
#-------------------------------------------#
|
|
||||||
@@ -586,6 +715,9 @@ while [ $# -gt 0 ]; do
|
|
||||||
--long|-l)
|
|
||||||
OUTPUT="extended"
|
|
||||||
;;
|
|
||||||
+ --host-access-list|-H)
|
|
||||||
+ OUTPUT="host"
|
|
||||||
+ ;;
|
|
||||||
--version)
|
|
||||||
PrintVersion
|
|
||||||
exit 0
|
|
||||||
@@ -626,8 +758,13 @@ fi
|
|
||||||
|
|
||||||
# gather information on devices in list
|
|
||||||
PROCESSING=" $PROCESSING | gatherDeviceData "
|
|
||||||
+
|
|
||||||
# sort resulting list
|
|
||||||
-PROCESSING=" $PROCESSING | sort -t: -k1n -k2 | cut -d: -f3- "
|
|
||||||
+if [[ "$OUTPUT" == "host" ]]; then
|
|
||||||
+ PROCESSING=" $PROCESSING"
|
|
||||||
+else
|
|
||||||
+ PROCESSING=" $PROCESSING | sort -t: -k1n -k2 | cut -d: -f3- "
|
|
||||||
+fi
|
|
||||||
|
|
||||||
if [[ "$PRINTUID" == "true" ]] && [[ "$OUTPUT" != "old" ]]; then
|
|
||||||
printf "Bus-ID Name UID\n"
|
|
||||||
--- a/zconf/lsdasd.8
|
|
||||||
+++ b/zconf/lsdasd.8
|
|
||||||
@@ -40,11 +40,14 @@ Include only base devices.
|
|
||||||
Old output of lsdasd for compatibility.
|
|
||||||
.TP
|
|
||||||
.BR -l | --long
|
|
||||||
-Extended output of lsdasd including UID, attributes and path information.
|
|
||||||
+Extended output of lsdasd including UID and attributes.
|
|
||||||
.TP
|
|
||||||
.BR -u | --uid
|
|
||||||
Output includes and is sorted by UID.
|
|
||||||
.TP
|
|
||||||
+.BR -H | --host-acces
|
|
||||||
+Show information about all hosts using this device.
|
|
||||||
+.TP
|
|
||||||
.BR -v | --verbose
|
|
||||||
Only for compatibility (and maybe future) use. This option currently does
|
|
||||||
nothing.
|
|
||||||
--- a/zdsfs/zdsfs.1
|
|
||||||
+++ b/zdsfs/zdsfs.1
|
|
||||||
@@ -150,6 +150,10 @@ If \fI<s>\fR is set to 0, no seek histor
|
|
||||||
case `seek' is still supported, but a `seek' operation might result in a
|
|
||||||
read from the beginning of the data set.
|
|
||||||
|
|
||||||
+.TP
|
|
||||||
+\fB\-o\fR check_host_count
|
|
||||||
+Stop processing if the device is used by another operating system instance.
|
|
||||||
+
|
|
||||||
.SS "Applicable FUSE options (version 2.8):"
|
|
||||||
This is a selected subset of all FUSE options. Use the zdsfs
|
|
||||||
\fB\--help\fR option to print a full list.
|
|
||||||
--- a/zdsfs/zdsfs.c
|
|
||||||
+++ b/zdsfs/zdsfs.c
|
|
||||||
@@ -39,6 +39,7 @@ struct zdsfs_info {
|
|
||||||
int devcount;
|
|
||||||
int allow_inclomplete_multi_volume;
|
|
||||||
int keepRDW;
|
|
||||||
+ int host_count;
|
|
||||||
unsigned int tracks_per_frame;
|
|
||||||
unsigned long long seek_buffer_size;
|
|
||||||
struct zdsroot *zdsroot;
|
|
||||||
@@ -765,6 +766,7 @@ static const struct fuse_opt zdsfs_opts[
|
|
||||||
FUSE_OPT_KEY("seekbuffer=", KEY_SEEKBUFFER),
|
|
||||||
ZDSFS_OPT("rdw", keepRDW, 1),
|
|
||||||
ZDSFS_OPT("ignore_incomplete", allow_inclomplete_multi_volume, 1),
|
|
||||||
+ ZDSFS_OPT("check_host_count", host_count, 1),
|
|
||||||
FUSE_OPT_END
|
|
||||||
};
|
|
||||||
|
|
||||||
@@ -790,7 +792,10 @@ static void usage(const char *progname)
|
|
||||||
" data set are missing\n"
|
|
||||||
" -o tracks=N Size of the track buffer in tracks (default 128)\n"
|
|
||||||
" -o seekbuffer=S Upper limit in bytes for the seek history buffer\n"
|
|
||||||
-" size (default 1048576)\n", progname);
|
|
||||||
+" size (default 1048576)\n"
|
|
||||||
+" -o check_host_count Stop processing if the device is used by another\n"
|
|
||||||
+" operating system instance\n"
|
|
||||||
+ , progname);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void zdsfs_process_device(const char *device)
|
|
||||||
@@ -1014,6 +1019,17 @@ int main(int argc, char *argv[])
|
|
||||||
argv[0]);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+ if (zdsfsinfo.host_count) {
|
|
||||||
+ /* check, print error and exit if multiple online */
|
|
||||||
+ rc = lzds_analyse_open_count(zdsfsinfo.zdsroot, 0);
|
|
||||||
+ if (rc == -EACCES)
|
|
||||||
+ goto cleanup;
|
|
||||||
+ } else {
|
|
||||||
+ /* check, print warning if multiple online */
|
|
||||||
+ lzds_analyse_open_count(zdsfsinfo.zdsroot, 1);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
rc = zdsfs_verify_datasets();
|
|
||||||
if (rc)
|
|
||||||
goto cleanup;
|
|
@ -1,37 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 140500] libu2s: Fix busid parsing
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: libu2s: Fix busid parsing
|
|
||||||
Symptom: dasdview displays a wrong busid and shows the error message
|
|
||||||
"Error: dasdview: Could not retrieve raw_track_access mode
|
|
||||||
information.", which is wrong as well.
|
|
||||||
Problem: dasdview retrieves the busid information from libu2s. Whenever
|
|
||||||
an FBA DASD is listed prior to the target DASD in
|
|
||||||
/proc/dasd/devices, the parsing will fail due to an additional
|
|
||||||
whitespace character. For example, an entry for ECKD devices
|
|
||||||
starts with "0.0.5e30(ECKD)...", while an entry for FBA starts
|
|
||||||
with "0.0.8000(FBA )...".
|
|
||||||
Solution: Change the busid parsing in libu2s by explicitly looking for the
|
|
||||||
closing bracket.
|
|
||||||
Reproduction: Add an FBA device and then an ECKD device to the system and use
|
|
||||||
dasdview to display information about the ECKD device.
|
|
||||||
# dasdview -i /dev/dasdX
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 140500
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
libu2s/u2s.c | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/libu2s/u2s.c
|
|
||||||
+++ b/libu2s/u2s.c
|
|
||||||
@@ -237,7 +237,7 @@ static int find_busid_in_proc(int maja,
|
|
||||||
filp = fopen("/proc/dasd/devices", "r");
|
|
||||||
if (!filp)
|
|
||||||
return rc;
|
|
||||||
- while (fscanf(filp, "%[^(] %*s at ( %d : %d %*[^\n]\n",
|
|
||||||
+ while (fscanf(filp, "%[^(] %*[^)] ) at ( %d : %d %*[^\n]\n",
|
|
||||||
bus, &majb, &minb) != EOF) {
|
|
||||||
if ((maja == majb) && (mina == minb)) {
|
|
||||||
strncpy(busid, bus, BUSIDSIZE + 1);
|
|
@ -1,37 +0,0 @@
|
|||||||
Subject: lscss: allow to specify devices from ssid > 2
|
|
||||||
From: Sebastian Ott <sebott@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: lscss: allow to specify devices from ssid > 2
|
|
||||||
Symptom: Specifying devices with ssid > 2 results in:
|
|
||||||
"Syntax error: 0.3.0000"
|
|
||||||
Problem: SSIDs > 2 are disallowed
|
|
||||||
Solution: allow SSIDs > 2
|
|
||||||
Reproduction: lscss 0.3.0000
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 150872
|
|
||||||
|
|
||||||
Signed-off-by: Sebastian Ott <sebott@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
zconf/lscss | 4 ++--
|
|
||||||
1 file changed, 2 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
--- a/zconf/lscss
|
|
||||||
+++ b/zconf/lscss
|
|
||||||
@@ -61,7 +61,7 @@ SUBCHANNEL_TYPE_IO=0
|
|
||||||
SUBCHANNEL_TYPE_CHSC=1
|
|
||||||
SUBCHANNEL_TYPE_EADM=3
|
|
||||||
|
|
||||||
-IDFORMAT=[[:xdigit:]]*.[0-3].[[:xdigit:]][[:xdigit:]][[:xdigit:]][[:xdigit:]]
|
|
||||||
+IDFORMAT=[[:xdigit:]]*.[[:xdigit:]].[[:xdigit:]][[:xdigit:]][[:xdigit:]][[:xdigit:]]
|
|
||||||
|
|
||||||
unset SCH_IO SCH_CHSC SCH_EADM SHOW_AVAIL UPPERCASE SHORTID DEVTYPES DEVRANGE
|
|
||||||
unset RANGE SHOW_VPM
|
|
||||||
@@ -81,7 +81,7 @@ function check_id() #return 0 if $1 has
|
|
||||||
fi
|
|
||||||
;;
|
|
||||||
3)
|
|
||||||
- if [ ${#__ID[2]} != 4 -o ${#__ID[1]} != 1 -o "${__ID[1]//[012]/}" \
|
|
||||||
+ if [ ${#__ID[2]} != 4 -o ${#__ID[1]} != 1 \
|
|
||||||
-o \( ${#__ID[0]} != 2 -a ${#__ID[0]} != 1 \) ] ;then
|
|
||||||
return 1
|
|
||||||
fi
|
|
@ -1,35 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 143050] zipl/boot: fix failed start subchannel in FBA loader
|
|
||||||
From: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: zipl/boot: fix failed start subchannel in FBA loader
|
|
||||||
Symptom: IPL of a FBA device fails with:
|
|
||||||
Start subchannel failed
|
|
||||||
disabled wait PSW 00020000 80000000 00000000 00004502
|
|
||||||
Problem: The FBA loader has only a limited amount of memory to build CCW
|
|
||||||
requests. Therefore larger I/O requests need to be split.
|
|
||||||
This splitting was off by one leading to the fact that one CCW
|
|
||||||
request uses memory of another data structure which in turn leads
|
|
||||||
to corrupted data.
|
|
||||||
Solution: Fix by correcting the split rule.
|
|
||||||
Reproduction: IPL a FBA device.
|
|
||||||
The error might occur randomly depending on the size of the
|
|
||||||
kernel image and offsets within it.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 143050
|
|
||||||
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
zipl/boot/fba2.c | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/zipl/boot/fba2.c
|
|
||||||
+++ b/zipl/boot/fba2.c
|
|
||||||
@@ -59,7 +59,7 @@ restart:
|
|
||||||
memset(irb, 0, sizeof(struct irb));
|
|
||||||
memset(&orb, 0, sizeof(struct orb));
|
|
||||||
|
|
||||||
- if (blockptr->blockct > MAX_BLOCKCT) {
|
|
||||||
+ if (blockptr->blockct >= MAX_BLOCKCT) {
|
|
||||||
record_number = MAX_BLOCKCT - 1;
|
|
||||||
blockptr->blockct -= MAX_BLOCKCT;
|
|
||||||
} else {
|
|
@ -1,35 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 156627] chmem: try to online memory to zone movable
|
|
||||||
From: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
|
||||||
|
|
||||||
Description: chmem: try to online memory to zone movable
|
|
||||||
Symptom: Standby/reserved memory that is onlined with chmem will be set
|
|
||||||
online to zone normal, instead of zone movable, and so it is much
|
|
||||||
less likely to be able to be offlined again.
|
|
||||||
Problem: With recent kernels, the default zone for hotplug memory was
|
|
||||||
changed from zone movable to zone normal.
|
|
||||||
Solution: Let chmem first try to online memory to the zone movable, before
|
|
||||||
setting it online to the default zone.
|
|
||||||
Reproduction: Set standby/reserved memory online with chmem, and check
|
|
||||||
/proc/zoneinfo for zone allocation.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 156627
|
|
||||||
|
|
||||||
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
|
||||||
---
|
|
||||||
zconf/chmem | 5 ++++-
|
|
||||||
1 file changed, 4 insertions(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/zconf/chmem
|
|
||||||
+++ b/zconf/chmem
|
|
||||||
@@ -86,7 +86,10 @@ sub chmem_online($)
|
|
||||||
{
|
|
||||||
my $block = shift;
|
|
||||||
|
|
||||||
- qx(echo online > $memdir/memory$block/state 2>/dev/null);
|
|
||||||
+ qx(echo online_movable > $memdir/memory$block/state 2>/dev/null);
|
|
||||||
+ if ($? >> 8 != 0) {
|
|
||||||
+ qx(echo online > $memdir/memory$block/state 2>/dev/null);
|
|
||||||
+ }
|
|
||||||
return $? >> 8;
|
|
||||||
}
|
|
||||||
|
|
@ -1,42 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: 9e49066f5c779e6591b06d2276add744ea8ca4d0
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Fix behaviour of -t combined with -y
|
|
||||||
|
|
||||||
When -t (testmode) is being combined with -y (noprompt), the
|
|
||||||
informations about what dasdfmt *would* do, is not being displayed.
|
|
||||||
|
|
||||||
Simply fix this by checking whether testmode is set.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 2 +-
|
|
||||||
1 file changed, 1 insertion(+), 1 deletion(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -894,7 +894,7 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
vtoc_volume_label_set_label(vlabel, "LNX1");
|
|
||||||
}
|
|
||||||
|
|
||||||
- if ((info->verbosity > 0) || (!info->withoutprompt))
|
|
||||||
+ if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
|
||||||
dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
|
||||||
|
|
||||||
count = u2s_get_host_access_count(info->devname);
|
|
@ -1,250 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Fix trailing whitespace
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 58 +++++++++++++++++++++++++++---------------------------
|
|
||||||
1 file changed, 29 insertions(+), 29 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -133,7 +133,7 @@ static void program_interrupt_signal (in
|
|
||||||
|
|
||||||
rc = close(filedes);
|
|
||||||
if (rc)
|
|
||||||
- ERRMSG("%s: (signal handler) Unable to close device (%s)\n",
|
|
||||||
+ ERRMSG("%s: (signal handler) Unable to close device (%s)\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
signal (sig, SIG_DFL);
|
|
||||||
@@ -329,7 +329,7 @@ retry:
|
|
||||||
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * check the volume serial for special
|
|
||||||
+ * check the volume serial for special
|
|
||||||
* characters and move blanks to the end
|
|
||||||
*/
|
|
||||||
static int check_volser(char *s, int devno)
|
|
||||||
@@ -345,7 +345,7 @@ static int check_volser(char *s, int dev
|
|
||||||
s[i] = ' ';
|
|
||||||
s[i] = toupper(s[i]);
|
|
||||||
}
|
|
||||||
- s[6] = 0x00;
|
|
||||||
+ s[6] = 0x00;
|
|
||||||
|
|
||||||
for (i=0; i<6; i++) {
|
|
||||||
if (s[i] == ' ')
|
|
||||||
@@ -416,16 +416,16 @@ static format_data_t ask_user_for_blksiz
|
|
||||||
break;
|
|
||||||
|
|
||||||
rc = sscanf(buffer,"%d%c", ¶ms.blksize, &c);
|
|
||||||
- if ((rc == 2) && (c == '\n'))
|
|
||||||
+ if ((rc == 2) && (c == '\n'))
|
|
||||||
rc = 1;
|
|
||||||
- if (rc == -1)
|
|
||||||
+ if (rc == -1)
|
|
||||||
rc = 1; /* this happens, if enter is pressed */
|
|
||||||
- if (rc != 1)
|
|
||||||
+ if (rc != 1)
|
|
||||||
printf(" -- wrong input, try again.\n");
|
|
||||||
|
|
||||||
if (check_param(str, ERR_LENGTH, ¶ms) < 0) {
|
|
||||||
- printf(" -- %s\n",str);
|
|
||||||
- rc = 0;
|
|
||||||
+ printf(" -- %s\n",str);
|
|
||||||
+ rc = 0;
|
|
||||||
}
|
|
||||||
} while (rc != 1);
|
|
||||||
|
|
||||||
@@ -479,7 +479,7 @@ static int dasdfmt_get_volser(char * dev
|
|
||||||
volume_label_t vlabel;
|
|
||||||
|
|
||||||
if ((f = open(devname, O_RDONLY)) == -1)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,"%s: Unable to open device %s: %s\n",
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE,"%s: Unable to open device %s: %s\n",
|
|
||||||
prog_name, devname, strerror(errno));
|
|
||||||
|
|
||||||
if (ioctl(f, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
@@ -491,7 +491,7 @@ static int dasdfmt_get_volser(char * dev
|
|
||||||
"failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
|
|
||||||
if (close(f) != 0)
|
|
||||||
- ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
||||||
+ ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
if ((strncmp(dasd_info.type, "ECKD", 4) == 0) &&
|
|
||||||
@@ -505,7 +505,7 @@ static int dasdfmt_get_volser(char * dev
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
-
|
|
||||||
+
|
|
||||||
/*
|
|
||||||
* do all the labeling (volume label and initial VTOC)
|
|
||||||
*/
|
|
||||||
@@ -577,7 +577,7 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
rc = lseek(filedes, label_position, SEEK_SET);
|
|
||||||
if (rc != label_position)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: lseek command to %i failed "
|
|
||||||
- "(%s).\n", prog_name, label_position,
|
|
||||||
+ "(%s).\n", prog_name, label_position,
|
|
||||||
strerror(errno));
|
|
||||||
|
|
||||||
rc = write(filedes, ipl2_record, ipl2_record_len);
|
|
||||||
@@ -633,9 +633,9 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
rc = lseek(filedes, label_position, SEEK_SET);
|
|
||||||
if (rc != label_position)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: lseek command to %i failed "
|
|
||||||
- "(%s).\n", prog_name, label_position,
|
|
||||||
+ "(%s).\n", prog_name, label_position,
|
|
||||||
strerror(errno));
|
|
||||||
-
|
|
||||||
+
|
|
||||||
/* write VTOC FMT4 DSCB */
|
|
||||||
rc = write(filedes, &f4, sizeof(format4_label_t));
|
|
||||||
if (rc != sizeof(format4_label_t))
|
|
||||||
@@ -695,21 +695,21 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
"using the default.\n");
|
|
||||||
info->hashstep = 10;
|
|
||||||
}
|
|
||||||
-
|
|
||||||
+
|
|
||||||
if(!info->yast_mode) printf("Printing hashmark every %d cylinders.\n",
|
|
||||||
info->hashstep);
|
|
||||||
}
|
|
||||||
|
|
||||||
format_step.blksize = format_params->blksize;
|
|
||||||
format_step.intensity = format_params->intensity;
|
|
||||||
-
|
|
||||||
+
|
|
||||||
k = 0;
|
|
||||||
cyl = 1;
|
|
||||||
if ((info->print_progressbar || info->print_hashmarks) && !info->yast_mode)
|
|
||||||
printf("\n");
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
- p1 = -1;
|
|
||||||
+ p1 = -1;
|
|
||||||
p2 = 0;
|
|
||||||
if (k + heads * reqsize >= format_params->stop_unit)
|
|
||||||
reqsize = 1;
|
|
||||||
@@ -734,7 +734,7 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
tmp = cyl*50/cylinders;
|
|
||||||
for (j=1; j<=tmp; j++)
|
|
||||||
printf("#");
|
|
||||||
- for (j=tmp+1; j<=50; j++)
|
|
||||||
+ for (j=tmp+1; j<=50; j++)
|
|
||||||
printf("-");
|
|
||||||
printf("|%3d%%", p1);
|
|
||||||
}
|
|
||||||
@@ -758,15 +758,15 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
k += reqsize * heads;
|
|
||||||
cyl += reqsize;
|
|
||||||
}
|
|
||||||
- else
|
|
||||||
+ else
|
|
||||||
k += format_params->stop_unit % heads;
|
|
||||||
|
|
||||||
- if (k > format_params->stop_unit)
|
|
||||||
+ if (k > format_params->stop_unit)
|
|
||||||
break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((info->print_progressbar || info->print_hashmarks) && !info->yast_mode)
|
|
||||||
- printf("\n\n");
|
|
||||||
+ printf("\n\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -790,7 +790,7 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDDISABLE, p) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
- "BIODASDDISABLE failed. (%s)\n", prog_name,
|
|
||||||
+ "BIODASDDISABLE failed. (%s)\n", prog_name,
|
|
||||||
strerror(errno));
|
|
||||||
disk_disabled = 1;
|
|
||||||
|
|
||||||
@@ -798,7 +798,7 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDFMT, &temp) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (invalidate first track) IOCTL "
|
|
||||||
- "BIODASDFMT failed. (%s)\n", prog_name,
|
|
||||||
+ "BIODASDFMT failed. (%s)\n", prog_name,
|
|
||||||
strerror(errno));
|
|
||||||
|
|
||||||
/* except track 0 from standard formatting procss */
|
|
||||||
@@ -814,14 +814,14 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDFMT, &temp) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (re-validate first track) IOCTL"
|
|
||||||
- " BIODASDFMT failed (%s)\n", prog_name,
|
|
||||||
+ " BIODASDFMT failed (%s)\n", prog_name,
|
|
||||||
strerror(errno));
|
|
||||||
|
|
||||||
if (info->verbosity > 0) printf("Re-accessing the device...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDENABLE, p) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
- "BIODASDENABLE failed. (%s)\n", prog_name,
|
|
||||||
+ "BIODASDENABLE failed. (%s)\n", prog_name,
|
|
||||||
strerror(errno));
|
|
||||||
disk_disabled = 0;
|
|
||||||
}
|
|
||||||
@@ -830,7 +830,7 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
/*
|
|
||||||
*
|
|
||||||
*/
|
|
||||||
-static void do_format_dasd(dasdfmt_info_t *info, format_data_t *p,
|
|
||||||
+static void do_format_dasd(dasdfmt_info_t *info, format_data_t *p,
|
|
||||||
volume_label_t *vlabel)
|
|
||||||
{
|
|
||||||
char inp_buffer[5];
|
|
||||||
@@ -943,7 +943,7 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
if (!info->yast_mode)
|
|
||||||
printf("Finished formatting the device.\n");
|
|
||||||
|
|
||||||
- if (!info->writenolabel)
|
|
||||||
+ if (!info->writenolabel)
|
|
||||||
dasdfmt_write_labels(info, vlabel, cylinders, heads);
|
|
||||||
|
|
||||||
if (!info->yast_mode)
|
|
||||||
@@ -959,7 +959,7 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
-int main(int argc,char *argv[])
|
|
||||||
+int main(int argc,char *argv[])
|
|
||||||
{
|
|
||||||
dasdfmt_info_t info;
|
|
||||||
volume_label_t vlabel;
|
|
||||||
@@ -1001,7 +1001,7 @@ int main(int argc,char *argv[])
|
|
||||||
rc=getopt_long(argc, argv, dasdfmt_getopt_string,
|
|
||||||
dasdfmt_getopt_long_options, &index);
|
|
||||||
|
|
||||||
- switch (rc)
|
|
||||||
+ switch (rc)
|
|
||||||
{
|
|
||||||
case 'F':
|
|
||||||
info.force=1;
|
|
@ -1,892 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Apply coding convention
|
|
||||||
|
|
||||||
Improve the overall readability of the code by applying the Kernel
|
|
||||||
coding convention.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 362 +++++++++++++++++++++++++-----------------------------
|
|
||||||
1 file changed, 171 insertions(+), 191 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -37,11 +37,10 @@ int reqsize;
|
|
||||||
/*
|
|
||||||
* Print version information.
|
|
||||||
*/
|
|
||||||
-static void
|
|
||||||
-print_version (void)
|
|
||||||
+static void print_version(void)
|
|
||||||
{
|
|
||||||
- printf ("%s version %s\n", tool_name, RELEASE_STRING);
|
|
||||||
- printf ("%s\n", copyright_notice);
|
|
||||||
+ printf("%s version %s\n", tool_name, RELEASE_STRING);
|
|
||||||
+ printf("%s\n", copyright_notice);
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -54,7 +53,7 @@ static void exit_usage(int exitcode)
|
|
||||||
" [-b <blocksize> | --blocksize=<blocksize>]\n"
|
|
||||||
" [-d <disk layout> | --disk_layout=<disk layout>]\n"
|
|
||||||
" [-r <cylinder> | --requestsize=<cylinder>]\n"
|
|
||||||
- " <device>\n\n",prog_name);
|
|
||||||
+ " <device>\n\n", prog_name);
|
|
||||||
|
|
||||||
printf(" -t or --test means testmode\n"
|
|
||||||
" -V or --version means print version\n"
|
|
||||||
@@ -71,13 +70,13 @@ static void exit_usage(int exitcode)
|
|
||||||
" -C or --check_host_count means force dasdfmt to check\n"
|
|
||||||
" the host access open count to ensure the device\n"
|
|
||||||
" is not online on another operating system instance\n"
|
|
||||||
- " --norecordzero prevent storage server from modifying"
|
|
||||||
- " record 0\n\n"
|
|
||||||
+ " --norecordzero prevent storage server from modifying"
|
|
||||||
+ " record 0\n\n"
|
|
||||||
" <volser> is the volume identifier, which is converted\n"
|
|
||||||
- " to EBCDIC and written to disk. \n"
|
|
||||||
+ " to EBCDIC and written to disk.\n"
|
|
||||||
" (6 characters, e.g. LNX001\n"
|
|
||||||
" <blocksize> has to be power of 2 and at least 512\n"
|
|
||||||
- " <disk layout> is either \n"
|
|
||||||
+ " <disk layout> is either\n"
|
|
||||||
" 'cdl' for compatible disk layout (default) or\n"
|
|
||||||
" 'ldl' for linux disk layout\n"
|
|
||||||
" <device> device node of the device to format\n");
|
|
||||||
@@ -106,38 +105,39 @@ static int reread_partition_table(void)
|
|
||||||
* signal handler:
|
|
||||||
* enables the disk again in case of SIGTERM, SIGINT and SIGQUIT
|
|
||||||
*/
|
|
||||||
-static void program_interrupt_signal (int sig)
|
|
||||||
+static void program_interrupt_signal(int sig)
|
|
||||||
{
|
|
||||||
int rc;
|
|
||||||
|
|
||||||
if (program_interrupt_in_progress)
|
|
||||||
- raise (sig);
|
|
||||||
+ raise(sig);
|
|
||||||
program_interrupt_in_progress = 1;
|
|
||||||
|
|
||||||
if (disk_disabled) {
|
|
||||||
- printf("Re-accessing the device... \n");
|
|
||||||
+ printf("Re-accessing the device...\n");
|
|
||||||
rc = ioctl(filedes, BIODASDENABLE, &format_params);
|
|
||||||
if (rc)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
- "%s: (signal handler) IOCTL BIODASDENABLE "
|
|
||||||
- "failed (%s)\n",prog_name,strerror(errno));
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (signal handler) IOCTL "
|
|
||||||
+ "BIODASDENABLE failed (%s)\n", prog_name,
|
|
||||||
+ strerror(errno));
|
|
||||||
}
|
|
||||||
|
|
||||||
- printf("Rereading the partition table... \n");
|
|
||||||
+ printf("Rereading the partition table...\n");
|
|
||||||
rc = reread_partition_table();
|
|
||||||
if (rc) {
|
|
||||||
ERRMSG("%s: (signal handler) Re-reading partition table "
|
|
||||||
"failed. (%s)\n", prog_name, strerror(errno));
|
|
||||||
- } else
|
|
||||||
+ } else {
|
|
||||||
printf("Exiting...\n");
|
|
||||||
+ }
|
|
||||||
|
|
||||||
rc = close(filedes);
|
|
||||||
if (rc)
|
|
||||||
ERRMSG("%s: (signal handler) Unable to close device (%s)\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
- signal (sig, SIG_DFL);
|
|
||||||
- raise (sig);
|
|
||||||
+ signal(sig, SIG_DFL);
|
|
||||||
+ raise(sig);
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -171,13 +171,13 @@ static void get_device_name(dasdfmt_info
|
|
||||||
char* device;
|
|
||||||
int i;
|
|
||||||
|
|
||||||
- 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 "
|
|
||||||
+ 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);
|
|
||||||
|
|
||||||
@@ -215,14 +215,14 @@ static void get_device_name(dasdfmt_info
|
|
||||||
info->devname[PATH_MAX - 1] = '\0';
|
|
||||||
|
|
||||||
if (stat(info->devname, &dev_stat) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_MISUSE,
|
|
||||||
- "%s: Could not get information for device node %s: %s\n",
|
|
||||||
- prog_name, info->devname, strerror(errno));
|
|
||||||
+ ERRMSG_EXIT(EXIT_MISUSE, "%s: Could not get information for "
|
|
||||||
+ "device node %s: %s\n", prog_name, info->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);
|
|
||||||
+ ERRMSG_EXIT(EXIT_MISUSE, "%s: Unable to format partition %s. "
|
|
||||||
+ "Please specify a device.\n", prog_name,
|
|
||||||
+ info->devname);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (util_proc_dev_get_entry(dev_stat.st_rdev, 1, &dev_entry) == 0) {
|
|
||||||
@@ -253,7 +253,7 @@ static void init_info(dasdfmt_info_t *in
|
|
||||||
info->force = 0;
|
|
||||||
info->writenolabel = 0;
|
|
||||||
info->labelspec = 0;
|
|
||||||
- info->cdl_format = 0;
|
|
||||||
+ info->cdl_format = 0;
|
|
||||||
info->blksize_specified = 0;
|
|
||||||
info->reqsize_specified = 0;
|
|
||||||
info->node_specified = 0;
|
|
||||||
@@ -263,7 +263,6 @@ static void init_info(dasdfmt_info_t *in
|
|
||||||
info->yast_mode = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* check for disk type and set some variables (e.g. usage count)
|
|
||||||
*/
|
|
||||||
@@ -280,9 +279,9 @@ static void check_disk(dasdfmt_info_t *i
|
|
||||||
"status information failed (%s)\n",
|
|
||||||
prog_name, strerror(errno_save));
|
|
||||||
}
|
|
||||||
- if (ro) {
|
|
||||||
+ if (ro)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "Disk is read only!\n");
|
|
||||||
- }
|
|
||||||
+
|
|
||||||
retry:
|
|
||||||
if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0) {
|
|
||||||
errno_save = errno;
|
|
||||||
@@ -314,7 +313,7 @@ retry:
|
|
||||||
|
|
||||||
info->usage_count = dasd_info.open_count;
|
|
||||||
info->devno = dasd_info.devno;
|
|
||||||
- if (strncmp(dasd_info.type, "ECKD",4) != 0) {
|
|
||||||
+ if (strncmp(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);
|
|
||||||
@@ -327,29 +326,28 @@ retry:
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* check the volume serial for special
|
|
||||||
* characters and move blanks to the end
|
|
||||||
*/
|
|
||||||
static int check_volser(char *s, int devno)
|
|
||||||
{
|
|
||||||
- int i,j;
|
|
||||||
+ int i, j;
|
|
||||||
|
|
||||||
- for (i=0; i<6; i++) {
|
|
||||||
+ for (i = 0; i < 6; i++) {
|
|
||||||
if ((s[i] < 0x20) || (s[i] > 0x7a) ||
|
|
||||||
- ((s[i] >= 0x21)&&(s[i] <= 0x22)) || /* !" */
|
|
||||||
- ((s[i] >= 0x26)&&(s[i] <= 0x2f)) || /* &'()*+,-./ */
|
|
||||||
- ((s[i] >= 0x3a)&&(s[i] <= 0x3f)) || /* :;<=>? */
|
|
||||||
- ((s[i] >= 0x5b)&&(s[i] <= 0x60))) /* \]^_` */
|
|
||||||
+ ((s[i] >= 0x21) && (s[i] <= 0x22)) || /* !" */
|
|
||||||
+ ((s[i] >= 0x26) && (s[i] <= 0x2f)) || /* &'()*+,-./ */
|
|
||||||
+ ((s[i] >= 0x3a) && (s[i] <= 0x3f)) || /* :;<=>? */
|
|
||||||
+ ((s[i] >= 0x5b) && (s[i] <= 0x60))) /* \]^_` */
|
|
||||||
s[i] = ' ';
|
|
||||||
s[i] = toupper(s[i]);
|
|
||||||
}
|
|
||||||
s[6] = 0x00;
|
|
||||||
|
|
||||||
- for (i=0; i<6; i++) {
|
|
||||||
+ for (i = 0; i < 6; i++) {
|
|
||||||
if (s[i] == ' ')
|
|
||||||
- for (j=i; j<6; j++)
|
|
||||||
+ for (j = i; j < 6; j++)
|
|
||||||
if (s[j] != ' ') {
|
|
||||||
s[i] = s[j];
|
|
||||||
s[j] = ' ';
|
|
||||||
@@ -360,7 +358,7 @@ static int check_volser(char *s, int dev
|
|
||||||
if (s[0] == ' ') {
|
|
||||||
printf("Usage error, switching to default.\n");
|
|
||||||
sprintf(s, "0X%04x", devno);
|
|
||||||
- for (i=0; i<6; i++)
|
|
||||||
+ for (i = 0; i < 6; i++)
|
|
||||||
s[i] = toupper(s[i]);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
@@ -368,7 +366,6 @@ static int check_volser(char *s, int dev
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* do some blocksize checks
|
|
||||||
*/
|
|
||||||
@@ -377,7 +374,7 @@ static int check_param(char *s, size_t b
|
|
||||||
int tmp = data->blksize;
|
|
||||||
|
|
||||||
if ((tmp < 512) || (tmp > 4096)) {
|
|
||||||
- strncpy(s,"Blocksize must be one of the following positive "
|
|
||||||
+ strncpy(s, "Blocksize must be one of the following positive "
|
|
||||||
"integers:\n512, 1024, 2048, 4096.", buffsize);
|
|
||||||
if (buffsize > 0)
|
|
||||||
s[buffsize - 1] = '\0';
|
|
||||||
@@ -386,7 +383,7 @@ static int check_param(char *s, size_t b
|
|
||||||
|
|
||||||
while (tmp > 0) {
|
|
||||||
if ((tmp % 2) && (tmp != 1)) {
|
|
||||||
- strncpy(s,"Blocksize must be a power of 2.", buffsize);
|
|
||||||
+ strncpy(s, "Blocksize must be a power of 2.", buffsize);
|
|
||||||
if (buffsize > 0)
|
|
||||||
s[buffsize - 1] = '\0';
|
|
||||||
return -1;
|
|
||||||
@@ -397,7 +394,6 @@ static int check_param(char *s, size_t b
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* ask the user to specify a blocksize
|
|
||||||
*/
|
|
||||||
@@ -415,7 +411,7 @@ static format_data_t ask_user_for_blksiz
|
|
||||||
if (fgets(buffer, sizeof(buffer), stdin) == NULL)
|
|
||||||
break;
|
|
||||||
|
|
||||||
- rc = sscanf(buffer,"%d%c", ¶ms.blksize, &c);
|
|
||||||
+ rc = sscanf(buffer, "%d%c", ¶ms.blksize, &c);
|
|
||||||
if ((rc == 2) && (c == '\n'))
|
|
||||||
rc = 1;
|
|
||||||
if (rc == -1)
|
|
||||||
@@ -424,7 +420,7 @@ static format_data_t ask_user_for_blksiz
|
|
||||||
printf(" -- wrong input, try again.\n");
|
|
||||||
|
|
||||||
if (check_param(str, ERR_LENGTH, ¶ms) < 0) {
|
|
||||||
- printf(" -- %s\n",str);
|
|
||||||
+ printf(" -- %s\n", str);
|
|
||||||
rc = 0;
|
|
||||||
}
|
|
||||||
} while (rc != 1);
|
|
||||||
@@ -432,7 +428,6 @@ static format_data_t ask_user_for_blksiz
|
|
||||||
return params;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* print all information needed to format the device
|
|
||||||
*/
|
|
||||||
@@ -449,7 +444,7 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
printf("%s in the following way:\n", info->devname);
|
|
||||||
printf(" Device number of device : 0x%x\n", info->devno);
|
|
||||||
printf(" Labelling device : %s\n",
|
|
||||||
- (info->writenolabel)?"no":"yes");
|
|
||||||
+ (info->writenolabel) ? "no" : "yes");
|
|
||||||
|
|
||||||
if (!info->writenolabel) {
|
|
||||||
vtoc_volume_label_get_label(vlabel, vollbl);
|
|
||||||
@@ -460,31 +455,31 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
printf(" Extent start (trk no) : %u\n", p->start_unit);
|
|
||||||
printf(" Extent end (trk no) : %u\n", p->stop_unit);
|
|
||||||
printf(" Compatible Disk Layout : %s\n",
|
|
||||||
- (p->intensity & DASD_FMT_INT_COMPAT)?"yes":"no");
|
|
||||||
+ (p->intensity & DASD_FMT_INT_COMPAT) ? "yes" : "no");
|
|
||||||
printf(" Blocksize : %d\n", p->blksize);
|
|
||||||
|
|
||||||
if (info->testmode)
|
|
||||||
printf("Test mode active, omitting ioctl.\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* get volser
|
|
||||||
*/
|
|
||||||
-static int dasdfmt_get_volser(char * devname, char * volser)
|
|
||||||
+static int dasdfmt_get_volser(char *devname, char *volser)
|
|
||||||
{
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
+ dasd_information_t dasd_info;
|
|
||||||
int blksize;
|
|
||||||
int f;
|
|
||||||
volume_label_t vlabel;
|
|
||||||
|
|
||||||
- if ((f = open(devname, O_RDONLY)) == -1)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,"%s: Unable to open device %s: %s\n",
|
|
||||||
+ f = open(devname, O_RDONLY);
|
|
||||||
+ if (f == -1)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
prog_name, devname, strerror(errno));
|
|
||||||
|
|
||||||
if (ioctl(f, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BIODASD"
|
|
||||||
- "INFO failed (%s).\n",prog_name, strerror(errno));
|
|
||||||
+ "INFO failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
|
|
||||||
if (ioctl(f, BLKSSZGET, &blksize) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BLKSSZGET "
|
|
||||||
@@ -500,8 +495,7 @@ static int dasdfmt_get_volser(char * dev
|
|
||||||
vtoc_read_volume_label(devname, dasd_info.label_block * blksize, &vlabel);
|
|
||||||
vtoc_volume_label_get_volser(&vlabel, volser);
|
|
||||||
return 0;
|
|
||||||
- }
|
|
||||||
- else {
|
|
||||||
+ } else {
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
@@ -512,22 +506,24 @@ static int dasdfmt_get_volser(char * dev
|
|
||||||
static void dasdfmt_write_labels(dasdfmt_info_t *info, volume_label_t *vlabel,
|
|
||||||
unsigned int cylinders, unsigned int heads)
|
|
||||||
{
|
|
||||||
- int label_position;
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
- struct hd_geometry geo;
|
|
||||||
- format4_label_t f4;
|
|
||||||
- format5_label_t f5;
|
|
||||||
- format7_label_t f7;
|
|
||||||
+ int label_position;
|
|
||||||
+ dasd_information_t dasd_info;
|
|
||||||
+ struct hd_geometry geo;
|
|
||||||
+ format4_label_t f4;
|
|
||||||
+ format5_label_t f5;
|
|
||||||
+ format7_label_t f7;
|
|
||||||
int rc, blksize;
|
|
||||||
void *ipl1_record, *ipl2_record;
|
|
||||||
int ipl1_record_len, ipl2_record_len;
|
|
||||||
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Retrieving dasd information... ");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Retrieving dasd information... ");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL BIODASD"
|
|
||||||
- "INFO failed (%s).\n",prog_name, strerror(errno));
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL "
|
|
||||||
+ "BIODASDINFO failed (%s).\n",
|
|
||||||
+ prog_name, strerror(errno));
|
|
||||||
|
|
||||||
if (ioctl(filedes, BLKSSZGET, &blksize) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL BLKSSZGET "
|
|
||||||
@@ -539,13 +535,16 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
* vary depending on the format.
|
|
||||||
*/
|
|
||||||
if (ioctl(filedes, HDIO_GETGEO, &geo) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL HDIO_GET"
|
|
||||||
- "GEO failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL "
|
|
||||||
+ "HDIO_GETGEO failed (%s).\n",
|
|
||||||
+ prog_name, strerror(errno));
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("ok\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("ok\n");
|
|
||||||
|
|
||||||
/* write empty bootstrap (initial IPL records) */
|
|
||||||
- if (info->verbosity > 0) printf("Writing empty bootstrap...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Writing empty bootstrap...\n");
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Note: ldl labels do not contain the key field
|
|
||||||
@@ -596,7 +595,8 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
|
|
||||||
label_position = dasd_info.label_block * blksize;
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Writing label...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Writing label...\n");
|
|
||||||
|
|
||||||
rc = lseek(filedes, label_position, SEEK_SET);
|
|
||||||
if (rc != label_position)
|
|
||||||
@@ -608,10 +608,10 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
* Note: cdl volume labels do not contain the 'formatted_blocks' part
|
|
||||||
* and ldl labels do not contain the key field
|
|
||||||
*/
|
|
||||||
- if (info->cdl_format)
|
|
||||||
+ if (info->cdl_format) {
|
|
||||||
rc = write(filedes, vlabel, (sizeof(*vlabel) -
|
|
||||||
sizeof(vlabel->formatted_blocks)));
|
|
||||||
- else {
|
|
||||||
+ } else {
|
|
||||||
vlabel->ldl_version = 0xf2; /* EBCDIC '2' */
|
|
||||||
vlabel->formatted_blocks = cylinders * heads * geo.sectors;
|
|
||||||
rc = write(filedes, &vlabel->vollbl, (sizeof(*vlabel)
|
|
||||||
@@ -625,7 +625,8 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Error writing volume label "
|
|
||||||
"(%d).\n", prog_name, rc);
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Writing VTOC... ");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Writing VTOC... ");
|
|
||||||
|
|
||||||
label_position = (VTOC_START_CC * heads + VTOC_START_HH) *
|
|
||||||
geo.sectors * blksize;
|
|
||||||
@@ -673,10 +674,10 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
|
|
||||||
fsync(filedes);
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("ok\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("ok\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* formats the disk cylinderwise
|
|
||||||
*/
|
|
||||||
@@ -720,21 +721,20 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
format_step.start_unit += 1;
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDFMT, &format_step) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,"%s: (format cylinder) IOCTL "
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (format cylinder) IOCTL "
|
|
||||||
"BIODASDFMT failed. (%s)\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
if (info->print_progressbar) {
|
|
||||||
printf("cyl %7d of %7d |", cyl, cylinders);
|
|
||||||
p2 = p1;
|
|
||||||
- p1 = cyl*100/cylinders;
|
|
||||||
- if (p1 != p2)
|
|
||||||
- {
|
|
||||||
+ p1 = cyl * 100 / cylinders;
|
|
||||||
+ if (p1 != p2) {
|
|
||||||
/* percent value has changed */
|
|
||||||
- tmp = cyl*50/cylinders;
|
|
||||||
- for (j=1; j<=tmp; j++)
|
|
||||||
+ tmp = cyl * 50 / cylinders;
|
|
||||||
+ for (j = 1; j <= tmp; j++)
|
|
||||||
printf("#");
|
|
||||||
- for (j=tmp+1; j<=50; j++)
|
|
||||||
+ for (j = tmp + 1; j <= 50; j++)
|
|
||||||
printf("-");
|
|
||||||
printf("|%3d%%", p1);
|
|
||||||
}
|
|
||||||
@@ -748,6 +748,7 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
fflush(stdout);
|
|
||||||
hashcount++;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
if (info->print_percentage) {
|
|
||||||
printf("cyl %7d of %7d |%3d%%\n", cyl, cylinders,
|
|
||||||
cyl*100/cylinders);
|
|
||||||
@@ -757,9 +758,9 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
if (k % heads == 0) {
|
|
||||||
k += reqsize * heads;
|
|
||||||
cyl += reqsize;
|
|
||||||
- }
|
|
||||||
- else
|
|
||||||
+ } else {
|
|
||||||
k += format_params->stop_unit % heads;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (k > format_params->stop_unit)
|
|
||||||
break;
|
|
||||||
@@ -769,14 +770,9 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
printf("\n\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
-/*
|
|
||||||
- *
|
|
||||||
- */
|
|
||||||
-static void dasdfmt_prepare_and_format (dasdfmt_info_t *info,
|
|
||||||
- unsigned int cylinders,
|
|
||||||
- unsigned int heads,
|
|
||||||
- format_data_t *p)
|
|
||||||
+static void dasdfmt_prepare_and_format(dasdfmt_info_t *info,
|
|
||||||
+ unsigned int cylinders,
|
|
||||||
+ unsigned int heads, format_data_t *p)
|
|
||||||
{
|
|
||||||
format_data_t temp = {
|
|
||||||
start_unit: 0,
|
|
||||||
@@ -786,7 +782,8 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
| DASD_FMT_INT_INVAL)
|
|
||||||
};
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Detaching the device...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Detaching the device...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDDISABLE, p) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
@@ -794,7 +791,8 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
strerror(errno));
|
|
||||||
disk_disabled = 1;
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Invalidate first track...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Invalidate first track...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDFMT, &temp) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (invalidate first track) IOCTL "
|
|
||||||
@@ -806,18 +804,21 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
|
|
||||||
dasdfmt_format(info, cylinders, heads, p);
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("formatting tracks complete...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("formatting tracks complete...\n");
|
|
||||||
|
|
||||||
temp.intensity = p->intensity;
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Revalidate first track...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Revalidate first track...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDFMT, &temp) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (re-validate first track) IOCTL"
|
|
||||||
" BIODASDFMT failed (%s)\n", prog_name,
|
|
||||||
strerror(errno));
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Re-accessing the device...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Re-accessing the device...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDENABLE, p) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
@@ -826,20 +827,17 @@ static void dasdfmt_prepare_and_format (
|
|
||||||
disk_disabled = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
-/*
|
|
||||||
- *
|
|
||||||
- */
|
|
||||||
static void do_format_dasd(dasdfmt_info_t *info, format_data_t *p,
|
|
||||||
volume_label_t *vlabel)
|
|
||||||
{
|
|
||||||
- char inp_buffer[5];
|
|
||||||
+ char inp_buffer[5];
|
|
||||||
dasd_information_t dasd_info;
|
|
||||||
struct dasd_eckd_characteristics *characteristics;
|
|
||||||
unsigned int cylinders, heads;
|
|
||||||
int count;
|
|
||||||
|
|
||||||
- if (info->verbosity > 0) printf("Retrieving disk geometry...\n");
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Retrieving disk geometry...\n");
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (retrieving disk information) "
|
|
||||||
@@ -877,22 +875,23 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
}
|
|
||||||
}
|
|
||||||
} else {
|
|
||||||
- if (!info->labelspec && !info->keep_volser) {
|
|
||||||
+ if (!info->labelspec && !info->keep_volser) {
|
|
||||||
char buf[7];
|
|
||||||
|
|
||||||
- sprintf(buf, "0X%04x", info->devno);
|
|
||||||
+ sprintf(buf, "0X%04x", info->devno);
|
|
||||||
check_volser(buf, info->devno);
|
|
||||||
vtoc_volume_label_set_volser(vlabel, buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (p->intensity & DASD_FMT_INT_COMPAT) {
|
|
||||||
+ if (p->intensity & DASD_FMT_INT_COMPAT) {
|
|
||||||
info->cdl_format = 1;
|
|
||||||
vtoc_volume_label_set_label(vlabel, "VOL1");
|
|
||||||
vtoc_volume_label_set_key(vlabel, "VOL1");
|
|
||||||
vtoc_set_cchhb(&vlabel->vtoc, 0x0000, 0x0001, 0x01);
|
|
||||||
- } else
|
|
||||||
+ } else {
|
|
||||||
vtoc_volume_label_set_label(vlabel, "LNX1");
|
|
||||||
- }
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
|
||||||
dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
|
||||||
@@ -926,15 +925,15 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
"untouched: ");
|
|
||||||
if (fgets(inp_buffer, sizeof(inp_buffer), stdin) == NULL)
|
|
||||||
return;
|
|
||||||
- if (strcasecmp(inp_buffer,"yes") &&
|
|
||||||
- strcasecmp(inp_buffer,"yes\n")) {
|
|
||||||
+ if (strcasecmp(inp_buffer, "yes") &&
|
|
||||||
+ strcasecmp(inp_buffer, "yes\n")) {
|
|
||||||
printf("Omitting ioctl call (disk will "
|
|
||||||
"NOT be formatted).\n");
|
|
||||||
return;
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (!((info->withoutprompt)&&(info->verbosity<1)))
|
|
||||||
+ if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
printf("Formatting the device. This may take a "
|
|
||||||
"while (get yourself a coffee).\n");
|
|
||||||
|
|
||||||
@@ -954,12 +953,11 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
} else {
|
|
||||||
if (!info->yast_mode)
|
|
||||||
printf("ok\n");
|
|
||||||
- }
|
|
||||||
+ }
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
-int main(int argc,char *argv[])
|
|
||||||
+int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
dasdfmt_info_t info;
|
|
||||||
volume_label_t vlabel;
|
|
||||||
@@ -980,9 +978,9 @@ int main(int argc,char *argv[])
|
|
||||||
int running=0;
|
|
||||||
|
|
||||||
/* Establish a handler for interrupt signals. */
|
|
||||||
- signal (SIGTERM, program_interrupt_signal);
|
|
||||||
- signal (SIGINT, program_interrupt_signal);
|
|
||||||
- signal (SIGQUIT, program_interrupt_signal);
|
|
||||||
+ signal(SIGTERM, program_interrupt_signal);
|
|
||||||
+ signal(SIGINT, program_interrupt_signal);
|
|
||||||
+ signal(SIGQUIT, program_interrupt_signal);
|
|
||||||
|
|
||||||
/******************* initialization ********************/
|
|
||||||
prog_name = argv[0];
|
|
||||||
@@ -996,102 +994,81 @@ int main(int argc,char *argv[])
|
|
||||||
|
|
||||||
/*************** parse parameters **********************/
|
|
||||||
|
|
||||||
- while (1)
|
|
||||||
- {
|
|
||||||
- rc=getopt_long(argc, argv, dasdfmt_getopt_string,
|
|
||||||
- dasdfmt_getopt_long_options, &index);
|
|
||||||
+ while (1) {
|
|
||||||
+ rc = getopt_long(argc, argv, dasdfmt_getopt_string,
|
|
||||||
+ dasdfmt_getopt_long_options, &index);
|
|
||||||
|
|
||||||
- switch (rc)
|
|
||||||
- {
|
|
||||||
+ switch (rc) {
|
|
||||||
case 'F':
|
|
||||||
- info.force=1;
|
|
||||||
+ info.force = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
- case 'd' :
|
|
||||||
- if (strncmp(optarg,"cdl",3)==0)
|
|
||||||
- {
|
|
||||||
+ case 'd':
|
|
||||||
+ if (strncmp(optarg, "cdl", 3) == 0) {
|
|
||||||
format_params.intensity |= DASD_FMT_INT_COMPAT;
|
|
||||||
- if (info.writenolabel)
|
|
||||||
- {
|
|
||||||
- printf("WARNING: using the cdl " \
|
|
||||||
- "format without writing a " \
|
|
||||||
- "label doesn't make much " \
|
|
||||||
+ if (info.writenolabel) {
|
|
||||||
+ printf("WARNING: using the cdl "
|
|
||||||
+ "format without writing a "
|
|
||||||
+ "label doesn't make much "
|
|
||||||
"sense!\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
- }
|
|
||||||
- else if (strncmp(optarg,"ldl",3)==0)
|
|
||||||
+ } else if (strncmp(optarg, "ldl", 3) == 0) {
|
|
||||||
format_params.intensity &= ~DASD_FMT_INT_COMPAT;
|
|
||||||
- else
|
|
||||||
- {
|
|
||||||
+ } else {
|
|
||||||
printf("%s is not a valid option!\n", optarg);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
- break;
|
|
||||||
-
|
|
||||||
+ break;
|
|
||||||
case 'y':
|
|
||||||
- info.withoutprompt=1;
|
|
||||||
+ info.withoutprompt = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'z':
|
|
||||||
- format_params.intensity |= DASD_FMT_INT_FMT_NOR0;
|
|
||||||
+ format_params.intensity |= DASD_FMT_INT_FMT_NOR0;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 't':
|
|
||||||
- info.testmode=1;
|
|
||||||
+ info.testmode = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'p':
|
|
||||||
if (!(info.print_hashmarks || info.print_percentage))
|
|
||||||
info.print_progressbar = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'm':
|
|
||||||
- if (!(info.print_progressbar || info.print_percentage))
|
|
||||||
- {
|
|
||||||
- hashstep_str=optarg;
|
|
||||||
- info.print_hashmarks=1;
|
|
||||||
+ if (!(info.print_progressbar || info.print_percentage)) {
|
|
||||||
+ hashstep_str = optarg;
|
|
||||||
+ info.print_hashmarks = 1;
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'Q':
|
|
||||||
if (!(info.print_hashmarks || info.print_progressbar))
|
|
||||||
info.print_percentage = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'v':
|
|
||||||
- info.verbosity=1;
|
|
||||||
+ info.verbosity = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'h':
|
|
||||||
exit_usage(0);
|
|
||||||
-
|
|
||||||
case 'V':
|
|
||||||
print_version();
|
|
||||||
exit(0);
|
|
||||||
-
|
|
||||||
case 'l':
|
|
||||||
- strncpy(buf, optarg, 6);
|
|
||||||
+ strncpy(buf, optarg, 6);
|
|
||||||
if (check_volser(buf, 0) < 0)
|
|
||||||
break;
|
|
||||||
- vtoc_volume_label_set_volser(&vlabel,buf);
|
|
||||||
- info.labelspec=1;
|
|
||||||
+ vtoc_volume_label_set_volser(&vlabel, buf);
|
|
||||||
+ info.labelspec = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
case 'L':
|
|
||||||
- if (format_params.intensity & DASD_FMT_INT_COMPAT)
|
|
||||||
- {
|
|
||||||
- printf("WARNING: using the cdl format " \
|
|
||||||
- "without writing a label doesn't " \
|
|
||||||
+ if (format_params.intensity & DASD_FMT_INT_COMPAT) {
|
|
||||||
+ printf("WARNING: using the cdl format "
|
|
||||||
+ "without writing a label doesn't "
|
|
||||||
"make much sense!\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
- info.writenolabel=1;
|
|
||||||
+ info.writenolabel = 1;
|
|
||||||
break;
|
|
||||||
-
|
|
||||||
- case 'b' :
|
|
||||||
- blksize_param_str=optarg;
|
|
||||||
- info.blksize_specified=1;
|
|
||||||
+ case 'b':
|
|
||||||
+ blksize_param_str = optarg;
|
|
||||||
+ info.blksize_specified = 1;
|
|
||||||
break;
|
|
||||||
case 'r':
|
|
||||||
reqsize_param_str = optarg;
|
|
||||||
@@ -1102,7 +1079,7 @@ int main(int argc,char *argv[])
|
|
||||||
ERRMSG_EXIT(EXIT_MISUSE,"%s: too many devices specified.\n",
|
|
||||||
prog_name);
|
|
||||||
dev_filename[dev_count++]=strdup(optarg);
|
|
||||||
- info.node_specified=1;
|
|
||||||
+ info.node_specified = 1;
|
|
||||||
break;
|
|
||||||
case 'Y' : /* YaST mode */
|
|
||||||
info.yast_mode=1;
|
|
||||||
@@ -1110,8 +1087,8 @@ int main(int argc,char *argv[])
|
|
||||||
case 'P' : /* max parallel formatting processes */
|
|
||||||
max_parallel=atoi(optarg);
|
|
||||||
break;
|
|
||||||
- case 'k' :
|
|
||||||
- info.keep_volser=1;
|
|
||||||
+ case 'k':
|
|
||||||
+ info.keep_volser = 1;
|
|
||||||
break;
|
|
||||||
case 'C':
|
|
||||||
info.force_host = 1;
|
|
||||||
@@ -1121,11 +1098,12 @@ int main(int argc,char *argv[])
|
|
||||||
info.device_id = optind;
|
|
||||||
break;
|
|
||||||
default:
|
|
||||||
- ERRMSG_EXIT(EXIT_MISUSE,
|
|
||||||
- "Try '%s --help' for more"
|
|
||||||
- " information.\n",prog_name);
|
|
||||||
+ ERRMSG_EXIT(EXIT_MISUSE, "Try '%s --help' for more"
|
|
||||||
+ " information.\n", prog_name);
|
|
||||||
}
|
|
||||||
- if (rc==-1) break; // exit loop if finished
|
|
||||||
+
|
|
||||||
+ if (rc == -1)
|
|
||||||
+ break; /* exit loop if finished */
|
|
||||||
}
|
|
||||||
|
|
||||||
CHECK_SPEC_MAX_ONCE(info.blksize_specified, "blocksize");
|
|
||||||
@@ -1222,7 +1200,7 @@ int main(int argc,char *argv[])
|
|
||||||
} else
|
|
||||||
reqsize = DEFAULT_REQUESTSIZE;
|
|
||||||
if (info.print_hashmarks)
|
|
||||||
- PARSE_PARAM_INTO(info.hashstep, hashstep_str,10,"hashstep");
|
|
||||||
+ PARSE_PARAM_INTO(info.hashstep, hashstep_str, 10, "hashstep");
|
|
||||||
|
|
||||||
get_device_name(&info, dev_filename[i]);
|
|
||||||
|
|
||||||
@@ -1230,22 +1208,24 @@ int main(int argc,char *argv[])
|
|
||||||
format_params = ask_user_for_blksize(format_params);
|
|
||||||
|
|
||||||
if (info.keep_volser) {
|
|
||||||
- if(format_params.intensity == 0x00) {
|
|
||||||
- printf("WARNING: VOLSER cannot be kept " \
|
|
||||||
+ if (format_params.intensity == 0x00) {
|
|
||||||
+ printf("WARNING: VOLSER cannot be kept "
|
|
||||||
"when using the ldl format!\n");
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if(dasdfmt_get_volser(info.devname, old_volser) == 0)
|
|
||||||
+ if (dasdfmt_get_volser(info.devname, old_volser) == 0)
|
|
||||||
vtoc_volume_label_set_volser(&vlabel, old_volser);
|
|
||||||
else
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,"%s: VOLSER not found on device %s\n",
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
+ "%s: VOLSER not found on device %s\n",
|
|
||||||
prog_name, info.devname);
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
- if ((filedes = open(info.devname, O_RDWR)) == -1)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,"%s: Unable to open device %s: %s\n",
|
|
||||||
+ filedes = open(info.devname, O_RDWR);
|
|
||||||
+ if (filedes == -1)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
prog_name, info.devname, strerror(errno));
|
|
||||||
|
|
||||||
check_disk(&info);
|
|
@ -1,399 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Use enhanced DASD information
|
|
||||||
|
|
||||||
Currently dasdfmt uses BIODASDINFO as the IOCTL command to retrieve
|
|
||||||
information about a DASD and stores them in dasd_information_t.
|
|
||||||
However, BIODASDINFO2 offers a few more useful information (which are
|
|
||||||
then stored in dasd_information2_t).
|
|
||||||
|
|
||||||
- Replace dasd_information_t with dasd_information2_t.
|
|
||||||
- Make the corresponding variable part of dasdfmt_info_t, since it is
|
|
||||||
used in several functions anyway and we can save a few parameters and
|
|
||||||
IOCTL calls.
|
|
||||||
- Change the initialization of dasdfmt_info_t. A separate function isn't
|
|
||||||
necessary for that.
|
|
||||||
- Put the BIODASDINFO2 IOCTL call in a separate function which is then
|
|
||||||
called only once.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 132 ++++++++++++++++++------------------------------------
|
|
||||||
dasdfmt/dasdfmt.h | 21 ++++++--
|
|
||||||
2 files changed, 61 insertions(+), 92 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -237,30 +237,18 @@ static void get_device_name(dasdfmt_info
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * initialize the dasdfmt info structure
|
|
||||||
+ * Retrieve DASD information
|
|
||||||
*/
|
|
||||||
-static void init_info(dasdfmt_info_t *info)
|
|
||||||
+static void get_device_info(dasdfmt_info_t *info)
|
|
||||||
{
|
|
||||||
- info->devno = 0x0;
|
|
||||||
- info->usage_count = 0;
|
|
||||||
- info->testmode = 0;
|
|
||||||
- info->verbosity = 0;
|
|
||||||
- info->withoutprompt = 0;
|
|
||||||
- info->print_progressbar = 0;
|
|
||||||
- info->print_hashmarks = 0;
|
|
||||||
- info->print_percentage = 0;
|
|
||||||
- info->hashstep = 0;
|
|
||||||
- info->force = 0;
|
|
||||||
- info->writenolabel = 0;
|
|
||||||
- info->labelspec = 0;
|
|
||||||
- info->cdl_format = 0;
|
|
||||||
- info->blksize_specified = 0;
|
|
||||||
- info->reqsize_specified = 0;
|
|
||||||
- info->node_specified = 0;
|
|
||||||
- info->device_id = 0;
|
|
||||||
- info->keep_volser = 0;
|
|
||||||
- info->force_host = 0;
|
|
||||||
- info->yast_mode = 0;
|
|
||||||
+ dasd_information2_t dasd_info;
|
|
||||||
+
|
|
||||||
+ if (ioctl(filedes, BIODASDINFO2, &dasd_info))
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl call to retrieve "
|
|
||||||
+ "device information failed (%s).\n",
|
|
||||||
+ prog_name, strerror(errno));
|
|
||||||
+
|
|
||||||
+ info->dasd_info = dasd_info;
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
@@ -268,7 +256,6 @@ static void init_info(dasdfmt_info_t *in
|
|
||||||
*/
|
|
||||||
static void check_disk(dasdfmt_info_t *info)
|
|
||||||
{
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
int ro, errno_save, i = 0;
|
|
||||||
|
|
||||||
if (ioctl(filedes, BLKROGET, &ro) != 0) {
|
|
||||||
@@ -283,15 +270,6 @@ static void check_disk(dasdfmt_info_t *i
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "Disk is read only!\n");
|
|
||||||
|
|
||||||
retry:
|
|
||||||
- if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0) {
|
|
||||||
- errno_save = errno;
|
|
||||||
- close(filedes);
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
- "%s: the ioctl call to retrieve device "
|
|
||||||
- "information failed (%s)\n",
|
|
||||||
- prog_name, strerror(errno_save));
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if (!info->force)
|
|
||||||
/*
|
|
||||||
* udev strikes again.
|
|
||||||
@@ -302,7 +280,7 @@ retry:
|
|
||||||
* And confusing the hell out ouf anyone else.
|
|
||||||
* Bah.
|
|
||||||
*/
|
|
||||||
- if (dasd_info.open_count > 1) {
|
|
||||||
+ if (info->dasd_info.open_count > 1) {
|
|
||||||
if (i < 5) {
|
|
||||||
++i;
|
|
||||||
sleep(1);
|
|
||||||
@@ -311,9 +289,7 @@ retry:
|
|
||||||
ERRMSG_EXIT(EXIT_BUSY, "Disk in use!\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
- info->usage_count = dasd_info.open_count;
|
|
||||||
- info->devno = dasd_info.devno;
|
|
||||||
- if (strncmp(dasd_info.type, "ECKD", 4) != 0) {
|
|
||||||
+ 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);
|
|
||||||
@@ -442,7 +418,7 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
|
|
||||||
printf("\nI am going to format the device ");
|
|
||||||
printf("%s in the following way:\n", info->devname);
|
|
||||||
- printf(" Device number of device : 0x%x\n", info->devno);
|
|
||||||
+ printf(" Device number of device : 0x%x\n", info->dasd_info.devno);
|
|
||||||
printf(" Labelling device : %s\n",
|
|
||||||
(info->writenolabel) ? "no" : "yes");
|
|
||||||
|
|
||||||
@@ -465,21 +441,16 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
/*
|
|
||||||
* get volser
|
|
||||||
*/
|
|
||||||
-static int dasdfmt_get_volser(char *devname, char *volser)
|
|
||||||
+static int dasdfmt_get_volser(dasdfmt_info_t *info, char *volser)
|
|
||||||
{
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
int blksize;
|
|
||||||
int f;
|
|
||||||
volume_label_t vlabel;
|
|
||||||
|
|
||||||
- f = open(devname, O_RDONLY);
|
|
||||||
+ f = open(info->devname, O_RDONLY);
|
|
||||||
if (f == -1)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
- prog_name, devname, strerror(errno));
|
|
||||||
-
|
|
||||||
- if (ioctl(f, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BIODASD"
|
|
||||||
- "INFO failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
+ prog_name, info->devname, strerror(errno));
|
|
||||||
|
|
||||||
if (ioctl(f, BLKSSZGET, &blksize) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BLKSSZGET "
|
|
||||||
@@ -489,10 +460,12 @@ static int dasdfmt_get_volser(char *devn
|
|
||||||
ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
- if ((strncmp(dasd_info.type, "ECKD", 4) == 0) &&
|
|
||||||
- (!dasd_info.FBA_layout)) {
|
|
||||||
+ if ((strncmp(info->dasd_info.type, "ECKD", 4) == 0) &&
|
|
||||||
+ (!info->dasd_info.FBA_layout)) {
|
|
||||||
/* OS/390 and zOS compatible disk layout */
|
|
||||||
- vtoc_read_volume_label(devname, dasd_info.label_block * blksize, &vlabel);
|
|
||||||
+ vtoc_read_volume_label(info->devname,
|
|
||||||
+ info->dasd_info.label_block * blksize,
|
|
||||||
+ &vlabel);
|
|
||||||
vtoc_volume_label_get_volser(&vlabel, volser);
|
|
||||||
return 0;
|
|
||||||
} else {
|
|
||||||
@@ -507,7 +480,6 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
unsigned int cylinders, unsigned int heads)
|
|
||||||
{
|
|
||||||
int label_position;
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
struct hd_geometry geo;
|
|
||||||
format4_label_t f4;
|
|
||||||
format5_label_t f5;
|
|
||||||
@@ -520,11 +492,6 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
if (info->verbosity > 0)
|
|
||||||
printf("Retrieving dasd information... ");
|
|
||||||
|
|
||||||
- if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL "
|
|
||||||
- "BIODASDINFO failed (%s).\n",
|
|
||||||
- prog_name, strerror(errno));
|
|
||||||
-
|
|
||||||
if (ioctl(filedes, BLKSSZGET, &blksize) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL BLKSSZGET "
|
|
||||||
"failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
@@ -586,14 +553,14 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
|
|
||||||
/* write VTOC */
|
|
||||||
vtoc_init_format4_label(&f4, geo.cylinders, cylinders, heads,
|
|
||||||
- geo.sectors, blksize, dasd_info.dev_type);
|
|
||||||
+ geo.sectors, blksize, info->dasd_info.dev_type);
|
|
||||||
|
|
||||||
vtoc_init_format5_label(&f5);
|
|
||||||
vtoc_init_format7_label(&f7);
|
|
||||||
vtoc_set_freespace(&f4, &f5, &f7, '+', 0, FIRST_USABLE_TRK,
|
|
||||||
(cylinders * heads - 1), cylinders, heads);
|
|
||||||
|
|
||||||
- label_position = dasd_info.label_block * blksize;
|
|
||||||
+ label_position = info->dasd_info.label_block * blksize;
|
|
||||||
|
|
||||||
if (info->verbosity > 0)
|
|
||||||
printf("Writing label...\n");
|
|
||||||
@@ -831,7 +798,6 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
volume_label_t *vlabel)
|
|
||||||
{
|
|
||||||
char inp_buffer[5];
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
struct dasd_eckd_characteristics *characteristics;
|
|
||||||
unsigned int cylinders, heads;
|
|
||||||
int count;
|
|
||||||
@@ -839,13 +805,9 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
if (info->verbosity > 0)
|
|
||||||
printf("Retrieving disk geometry...\n");
|
|
||||||
|
|
||||||
- if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (retrieving disk information) "
|
|
||||||
- "IOCTL BIODASDINFO failed (%s).\n",
|
|
||||||
- prog_name, strerror(errno));
|
|
||||||
-
|
|
||||||
characteristics =
|
|
||||||
- (struct dasd_eckd_characteristics *) &dasd_info.characteristics;
|
|
||||||
+ (struct dasd_eckd_characteristics *)
|
|
||||||
+ &info->dasd_info.characteristics;
|
|
||||||
if (characteristics->no_cyl == LV_COMPAT_CYL &&
|
|
||||||
characteristics->long_no_cyl)
|
|
||||||
cylinders = characteristics->long_no_cyl;
|
|
||||||
@@ -878,8 +840,8 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
if (!info->labelspec && !info->keep_volser) {
|
|
||||||
char buf[7];
|
|
||||||
|
|
||||||
- sprintf(buf, "0X%04x", info->devno);
|
|
||||||
- check_volser(buf, info->devno);
|
|
||||||
+ sprintf(buf, "0X%04x", info->dasd_info.devno);
|
|
||||||
+ check_volser(buf, info->dasd_info.devno);
|
|
||||||
vtoc_volume_label_set_volser(vlabel, buf);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -959,7 +921,10 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
|
|
||||||
int main(int argc, char *argv[])
|
|
||||||
{
|
|
||||||
- dasdfmt_info_t info;
|
|
||||||
+ dasdfmt_info_t info = {
|
|
||||||
+ .dasd_info = {0},
|
|
||||||
+ {0}
|
|
||||||
+ };
|
|
||||||
volume_label_t vlabel;
|
|
||||||
char old_volser[7];
|
|
||||||
|
|
||||||
@@ -986,7 +951,6 @@ int main(int argc, char *argv[])
|
|
||||||
prog_name = argv[0];
|
|
||||||
|
|
||||||
/* set default values */
|
|
||||||
- init_info(&info);
|
|
||||||
vtoc_volume_label_init(&vlabel);
|
|
||||||
|
|
||||||
format_params.blksize = DEFAULT_BLOCKSIZE;
|
|
||||||
@@ -1137,30 +1101,24 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
if(info.yast_mode) {
|
|
||||||
for(i=0;i<dev_count;i++) {
|
|
||||||
- dasd_information_t dasd_info;
|
|
||||||
struct dasd_eckd_characteristics *characteristics;
|
|
||||||
unsigned int cylinders;
|
|
||||||
|
|
||||||
get_device_name(&info, dev_filename[i]);
|
|
||||||
- if ((filedes = open(info.devname, O_RDWR)) == -1) {
|
|
||||||
+
|
|
||||||
+ filedes = open(info.devname, O_RDWR);
|
|
||||||
+ if (filedes == -1) {
|
|
||||||
ERRMSG("%s: Unable to open device %s: %s\n",
|
|
||||||
- prog_name, info.devname, strerror(errno));
|
|
||||||
- free(dev_filename[i]);
|
|
||||||
- dev_filename[i]=(char*)-1; /* ignore device */
|
|
||||||
- continue;
|
|
||||||
- }
|
|
||||||
- if (ioctl(filedes, BIODASDINFO, &dasd_info) != 0) {
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (retrieving disk information) "
|
|
||||||
- "IOCTL BIODASDINFO failed (%s).\n",
|
|
||||||
- prog_name, strerror(errno));
|
|
||||||
+ prog_name, info.devname, strerror(errno));
|
|
||||||
free(dev_filename[i]);
|
|
||||||
dev_filename[i]=(char*)-1; /* ignore device */
|
|
||||||
- close(filedes);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
+ get_device_info(&info);
|
|
||||||
+
|
|
||||||
characteristics =
|
|
||||||
- (struct dasd_eckd_characteristics *) &dasd_info.characteristics;
|
|
||||||
+ (struct dasd_eckd_characteristics *) &info.dasd_info.characteristics;
|
|
||||||
if (characteristics->no_cyl == LV_COMPAT_CYL &&
|
|
||||||
characteristics->long_no_cyl)
|
|
||||||
cylinders = characteristics->long_no_cyl;
|
|
||||||
@@ -1204,6 +1162,13 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
get_device_name(&info, dev_filename[i]);
|
|
||||||
|
|
||||||
+ filedes = open(info.devname, O_RDWR);
|
|
||||||
+ if (filedes == -1)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
+ prog_name, info.devname, strerror(errno));
|
|
||||||
+
|
|
||||||
+ get_device_info(&info);
|
|
||||||
+
|
|
||||||
if (!info.blksize_specified)
|
|
||||||
format_params = ask_user_for_blksize(format_params);
|
|
||||||
|
|
||||||
@@ -1214,7 +1179,7 @@ int main(int argc, char *argv[])
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (dasdfmt_get_volser(info.devname, old_volser) == 0)
|
|
||||||
+ if (dasdfmt_get_volser(&info, old_volser) == 0)
|
|
||||||
vtoc_volume_label_set_volser(&vlabel, old_volser);
|
|
||||||
else
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
@@ -1223,11 +1188,6 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
}
|
|
||||||
|
|
||||||
- filedes = open(info.devname, O_RDWR);
|
|
||||||
- if (filedes == -1)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
- prog_name, info.devname, strerror(errno));
|
|
||||||
-
|
|
||||||
check_disk(&info);
|
|
||||||
|
|
||||||
if (check_param(str, ERR_LENGTH, &format_params) < 0)
|
|
||||||
--- a/dasdfmt/dasdfmt.h
|
|
||||||
+++ b/dasdfmt/dasdfmt.h
|
|
||||||
@@ -32,11 +32,11 @@
|
|
||||||
#define DASD_IOCTL_LETTER 'D'
|
|
||||||
|
|
||||||
/*
|
|
||||||
- * struct dasd_information_t
|
|
||||||
+ * struct dasd_information2_t
|
|
||||||
* represents any data about the device, which is visible to userspace.
|
|
||||||
* including format and features.
|
|
||||||
*/
|
|
||||||
-typedef struct dasd_information_t {
|
|
||||||
+typedef struct dasd_information2_t {
|
|
||||||
unsigned int devno; /* S/390 devno */
|
|
||||||
unsigned int real_devno; /* for aliases */
|
|
||||||
unsigned int schid; /* S/390 subchannel identifier */
|
|
||||||
@@ -56,7 +56,17 @@ typedef struct dasd_information_t {
|
|
||||||
unsigned int confdata_size;
|
|
||||||
char characteristics[64]; /* from read_device_characteristics */
|
|
||||||
char configuration_data[256]; /* from read_configuration_data */
|
|
||||||
-} dasd_information_t;
|
|
||||||
+ unsigned int format; /* format info like formatted/cdl/ldl/... */
|
|
||||||
+ unsigned int features; /* dasd features like 'ro',... */
|
|
||||||
+ unsigned int reserved0; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved1; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved2; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved3; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved4; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved5; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved6; /* reserved for further use ,... */
|
|
||||||
+ unsigned int reserved7; /* reserved for further use ,... */
|
|
||||||
+} dasd_information2_t;
|
|
||||||
|
|
||||||
|
|
||||||
struct dasd_eckd_characteristics {
|
|
||||||
@@ -165,7 +175,7 @@ typedef struct format_data_t {
|
|
||||||
#define BIODASDENABLE _IO(DASD_IOCTL_LETTER,1)
|
|
||||||
|
|
||||||
/* Get information on a dasd device (enhanced) */
|
|
||||||
-#define BIODASDINFO _IOR(DASD_IOCTL_LETTER,1,dasd_information_t)
|
|
||||||
+#define BIODASDINFO2 _IOR(DASD_IOCTL_LETTER, 3, dasd_information2_t)
|
|
||||||
|
|
||||||
/* #define BIODASDFORMAT _IOW(IOCTL_LETTER,0,format_data_t) , deprecated */
|
|
||||||
#define BIODASDFMT _IOW(DASD_IOCTL_LETTER,1,format_data_t)
|
|
||||||
@@ -251,9 +261,8 @@ typedef struct bootstrap2 {
|
|
||||||
} __attribute__ ((packed)) bootstrap2_t;
|
|
||||||
|
|
||||||
typedef struct dasdfmt_info {
|
|
||||||
- int devno;
|
|
||||||
+ dasd_information2_t dasd_info;
|
|
||||||
char devname[PATH_MAX];
|
|
||||||
- int usage_count;
|
|
||||||
int verbosity;
|
|
||||||
int testmode;
|
|
||||||
int withoutprompt;
|
|
@ -1,210 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Refactor do_format_dasd
|
|
||||||
|
|
||||||
In order to allow for new features to be integrated properly in the
|
|
||||||
existing code, certain parts of do_format_dasd() must be moved to
|
|
||||||
separate functions. This applies to setting VTOC information and
|
|
||||||
geometrical information.
|
|
||||||
|
|
||||||
Therefore, move the relevant bits to set_geo() and set_label().
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 132 +++++++++++++++++++++++++++++++-----------------------
|
|
||||||
1 file changed, 76 insertions(+), 56 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -371,6 +371,73 @@ static int check_param(char *s, size_t b
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Retrieve disk information and set cylinders and heads accordingly.
|
|
||||||
+ */
|
|
||||||
+static void set_geo(dasdfmt_info_t *info, unsigned int *cylinders,
|
|
||||||
+ unsigned int *heads)
|
|
||||||
+{
|
|
||||||
+ struct dasd_eckd_characteristics *characteristics;
|
|
||||||
+
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Retrieving disk geometry...\n");
|
|
||||||
+
|
|
||||||
+ characteristics = (struct dasd_eckd_characteristics *)
|
|
||||||
+ &info->dasd_info.characteristics;
|
|
||||||
+ if (characteristics->no_cyl == LV_COMPAT_CYL &&
|
|
||||||
+ characteristics->long_no_cyl)
|
|
||||||
+ *cylinders = characteristics->long_no_cyl;
|
|
||||||
+ else
|
|
||||||
+ *cylinders = characteristics->no_cyl;
|
|
||||||
+ *heads = characteristics->trk_per_cyl;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * Set VTOC label information
|
|
||||||
+ */
|
|
||||||
+static void set_label(dasdfmt_info_t *info, volume_label_t *vlabel,
|
|
||||||
+ format_data_t *p, unsigned int cylinders)
|
|
||||||
+{
|
|
||||||
+ char inp_buffer[5];
|
|
||||||
+
|
|
||||||
+ if (info->writenolabel) {
|
|
||||||
+ if (cylinders > LV_COMPAT_CYL && !info->withoutprompt) {
|
|
||||||
+ printf("\n--->> ATTENTION! <<---\n");
|
|
||||||
+ printf("You specified to write no labels to a"
|
|
||||||
+ " volume with more then %u cylinders.\n"
|
|
||||||
+ "Cylinders above this limit will not be"
|
|
||||||
+ " accessible as a linux partition!\n"
|
|
||||||
+ "Type \"yes\" to continue, no will leave"
|
|
||||||
+ " the disk untouched: ", LV_COMPAT_CYL);
|
|
||||||
+ if (fgets(inp_buffer, sizeof(inp_buffer), stdin) == NULL)
|
|
||||||
+ return;
|
|
||||||
+ if (strcasecmp(inp_buffer, "yes") &&
|
|
||||||
+ strcasecmp(inp_buffer, "yes\n")) {
|
|
||||||
+ printf("Omitting ioctl call (disk will "
|
|
||||||
+ "NOT be formatted).\n");
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+ } else {
|
|
||||||
+ if (!info->labelspec && !info->keep_volser) {
|
|
||||||
+ char buf[7];
|
|
||||||
+
|
|
||||||
+ sprintf(buf, "0X%04x", info->dasd_info.devno);
|
|
||||||
+ check_volser(buf, info->dasd_info.devno);
|
|
||||||
+ vtoc_volume_label_set_volser(vlabel, buf);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (p->intensity & DASD_FMT_INT_COMPAT) {
|
|
||||||
+ info->cdl_format = 1;
|
|
||||||
+ vtoc_volume_label_set_label(vlabel, "VOL1");
|
|
||||||
+ vtoc_volume_label_set_key(vlabel, "VOL1");
|
|
||||||
+ vtoc_set_cchhb(&vlabel->vtoc, 0x0000, 0x0001, 0x01);
|
|
||||||
+ } else {
|
|
||||||
+ vtoc_volume_label_set_label(vlabel, "LNX1");
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* ask the user to specify a blocksize
|
|
||||||
*/
|
|
||||||
static format_data_t ask_user_for_blksize(format_data_t params)
|
|
||||||
@@ -452,7 +519,7 @@ static int dasdfmt_get_volser(dasdfmt_in
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
prog_name, info->devname, strerror(errno));
|
|
||||||
|
|
||||||
- if (ioctl(f, BLKSSZGET, &blksize) != 0)
|
|
||||||
+ if (ioctl(filedes, BLKSSZGET, &blksize) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BLKSSZGET "
|
|
||||||
"failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
|
|
||||||
@@ -794,67 +861,16 @@ static void dasdfmt_prepare_and_format(d
|
|
||||||
disk_disabled = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-static void do_format_dasd(dasdfmt_info_t *info, format_data_t *p,
|
|
||||||
- volume_label_t *vlabel)
|
|
||||||
+static void do_format_dasd(dasdfmt_info_t *info, volume_label_t *vlabel,
|
|
||||||
+ format_data_t *p, unsigned int cylinders,
|
|
||||||
+ unsigned int heads)
|
|
||||||
{
|
|
||||||
char inp_buffer[5];
|
|
||||||
- struct dasd_eckd_characteristics *characteristics;
|
|
||||||
- unsigned int cylinders, heads;
|
|
||||||
int count;
|
|
||||||
|
|
||||||
- if (info->verbosity > 0)
|
|
||||||
- printf("Retrieving disk geometry...\n");
|
|
||||||
-
|
|
||||||
- characteristics =
|
|
||||||
- (struct dasd_eckd_characteristics *)
|
|
||||||
- &info->dasd_info.characteristics;
|
|
||||||
- if (characteristics->no_cyl == LV_COMPAT_CYL &&
|
|
||||||
- characteristics->long_no_cyl)
|
|
||||||
- cylinders = characteristics->long_no_cyl;
|
|
||||||
- else
|
|
||||||
- cylinders = characteristics->no_cyl;
|
|
||||||
- heads = characteristics->trk_per_cyl;
|
|
||||||
-
|
|
||||||
p->start_unit = 0;
|
|
||||||
p->stop_unit = (cylinders * heads) - 1;
|
|
||||||
|
|
||||||
- if (info->writenolabel) {
|
|
||||||
- if (cylinders > LV_COMPAT_CYL && !info->withoutprompt) {
|
|
||||||
- printf("\n--->> ATTENTION! <<---\n");
|
|
||||||
- printf("You specified to write no labels to a"
|
|
||||||
- " volume with more then %u cylinders.\n"
|
|
||||||
- "Cylinders above this limit will not be"
|
|
||||||
- " accessible as a linux partition!\n"
|
|
||||||
- "Type \"yes\" to continue, no will leave"
|
|
||||||
- " the disk untouched: ", LV_COMPAT_CYL);
|
|
||||||
- if (fgets(inp_buffer, sizeof(inp_buffer), stdin) == NULL)
|
|
||||||
- return;
|
|
||||||
- if (strcasecmp(inp_buffer, "yes") &&
|
|
||||||
- strcasecmp(inp_buffer, "yes\n")) {
|
|
||||||
- printf("Omitting ioctl call (disk will "
|
|
||||||
- "NOT be formatted).\n");
|
|
||||||
- return;
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
- } else {
|
|
||||||
- if (!info->labelspec && !info->keep_volser) {
|
|
||||||
- char buf[7];
|
|
||||||
-
|
|
||||||
- sprintf(buf, "0X%04x", info->dasd_info.devno);
|
|
||||||
- check_volser(buf, info->dasd_info.devno);
|
|
||||||
- vtoc_volume_label_set_volser(vlabel, buf);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (p->intensity & DASD_FMT_INT_COMPAT) {
|
|
||||||
- info->cdl_format = 1;
|
|
||||||
- vtoc_volume_label_set_label(vlabel, "VOL1");
|
|
||||||
- vtoc_volume_label_set_key(vlabel, "VOL1");
|
|
||||||
- vtoc_set_cchhb(&vlabel->vtoc, 0x0000, 0x0001, 0x01);
|
|
||||||
- } else {
|
|
||||||
- vtoc_volume_label_set_label(vlabel, "LNX1");
|
|
||||||
- }
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
|
||||||
dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
|
||||||
|
|
||||||
@@ -938,6 +954,7 @@ int main(int argc, char *argv[])
|
|
||||||
char *hashstep_str = NULL;
|
|
||||||
|
|
||||||
int rc, index, i;
|
|
||||||
+ unsigned int cylinders, heads;
|
|
||||||
|
|
||||||
int max_parallel=1;
|
|
||||||
int running=0;
|
|
||||||
@@ -1193,7 +1210,10 @@ int main(int argc, char *argv[])
|
|
||||||
if (check_param(str, ERR_LENGTH, &format_params) < 0)
|
|
||||||
ERRMSG_EXIT(EXIT_MISUSE, "%s: %s\n", prog_name, str);
|
|
||||||
|
|
||||||
- do_format_dasd(&info, &format_params, &vlabel);
|
|
||||||
+ set_geo(&info, &cylinders, &heads);
|
|
||||||
+ set_label(&info, &vlabel, &format_params, cylinders);
|
|
||||||
+ do_format_dasd(&info, &vlabel, &format_params,
|
|
||||||
+ cylinders, heads);
|
|
||||||
|
|
||||||
if (close(filedes) != 0)
|
|
||||||
ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
@ -1,93 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Make the IOCTL BLKSSZGET reusable
|
|
||||||
|
|
||||||
The IOCTL BLKSSZGET is used to get blocksize information of a device.
|
|
||||||
Since it is used several times already and could be used for new
|
|
||||||
features as well, move the call to a separate function and make it
|
|
||||||
reusable.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 24 ++++++++++++++++--------
|
|
||||||
1 file changed, 16 insertions(+), 8 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -252,6 +252,17 @@ static void get_device_info(dasdfmt_info
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Retrieve blocksize of device
|
|
||||||
+ */
|
|
||||||
+static void get_blocksize(unsigned int *blksize)
|
|
||||||
+{
|
|
||||||
+ if (ioctl(filedes, BLKSSZGET, blksize) != 0)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl to get the blocksize "
|
|
||||||
+ "of the device failed (%s).\n", prog_name,
|
|
||||||
+ strerror(errno));
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* check for disk type and set some variables (e.g. usage count)
|
|
||||||
*/
|
|
||||||
static void check_disk(dasdfmt_info_t *info)
|
|
||||||
@@ -510,7 +521,7 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
*/
|
|
||||||
static int dasdfmt_get_volser(dasdfmt_info_t *info, char *volser)
|
|
||||||
{
|
|
||||||
- int blksize;
|
|
||||||
+ unsigned int blksize;
|
|
||||||
int f;
|
|
||||||
volume_label_t vlabel;
|
|
||||||
|
|
||||||
@@ -519,9 +530,7 @@ static int dasdfmt_get_volser(dasdfmt_in
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Unable to open device %s: %s\n",
|
|
||||||
prog_name, info->devname, strerror(errno));
|
|
||||||
|
|
||||||
- if (ioctl(filedes, BLKSSZGET, &blksize) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (label pos) IOCTL BLKSSZGET "
|
|
||||||
- "failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
+ get_blocksize(&blksize);
|
|
||||||
|
|
||||||
if (close(f) != 0)
|
|
||||||
ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
||||||
@@ -551,7 +560,8 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
format4_label_t f4;
|
|
||||||
format5_label_t f5;
|
|
||||||
format7_label_t f7;
|
|
||||||
- int rc, blksize;
|
|
||||||
+ unsigned int blksize;
|
|
||||||
+ int rc;
|
|
||||||
void *ipl1_record, *ipl2_record;
|
|
||||||
int ipl1_record_len, ipl2_record_len;
|
|
||||||
|
|
||||||
@@ -559,9 +569,7 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
if (info->verbosity > 0)
|
|
||||||
printf("Retrieving dasd information... ");
|
|
||||||
|
|
||||||
- if (ioctl(filedes, BLKSSZGET, &blksize) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (write labels) IOCTL BLKSSZGET "
|
|
||||||
- "failed (%s).\n", prog_name, strerror(errno));
|
|
||||||
+ get_blocksize(&blksize);
|
|
||||||
|
|
||||||
/*
|
|
||||||
* Don't rely on the cylinders returned by HDIO_GETGEO, they might be
|
|
@ -1,555 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Add quick format support
|
|
||||||
|
|
||||||
On occasion, a DASD device might have been formatted earlier and could
|
|
||||||
potentially be re-initialized very easily. For device initalization it
|
|
||||||
is necessary to write disk information (i.e. volume label (CDL or LDL)
|
|
||||||
and VTOC) to the first two tracks. Currently you'd need to format the
|
|
||||||
entire disk, which can take a long time and is totally unnecessary.
|
|
||||||
|
|
||||||
Therefore, add a quick format mode which formats only the first two
|
|
||||||
tracks and fills them with data accordingly.
|
|
||||||
Before any formatting is done, several checks regarding the
|
|
||||||
expected device format are performed.
|
|
||||||
|
|
||||||
The mode can be specified with the new command line switch -M (--mode)
|
|
||||||
<mode>. Where 'mode' can be either 'full' (default) or 'quick'.
|
|
||||||
|
|
||||||
Document the switch -M (--mode) and its options full and quick in the
|
|
||||||
man page.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.8 | 15 ++
|
|
||||||
dasdfmt/dasdfmt.c | 290 ++++++++++++++++++++++++++++++++++++++++++++++++++++--
|
|
||||||
dasdfmt/dasdfmt.h | 51 +++++++++
|
|
||||||
3 files changed, 344 insertions(+), 12 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.8
|
|
||||||
+++ b/dasdfmt/dasdfmt.8
|
|
||||||
@@ -67,7 +67,7 @@ Print version number and exit.
|
|
||||||
|
|
||||||
.TP
|
|
||||||
\fB-F\fR or \fB--force\fR
|
|
||||||
-Formats the device without checking, if the device is in use.
|
|
||||||
+Formats the device without performing sanity checking.
|
|
||||||
|
|
||||||
.TP
|
|
||||||
\fB-C\fR or \fB--check_host_count\fR
|
|
||||||
@@ -108,6 +108,19 @@ The value will be at least as big as the
|
|
||||||
.br
|
|
||||||
|
|
||||||
.TP
|
|
||||||
+\fB-M\fR \fImode\fR or \fB--mode\fR=\fImode\fR
|
|
||||||
+Specify the \fImode\fR to be used to format the device. Valid modes are:
|
|
||||||
+.RS
|
|
||||||
+.IP full
|
|
||||||
+Format the entire disk with the specified blocksize. (default)
|
|
||||||
+.IP quick
|
|
||||||
+Format the first two tracks and write label and partition information. Only use
|
|
||||||
+this option if you are sure that the target DASD already contains a regular
|
|
||||||
+format with the specified blocksize. A blocksize can optionally be specified
|
|
||||||
+using \fB-b\fR (\fB--blocksize\fR).
|
|
||||||
+.RE
|
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
\fB-r\fR \fIcylindercount\fR or \fB--requestsize\fR=\fIcylindercount\fR
|
|
||||||
Number of cylinders to be processed in one formatting step.
|
|
||||||
The value must be an integer in the range 1 - 255.
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -30,6 +30,7 @@ static const char copyright_notice[] = "
|
|
||||||
static int filedes;
|
|
||||||
static int disk_disabled;
|
|
||||||
static format_data_t format_params;
|
|
||||||
+static format_mode_t mode;
|
|
||||||
char *prog_name;
|
|
||||||
volatile sig_atomic_t program_interrupt_in_progress;
|
|
||||||
int reqsize;
|
|
||||||
@@ -53,6 +54,7 @@ static void exit_usage(int exitcode)
|
|
||||||
" [-b <blocksize> | --blocksize=<blocksize>]\n"
|
|
||||||
" [-d <disk layout> | --disk_layout=<disk layout>]\n"
|
|
||||||
" [-r <cylinder> | --requestsize=<cylinder>]\n"
|
|
||||||
+ " [-M <mode> | --mode=<mode>]\n"
|
|
||||||
" <device>\n\n", prog_name);
|
|
||||||
|
|
||||||
printf(" -t or --test means testmode\n"
|
|
||||||
@@ -65,7 +67,7 @@ static void exit_usage(int exitcode)
|
|
||||||
" -r x or --requestsize=x means use x cylinders in one "
|
|
||||||
"format step\n"
|
|
||||||
" -v means verbose mode\n"
|
|
||||||
- " -F means don't check if the device is in use\n"
|
|
||||||
+ " -F means format without performing sanity checking\n"
|
|
||||||
" -k means keep volume serial\n"
|
|
||||||
" -C or --check_host_count means force dasdfmt to check\n"
|
|
||||||
" the host access open count to ensure the device\n"
|
|
||||||
@@ -79,7 +81,10 @@ static void exit_usage(int exitcode)
|
|
||||||
" <disk layout> is either\n"
|
|
||||||
" 'cdl' for compatible disk layout (default) or\n"
|
|
||||||
" 'ldl' for linux disk layout\n"
|
|
||||||
- " <device> device node of the device to format\n");
|
|
||||||
+ " <device> device node of the device to format\n"
|
|
||||||
+ " <mode> is either\n"
|
|
||||||
+ " 'full' to fully format the device (default)\n"
|
|
||||||
+ " 'quick' to format only the first two tracks\n");
|
|
||||||
exit(exitcode);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -102,6 +107,131 @@ static int reread_partition_table(void)
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Helper function for recs_per_track.
|
|
||||||
+ */
|
|
||||||
+static inline unsigned int ceil_quot(unsigned int d1, unsigned int d2)
|
|
||||||
+{
|
|
||||||
+ return (d1 + (d2 - 1)) / d2;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * Calculate records per track depending on the device characteristics.
|
|
||||||
+ */
|
|
||||||
+static unsigned int recs_per_track(struct dasd_eckd_characteristics *rdc,
|
|
||||||
+ unsigned int kl, unsigned int dl)
|
|
||||||
+{
|
|
||||||
+ int dn, kn;
|
|
||||||
+
|
|
||||||
+ switch (rdc->dev_type) {
|
|
||||||
+ case 0x3380:
|
|
||||||
+ if (kl)
|
|
||||||
+ return 1499 / (15 + 7 + ceil_quot(kl + 12, 32) +
|
|
||||||
+ ceil_quot(dl + 12, 32));
|
|
||||||
+ else
|
|
||||||
+ return 1499 / (15 + ceil_quot(dl + 12, 32));
|
|
||||||
+ case 0x3390:
|
|
||||||
+ dn = ceil_quot(dl + 6, 232) + 1;
|
|
||||||
+ if (kl) {
|
|
||||||
+ kn = ceil_quot(kl + 6, 232) + 1;
|
|
||||||
+ return 1729 / (10 + 9 + ceil_quot(kl + 6 * kn, 34) +
|
|
||||||
+ 9 + ceil_quot(dl + 6 * dn, 34));
|
|
||||||
+ } else
|
|
||||||
+ return 1729 / (10 + 9 + ceil_quot(dl + 6 * dn, 34));
|
|
||||||
+ case 0x9345:
|
|
||||||
+ dn = ceil_quot(dl + 6, 232) + 1;
|
|
||||||
+ if (kl) {
|
|
||||||
+ kn = ceil_quot(kl + 6, 232) + 1;
|
|
||||||
+ return 1420 / (18 + 7 + ceil_quot(kl + 6 * kn, 34) +
|
|
||||||
+ ceil_quot(dl + 6 * dn, 34));
|
|
||||||
+ } else
|
|
||||||
+ return 1420 / (18 + 7 + ceil_quot(dl + 6 * dn, 34));
|
|
||||||
+ }
|
|
||||||
+ return 0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * Evaluate errors recognized by format checks and print appropriate error
|
|
||||||
+ * messages depending on the content of cdata.
|
|
||||||
+ */
|
|
||||||
+static void evaluate_format_error(dasdfmt_info_t *info, format_check_t *cdata,
|
|
||||||
+ unsigned int heads)
|
|
||||||
+{
|
|
||||||
+ struct dasd_eckd_characteristics *rdc;
|
|
||||||
+ /* Special blocksize values of the first 3 records of trk 0 of cyl 0 */
|
|
||||||
+ const int blksizes_trk0[] = { 24, 144, 80 };
|
|
||||||
+ /* Special blocksize value of trk 1 cyl 0 */
|
|
||||||
+ const int blksize_trk1 = 96;
|
|
||||||
+ unsigned int cyl;
|
|
||||||
+ unsigned int head;
|
|
||||||
+ unsigned int rpt;
|
|
||||||
+ unsigned int kl = 0;
|
|
||||||
+ int blksize = cdata->expect.blksize;
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Reading record zero will never happen. If the record in error is 0
|
|
||||||
+ * nonetheless, the device is not formatted at all!
|
|
||||||
+ */
|
|
||||||
+ if (cdata->rec == 0) {
|
|
||||||
+ ERRMSG("WARNING: The specified device is not "
|
|
||||||
+ "formatted at all.\n");
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ cyl = cdata->unit / heads;
|
|
||||||
+ head = cyl >> 16;
|
|
||||||
+ head <<= 4;
|
|
||||||
+ head |= cdata->unit % heads;
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * Set special expected values for the first 3 records of trk 0 of cyl 0
|
|
||||||
+ * and trk 1 of cyl 0 when checking a CDL formatted device.
|
|
||||||
+ */
|
|
||||||
+ if ((cdata->expect.intensity & DASD_FMT_INT_COMPAT) &&
|
|
||||||
+ cyl == 0 && head == 0 && cdata->rec < 4) {
|
|
||||||
+ kl = 4;
|
|
||||||
+ blksize = blksizes_trk0[cdata->rec - 1];
|
|
||||||
+ }
|
|
||||||
+ if ((cdata->expect.intensity & DASD_FMT_INT_COMPAT) &&
|
|
||||||
+ cyl == 0 && head == 1) {
|
|
||||||
+ kl = 44;
|
|
||||||
+ blksize = blksize_trk1;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ rdc = (struct dasd_eckd_characteristics *)
|
|
||||||
+ &info->dasd_info.characteristics;
|
|
||||||
+
|
|
||||||
+ rpt = recs_per_track(rdc, kl, cdata->expect.blksize);
|
|
||||||
+
|
|
||||||
+ ERRMSG("WARNING: The specified device is not formatted as expected.\n");
|
|
||||||
+ switch (cdata->result) {
|
|
||||||
+ case DASD_FMT_ERR_TOO_FEW_RECORDS:
|
|
||||||
+ ERRMSG("Too few records (found %d, expected %d) "
|
|
||||||
+ "at cyl: %d trk: %d rec: %d.\n",
|
|
||||||
+ cdata->num_records, rpt, cyl, head, cdata->rec);
|
|
||||||
+ break;
|
|
||||||
+ case DASD_FMT_ERR_TOO_MANY_RECORDS:
|
|
||||||
+ ERRMSG("Too many records (found %d, expected %d) "
|
|
||||||
+ "at cyl: %d trk: %d rec: %d.\n",
|
|
||||||
+ cdata->num_records, rpt, cyl, head, cdata->rec);
|
|
||||||
+ break;
|
|
||||||
+ case DASD_FMT_ERR_BLKSIZE:
|
|
||||||
+ ERRMSG("Invalid blocksize (found %d, expected %d) "
|
|
||||||
+ "at cyl: %d trk: %d rec: %d.\n",
|
|
||||||
+ cdata->blksize, blksize, cyl, head, cdata->rec);
|
|
||||||
+ break;
|
|
||||||
+ case DASD_FMT_ERR_RECORD_ID:
|
|
||||||
+ ERRMSG("Invalid record ID at cyl: %d trk: %d rec: %d.\n",
|
|
||||||
+ cyl, head, cdata->rec);
|
|
||||||
+ break;
|
|
||||||
+ case DASD_FMT_ERR_KEY_LENGTH:
|
|
||||||
+ ERRMSG("Invalid key length (found %d, expected %d) "
|
|
||||||
+ "at cyl: %d trk: %d rec: %d.\n",
|
|
||||||
+ cdata->key_length, kl, cyl, head, cdata->rec);
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* signal handler:
|
|
||||||
* enables the disk again in case of SIGTERM, SIGINT and SIGQUIT
|
|
||||||
*/
|
|
||||||
@@ -263,6 +393,25 @@ static void get_blocksize(unsigned int *
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Check whether a specified blocksize matches the blocksize of the device
|
|
||||||
+ */
|
|
||||||
+static void check_blocksize(dasdfmt_info_t *info, unsigned int blksize)
|
|
||||||
+{
|
|
||||||
+ unsigned int dev_blksize;
|
|
||||||
+
|
|
||||||
+ if (!info->blksize_specified ||
|
|
||||||
+ info->dasd_info.format == DASD_FORMAT_NONE)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ get_blocksize(&dev_blksize);
|
|
||||||
+ if (dev_blksize != blksize) {
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "WARNING: Device is formatted with a "
|
|
||||||
+ "different blocksize (%d).\nUse --mode=full to "
|
|
||||||
+ "perform a clean format.\n", dev_blksize);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* check for disk type and set some variables (e.g. usage count)
|
|
||||||
*/
|
|
||||||
static void check_disk(dasdfmt_info_t *info)
|
|
||||||
@@ -449,6 +598,35 @@ static void set_label(dasdfmt_info_t *in
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * This function checks whether a range of tracks is in regular format
|
|
||||||
+ * with the specified block size.
|
|
||||||
+ */
|
|
||||||
+static format_check_t check_track_format(format_data_t *p)
|
|
||||||
+{
|
|
||||||
+ format_check_t cdata = {
|
|
||||||
+ .expect = {
|
|
||||||
+ .blksize = p->blksize,
|
|
||||||
+ .intensity = p->intensity,
|
|
||||||
+ .start_unit = p->start_unit,
|
|
||||||
+ .stop_unit = p->stop_unit
|
|
||||||
+ }, 0
|
|
||||||
+ };
|
|
||||||
+
|
|
||||||
+ if (ioctl(filedes, BIODASDCHECKFMT, &cdata)) {
|
|
||||||
+ if (errno == ENOTTY) {
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: Missing kernel support "
|
|
||||||
+ "for format checking (--force to "
|
|
||||||
+ "override)\n", prog_name);
|
|
||||||
+ }
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: Could no check format: %s\n",
|
|
||||||
+ prog_name, strerror(errno));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return cdata;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* ask the user to specify a blocksize
|
|
||||||
*/
|
|
||||||
static format_data_t ask_user_for_blksize(format_data_t params)
|
|
||||||
@@ -511,6 +689,8 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
printf(" Compatible Disk Layout : %s\n",
|
|
||||||
(p->intensity & DASD_FMT_INT_COMPAT) ? "yes" : "no");
|
|
||||||
printf(" Blocksize : %d\n", p->blksize);
|
|
||||||
+ printf(" Mode : %s\n",
|
|
||||||
+ (mode == FULL) ? "Full" : "Quick");
|
|
||||||
|
|
||||||
if (info->testmode)
|
|
||||||
printf("Test mode active, omitting ioctl.\n");
|
|
||||||
@@ -869,6 +1049,62 @@ static void dasdfmt_prepare_and_format(d
|
|
||||||
disk_disabled = 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * This function will only format the first two tracks of a DASD.
|
|
||||||
+ * The rest of the DASD is untouched and left as is.
|
|
||||||
+ */
|
|
||||||
+static void dasdfmt_quick_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
+ unsigned int heads, format_data_t *p)
|
|
||||||
+{
|
|
||||||
+ format_check_t cdata = { .expect = {0}, 0 };
|
|
||||||
+ format_data_t tmp = *p;
|
|
||||||
+
|
|
||||||
+ if (info->force) {
|
|
||||||
+ printf("Skipping format check due to --force.\n");
|
|
||||||
+ } else {
|
|
||||||
+ check_blocksize(info, p->blksize);
|
|
||||||
+
|
|
||||||
+ printf("Checking the format of selected tracks...\n");
|
|
||||||
+
|
|
||||||
+ /* Check device format on the first and last 3 regular tracks */
|
|
||||||
+ tmp.start_unit = 2;
|
|
||||||
+ tmp.stop_unit = 4;
|
|
||||||
+ cdata = check_track_format(&tmp);
|
|
||||||
+ if (!cdata.result) {
|
|
||||||
+ tmp.start_unit = (cylinders * heads) - 3;
|
|
||||||
+ tmp.stop_unit = (cylinders * heads) - 1;
|
|
||||||
+ cdata = check_track_format(&tmp);
|
|
||||||
+ }
|
|
||||||
+ if (cdata.result) {
|
|
||||||
+ evaluate_format_error(info, &cdata, heads);
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "Use --mode=full to perform "
|
|
||||||
+ "a clean format.\n");
|
|
||||||
+ } else {
|
|
||||||
+ printf("Done. Disk seems fine.\n");
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
+ printf("Formatting the first two tracks of the device.\n");
|
|
||||||
+
|
|
||||||
+ /* Disable the device before we do anything */
|
|
||||||
+ if (ioctl(filedes, BIODASDDISABLE, p))
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl to disable the device "
|
|
||||||
+ "failed. (%s)\n", prog_name, strerror(errno));
|
|
||||||
+ disk_disabled = 1;
|
|
||||||
+
|
|
||||||
+ /* Now do the actual formatting of our first two tracks */
|
|
||||||
+ if (ioctl(filedes, BIODASDFMT, p))
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl to format the device "
|
|
||||||
+ "failed. (%s)\n", prog_name, strerror(errno));
|
|
||||||
+
|
|
||||||
+ /* Re-Enable the device so that we can continue working with it */
|
|
||||||
+ if (ioctl(filedes, BIODASDENABLE, p))
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl to enable the device "
|
|
||||||
+ "failed. (%s)\n", prog_name, strerror(errno));
|
|
||||||
+ disk_disabled = 0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static void do_format_dasd(dasdfmt_info_t *info, volume_label_t *vlabel,
|
|
||||||
format_data_t *p, unsigned int cylinders,
|
|
||||||
unsigned int heads)
|
|
||||||
@@ -877,7 +1113,15 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
int count;
|
|
||||||
|
|
||||||
p->start_unit = 0;
|
|
||||||
- p->stop_unit = (cylinders * heads) - 1;
|
|
||||||
+
|
|
||||||
+ switch (mode) {
|
|
||||||
+ case FULL: /* all tracks */
|
|
||||||
+ p->stop_unit = (cylinders * heads) - 1;
|
|
||||||
+ break;
|
|
||||||
+ case QUICK: /* just the first two */
|
|
||||||
+ p->stop_unit = 1;
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
|
||||||
dasdfmt_print_info(info, vlabel, cylinders, heads, p);
|
|
||||||
@@ -919,11 +1163,17 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
}
|
|
||||||
}
|
|
||||||
|
|
||||||
- if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
- printf("Formatting the device. This may take a "
|
|
||||||
- "while (get yourself a coffee).\n");
|
|
||||||
-
|
|
||||||
- dasdfmt_prepare_and_format(info, cylinders, heads, p);
|
|
||||||
+ switch (mode) {
|
|
||||||
+ case FULL:
|
|
||||||
+ if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
+ printf("Formatting the device. This may take a "
|
|
||||||
+ "while (get yourself a coffee).\n");
|
|
||||||
+ dasdfmt_prepare_and_format(info, cylinders, heads, p);
|
|
||||||
+ break;
|
|
||||||
+ case QUICK:
|
|
||||||
+ dasdfmt_quick_format(info, cylinders, heads, p);
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (!info->yast_mode)
|
|
||||||
printf("Finished formatting the device.\n");
|
|
||||||
@@ -981,6 +1231,8 @@ int main(int argc, char *argv[])
|
|
||||||
format_params.blksize = DEFAULT_BLOCKSIZE;
|
|
||||||
format_params.intensity = DASD_FMT_INT_COMPAT;
|
|
||||||
|
|
||||||
+ mode = FULL;
|
|
||||||
+
|
|
||||||
/*************** parse parameters **********************/
|
|
||||||
|
|
||||||
while (1) {
|
|
||||||
@@ -1082,6 +1334,18 @@ int main(int argc, char *argv[])
|
|
||||||
case 'C':
|
|
||||||
info.force_host = 1;
|
|
||||||
break;
|
|
||||||
+ case 'M':
|
|
||||||
+ if (strcasecmp(optarg, "full") == 0)
|
|
||||||
+ mode = FULL;
|
|
||||||
+ else if (strcasecmp(optarg, "quick") == 0)
|
|
||||||
+ mode = QUICK;
|
|
||||||
+ else
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
+ "%s: The specified mode '%s' is "
|
|
||||||
+ "invalid. Consult the man page for "
|
|
||||||
+ "more information.\n",
|
|
||||||
+ prog_name, optarg);
|
|
||||||
+ break;
|
|
||||||
case -1:
|
|
||||||
/* End of options string - start of devices list */
|
|
||||||
info.device_id = optind;
|
|
||||||
@@ -1194,8 +1458,14 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
get_device_info(&info);
|
|
||||||
|
|
||||||
- if (!info.blksize_specified)
|
|
||||||
- format_params = ask_user_for_blksize(format_params);
|
|
||||||
+ /* Either let the user specify the blksize or get it from the kernel */
|
|
||||||
+ if (!info.blksize_specified) {
|
|
||||||
+ if (!(mode == FULL ||
|
|
||||||
+ info.dasd_info.format == DASD_FORMAT_NONE))
|
|
||||||
+ get_blocksize(&format_params.blksize);
|
|
||||||
+ else
|
|
||||||
+ format_params = ask_user_for_blksize(format_params);
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (info.keep_volser) {
|
|
||||||
if (format_params.intensity == 0x00) {
|
|
||||||
--- a/dasdfmt/dasdfmt.h
|
|
||||||
+++ b/dasdfmt/dasdfmt.h
|
|
||||||
@@ -143,6 +143,14 @@ struct dasd_eckd_characteristics {
|
|
||||||
unsigned int long_no_cyl;
|
|
||||||
} __attribute__ ((packed));
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * Represents possible format modes that can be specified when formatting
|
|
||||||
+ * a DASD.
|
|
||||||
+ */
|
|
||||||
+typedef enum format_mode_t {
|
|
||||||
+ FULL, /* default mode */
|
|
||||||
+ QUICK, /* format only the first 2 tracks */
|
|
||||||
+} format_mode_t;
|
|
||||||
|
|
||||||
/*
|
|
||||||
* struct format_data_t
|
|
||||||
@@ -168,6 +176,43 @@ typedef struct format_data_t {
|
|
||||||
#define DASD_FMT_INT_COMPAT 8 /* use OS/390 compatible disk layout */
|
|
||||||
#define DASD_FMT_INT_FMT_NOR0 16 /* remove permission to write record zero */
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * struct format_check_t
|
|
||||||
+ * represents all data necessary to evaluate the format of
|
|
||||||
+ * different tracks of a dasd
|
|
||||||
+ */
|
|
||||||
+typedef struct format_check_t {
|
|
||||||
+ /* Input */
|
|
||||||
+ struct format_data_t expect;
|
|
||||||
+
|
|
||||||
+ /* Output */
|
|
||||||
+ unsigned int result; /* Error indication (DASD_FMT_ERR_*) */
|
|
||||||
+ unsigned int unit; /* Track that is in error */
|
|
||||||
+ unsigned int rec; /* Record that is in error */
|
|
||||||
+ unsigned int num_records; /* Records in the track in error */
|
|
||||||
+ unsigned int blksize; /* Block-size of first record in error */
|
|
||||||
+ unsigned int key_length; /* Key length of first record in error */
|
|
||||||
+} format_check_t;
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * values to be used in format_check_t for indicating
|
|
||||||
+ * possible format errors
|
|
||||||
+ */
|
|
||||||
+#define DASD_FMT_ERR_TOO_FEW_RECORDS 1
|
|
||||||
+#define DASD_FMT_ERR_TOO_MANY_RECORDS 2
|
|
||||||
+#define DASD_FMT_ERR_BLKSIZE 3
|
|
||||||
+#define DASD_FMT_ERR_RECORD_ID 4
|
|
||||||
+#define DASD_FMT_ERR_KEY_LENGTH 5
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * values to be used for dasd_information2_t.format
|
|
||||||
+ * 0x00: NOT formatted
|
|
||||||
+ * 0x01: Linux disc layout
|
|
||||||
+ * 0x02: Common disc layout
|
|
||||||
+ */
|
|
||||||
+#define DASD_FORMAT_NONE 0
|
|
||||||
+#define DASD_FORMAT_LDL 1
|
|
||||||
+#define DASD_FORMAT_CDL 2
|
|
||||||
|
|
||||||
/* Disable the volume (for Linux) */
|
|
||||||
#define BIODASDDISABLE _IO(DASD_IOCTL_LETTER,0)
|
|
||||||
@@ -180,6 +225,9 @@ typedef struct format_data_t {
|
|
||||||
/* #define BIODASDFORMAT _IOW(IOCTL_LETTER,0,format_data_t) , deprecated */
|
|
||||||
#define BIODASDFMT _IOW(DASD_IOCTL_LETTER,1,format_data_t)
|
|
||||||
|
|
||||||
+/* Check device format according to format_data_t */
|
|
||||||
+#define BIODASDCHECKFMT _IOWR(DASD_IOCTL_LETTER, 2, format_check_t)
|
|
||||||
+
|
|
||||||
/****************************************************************************
|
|
||||||
* SECTION: Further IOCTL Definitions (see fs.h and hdreq.h ) *
|
|
||||||
****************************************************************************/
|
|
||||||
@@ -225,7 +273,7 @@ typedef struct format_data_t {
|
|
||||||
if (*endptr) ERRMSG_EXIT(EXIT_MISUSE,"%s: " str " " \
|
|
||||||
"is in invalid format\n",prog_name);}
|
|
||||||
|
|
||||||
-#define dasdfmt_getopt_string "b:n:l:f:d:m:r:hpQLtyvVFkCYP:"
|
|
||||||
+#define dasdfmt_getopt_string "b:n:l:f:d:m:M:r:hpQLtyvVFkCYP:"
|
|
||||||
|
|
||||||
static struct option dasdfmt_getopt_long_options[]=
|
|
||||||
{
|
|
||||||
@@ -247,6 +295,7 @@ static struct option dasdfmt_getopt_long
|
|
||||||
{ "keep_volser", 0, 0, 'k'},
|
|
||||||
{ "norecordzero", 0, 0, 'z'},
|
|
||||||
{ "check_host_count", 0, 0, 'C'},
|
|
||||||
+ { "mode", 1, 0, 'M'},
|
|
||||||
{0, 0, 0, 0}
|
|
||||||
};
|
|
||||||
|
|
@ -1,279 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Make progress output reusable and add ETR
|
|
||||||
|
|
||||||
The progress indicator (in form of a progressbar, hashmarks or
|
|
||||||
percentages) is created within the formatting loop.
|
|
||||||
|
|
||||||
Put the drawing of the progress into a separate function to make it
|
|
||||||
reusable. Clean up the formatting loop while at it and make it
|
|
||||||
more readable. Also, add the estimated time remaining to the output.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.c | 198 +++++++++++++++++++++++++++++++++++++-----------------
|
|
||||||
1 file changed, 138 insertions(+), 60 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -11,6 +11,7 @@
|
|
||||||
|
|
||||||
#include <sys/utsname.h>
|
|
||||||
#include <linux/version.h>
|
|
||||||
+#include <sys/time.h>
|
|
||||||
|
|
||||||
#include "zt_common.h"
|
|
||||||
#include "dasdfmt.h"
|
|
||||||
@@ -20,6 +21,8 @@
|
|
||||||
#include <sys/wait.h>
|
|
||||||
|
|
||||||
#define BUSIDSIZE 8
|
|
||||||
+#define SEC_PER_DAY (60 * 60 * 24)
|
|
||||||
+#define SEC_PER_HOUR (60 * 60)
|
|
||||||
|
|
||||||
/* Full tool name */
|
|
||||||
static const char tool_name[] = "dasdfmt: zSeries DASD format program";
|
|
||||||
@@ -88,6 +91,120 @@ static void exit_usage(int exitcode)
|
|
||||||
exit(exitcode);
|
|
||||||
}
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * Helper function to calculate the days, hours, minutes, and seconds
|
|
||||||
+ * for a given timestamp in seconds
|
|
||||||
+ */
|
|
||||||
+static void calc_time(time_t time, int *d, int *h, int *m, int *s)
|
|
||||||
+{
|
|
||||||
+ *d = time / SEC_PER_DAY;
|
|
||||||
+ time %= SEC_PER_DAY;
|
|
||||||
+ *h = time / SEC_PER_HOUR;
|
|
||||||
+ time %= SEC_PER_HOUR;
|
|
||||||
+ *m = time / 60;
|
|
||||||
+ *s = time % 60;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * This function calculates and prints the estimated time remaining.
|
|
||||||
+ */
|
|
||||||
+static void print_etr(int p_new, int started)
|
|
||||||
+{
|
|
||||||
+ static struct timeval start;
|
|
||||||
+ struct timeval now;
|
|
||||||
+ time_t time_elapsed;
|
|
||||||
+ time_t time_end;
|
|
||||||
+ int d, h, m, s;
|
|
||||||
+ static int p_init;
|
|
||||||
+ int p;
|
|
||||||
+
|
|
||||||
+ if (!started) {
|
|
||||||
+ gettimeofday(&start, NULL);
|
|
||||||
+ p_init = p_new;
|
|
||||||
+ }
|
|
||||||
+ gettimeofday(&now, NULL);
|
|
||||||
+ time_elapsed = now.tv_sec - start.tv_sec;
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * We might start somewhere in the middle with an initial percentage
|
|
||||||
+ * value of i.e. 60%. Therefore we need to calculate the relative
|
|
||||||
+ * percentage of p_new within that remaining range (100 - 60) in order
|
|
||||||
+ * to correctly estimate the remaining time.
|
|
||||||
+ */
|
|
||||||
+ if (p_init == 100)
|
|
||||||
+ p = p_init;
|
|
||||||
+ else
|
|
||||||
+ p = 100 * (p_new - p_init) / (100 - p_init);
|
|
||||||
+
|
|
||||||
+ if (p == 0)
|
|
||||||
+ time_end = time_elapsed;
|
|
||||||
+ else
|
|
||||||
+ time_end = time_elapsed * (100 - p) / p;
|
|
||||||
+
|
|
||||||
+ /* Calculate days, hours, minutes, and seconds */
|
|
||||||
+ calc_time(time_end, &d, &h, &m, &s);
|
|
||||||
+ if (p_new == 100)
|
|
||||||
+ calc_time(time_elapsed, &d, &h, &m, &s);
|
|
||||||
+
|
|
||||||
+ /* Avoid printing leading zeros */
|
|
||||||
+ if (d > 0)
|
|
||||||
+ printf(" [%dd %dh %dm %ds%-4s", d, h, m, s, "]");
|
|
||||||
+ else if (h > 0)
|
|
||||||
+ printf(" [%dh %dm %ds%-7s", h, m, s, "]");
|
|
||||||
+ else if (m > 0)
|
|
||||||
+ printf(" [%dm %ds%-6s", m, s, "]");
|
|
||||||
+ else if (s > 0 || p > 50)
|
|
||||||
+ printf(" [%ds%-5s", s, "]");
|
|
||||||
+ else
|
|
||||||
+ printf(" [--%-1s", "]");
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * Draw the progress indicator depending on what command line argument is set.
|
|
||||||
+ * This can either be a progressbar, hashmarks, or percentage.
|
|
||||||
+ */
|
|
||||||
+static void draw_progress(dasdfmt_info_t *info, int cyl, unsigned int cylinders)
|
|
||||||
+{
|
|
||||||
+ static int hashcount;
|
|
||||||
+ static int started;
|
|
||||||
+ static int p_old;
|
|
||||||
+ int p_new = 0;
|
|
||||||
+ int barlength;
|
|
||||||
+ int i;
|
|
||||||
+
|
|
||||||
+ if (info->print_progressbar) {
|
|
||||||
+ printf("cyl %7d of %7d |", cyl, cylinders);
|
|
||||||
+ p_new = cyl * 100 / cylinders;
|
|
||||||
+ if (p_new != p_old || !started) {
|
|
||||||
+ /* percent value has changed */
|
|
||||||
+ p_old = p_new;
|
|
||||||
+ barlength = cyl * 33 / cylinders;
|
|
||||||
+ for (i = 1; i <= barlength; i++)
|
|
||||||
+ printf("#");
|
|
||||||
+ for (i = barlength + 1; i <= 33; i++)
|
|
||||||
+ printf("-");
|
|
||||||
+ printf("|%3d%%", p_new);
|
|
||||||
+ print_etr(p_new, started);
|
|
||||||
+ started = 1;
|
|
||||||
+ }
|
|
||||||
+ printf("\r");
|
|
||||||
+ fflush(stdout);
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (info->print_hashmarks &&
|
|
||||||
+ (cyl / info->hashstep - hashcount) != 0) {
|
|
||||||
+ printf("%d|", info->procnum);
|
|
||||||
+ fflush(stdout);
|
|
||||||
+ hashcount++;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (info->print_percentage) {
|
|
||||||
+ printf("cyl %7d of %7d |%3d%%\n", cyl, cylinders,
|
|
||||||
+ cyl * 100 / cylinders);
|
|
||||||
+ fflush(stdout);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
static int reread_partition_table(void)
|
|
||||||
{
|
|
||||||
int i = 0;
|
|
||||||
@@ -906,9 +1023,10 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
static void dasdfmt_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
unsigned int heads, format_data_t *format_params)
|
|
||||||
{
|
|
||||||
- format_data_t format_step;
|
|
||||||
- int j, cyl, tmp, p1, p2, hashcount = 0;
|
|
||||||
- unsigned int k;
|
|
||||||
+ unsigned int step_value;
|
|
||||||
+ unsigned long cur_trk;
|
|
||||||
+ format_data_t step;
|
|
||||||
+ int cyl = 0;
|
|
||||||
|
|
||||||
if (info->print_hashmarks) {
|
|
||||||
if (info->hashstep < reqsize)
|
|
||||||
@@ -923,73 +1041,33 @@ static void dasdfmt_format(dasdfmt_info_
|
|
||||||
info->hashstep);
|
|
||||||
}
|
|
||||||
|
|
||||||
- format_step.blksize = format_params->blksize;
|
|
||||||
- format_step.intensity = format_params->intensity;
|
|
||||||
-
|
|
||||||
- k = 0;
|
|
||||||
- cyl = 1;
|
|
||||||
- if ((info->print_progressbar || info->print_hashmarks) && !info->yast_mode)
|
|
||||||
- printf("\n");
|
|
||||||
-
|
|
||||||
- while (1) {
|
|
||||||
- p1 = -1;
|
|
||||||
- p2 = 0;
|
|
||||||
- if (k + heads * reqsize >= format_params->stop_unit)
|
|
||||||
- reqsize = 1;
|
|
||||||
- format_step.start_unit = k;
|
|
||||||
- format_step.stop_unit = k + reqsize * heads - 1;
|
|
||||||
+ step = *format_params;
|
|
||||||
+ cur_trk = format_params->start_unit;
|
|
||||||
|
|
||||||
- if (cyl == 1)
|
|
||||||
- format_step.start_unit += 1;
|
|
||||||
+ while (cur_trk < format_params->stop_unit) {
|
|
||||||
+ step_value = reqsize * heads - (cur_trk % heads);
|
|
||||||
+ step.start_unit = cur_trk;
|
|
||||||
+ if (cur_trk + reqsize * heads >= format_params->stop_unit)
|
|
||||||
+ step.stop_unit = format_params->stop_unit;
|
|
||||||
+ else
|
|
||||||
+ step.stop_unit = cur_trk + step_value - 1;
|
|
||||||
|
|
||||||
- if (ioctl(filedes, BIODASDFMT, &format_step) != 0)
|
|
||||||
+ if (ioctl(filedes, BIODASDFMT, &step) != 0)
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: (format cylinder) IOCTL "
|
|
||||||
"BIODASDFMT failed. (%s)\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
|
|
||||||
- if (info->print_progressbar) {
|
|
||||||
- printf("cyl %7d of %7d |", cyl, cylinders);
|
|
||||||
- p2 = p1;
|
|
||||||
- p1 = cyl * 100 / cylinders;
|
|
||||||
- if (p1 != p2) {
|
|
||||||
- /* percent value has changed */
|
|
||||||
- tmp = cyl * 50 / cylinders;
|
|
||||||
- for (j = 1; j <= tmp; j++)
|
|
||||||
- printf("#");
|
|
||||||
- for (j = tmp + 1; j <= 50; j++)
|
|
||||||
- printf("-");
|
|
||||||
- printf("|%3d%%", p1);
|
|
||||||
- }
|
|
||||||
- printf("\r");
|
|
||||||
- fflush(stdout);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (info->print_hashmarks)
|
|
||||||
- if ((cyl / info->hashstep - hashcount) != 0) {
|
|
||||||
- printf("%d|",info->procnum);
|
|
||||||
- fflush(stdout);
|
|
||||||
- hashcount++;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (info->print_percentage) {
|
|
||||||
- printf("cyl %7d of %7d |%3d%%\n", cyl, cylinders,
|
|
||||||
- cyl*100/cylinders);
|
|
||||||
- fflush(stdout);
|
|
||||||
- }
|
|
||||||
+ cyl = cur_trk / heads + 1;
|
|
||||||
+ draw_progress(info, cyl, cylinders);
|
|
||||||
|
|
||||||
- if (k % heads == 0) {
|
|
||||||
- k += reqsize * heads;
|
|
||||||
- cyl += reqsize;
|
|
||||||
- } else {
|
|
||||||
- k += format_params->stop_unit % heads;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if (k > format_params->stop_unit)
|
|
||||||
- break;
|
|
||||||
+ cur_trk += step_value;
|
|
||||||
}
|
|
||||||
+ /* We're done, draw the 100% mark */
|
|
||||||
+ cyl = step.stop_unit / heads + 1;
|
|
||||||
+ draw_progress(info, cyl, cylinders);
|
|
||||||
|
|
||||||
if ((info->print_progressbar || info->print_hashmarks) && !info->yast_mode)
|
|
||||||
- printf("\n\n");
|
|
||||||
+ printf("\n");
|
|
||||||
}
|
|
||||||
|
|
||||||
static void dasdfmt_prepare_and_format(dasdfmt_info_t *info,
|
|
@ -1,453 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Add command line argument --check
|
|
||||||
|
|
||||||
Provide a function to check a DASD volume for correct formatting. This
|
|
||||||
can be useful in cases where only a few tracks of a volume are
|
|
||||||
incorrectly formatted.
|
|
||||||
|
|
||||||
All tracks on the device are checked. In an error case, the check
|
|
||||||
process is stopped and appropriate messages are displayed.
|
|
||||||
|
|
||||||
The --check command line argument can be combined with either -P,
|
|
||||||
-p or -m to display progress on the console.
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.8 | 5 +
|
|
||||||
dasdfmt/dasdfmt.c | 244 ++++++++++++++++++++++++++++++++++++++++--------------
|
|
||||||
dasdfmt/dasdfmt.h | 4
|
|
||||||
3 files changed, 190 insertions(+), 63 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.8
|
|
||||||
+++ b/dasdfmt/dasdfmt.8
|
|
||||||
@@ -121,6 +121,11 @@ using \fB-b\fR (\fB--blocksize\fR).
|
|
||||||
.RE
|
|
||||||
|
|
||||||
.TP
|
|
||||||
+\fB--check\fR
|
|
||||||
+Perform a complete format check on a DASD volume. A blocksize can be specified
|
|
||||||
+with \fB-b\fR (\fB--blocksize\fR).
|
|
||||||
+
|
|
||||||
+.TP
|
|
||||||
\fB-r\fR \fIcylindercount\fR or \fB--requestsize\fR=\fIcylindercount\fR
|
|
||||||
Number of cylinders to be processed in one formatting step.
|
|
||||||
The value must be an integer in the range 1 - 255.
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -76,7 +76,8 @@ static void exit_usage(int exitcode)
|
|
||||||
" the host access open count to ensure the device\n"
|
|
||||||
" is not online on another operating system instance\n"
|
|
||||||
" --norecordzero prevent storage server from modifying"
|
|
||||||
- " record 0\n\n"
|
|
||||||
+ " record 0\n"
|
|
||||||
+ " --check perform complete format check on device\n\n"
|
|
||||||
" <volser> is the volume identifier, which is converted\n"
|
|
||||||
" to EBCDIC and written to disk.\n"
|
|
||||||
" (6 characters, e.g. LNX001\n"
|
|
||||||
@@ -163,7 +164,8 @@ static void print_etr(int p_new, int sta
|
|
||||||
* Draw the progress indicator depending on what command line argument is set.
|
|
||||||
* This can either be a progressbar, hashmarks, or percentage.
|
|
||||||
*/
|
|
||||||
-static void draw_progress(dasdfmt_info_t *info, int cyl, unsigned int cylinders)
|
|
||||||
+static void draw_progress(dasdfmt_info_t *info, int cyl, unsigned int cylinders,
|
|
||||||
+ int aborted)
|
|
||||||
{
|
|
||||||
static int hashcount;
|
|
||||||
static int started;
|
|
||||||
@@ -175,7 +177,7 @@ static void draw_progress(dasdfmt_info_t
|
|
||||||
if (info->print_progressbar) {
|
|
||||||
printf("cyl %7d of %7d |", cyl, cylinders);
|
|
||||||
p_new = cyl * 100 / cylinders;
|
|
||||||
- if (p_new != p_old || !started) {
|
|
||||||
+ if (p_new != p_old || !started || aborted) {
|
|
||||||
/* percent value has changed */
|
|
||||||
p_old = p_new;
|
|
||||||
barlength = cyl * 33 / cylinders;
|
|
||||||
@@ -184,6 +186,8 @@ static void draw_progress(dasdfmt_info_t
|
|
||||||
for (i = barlength + 1; i <= 33; i++)
|
|
||||||
printf("-");
|
|
||||||
printf("|%3d%%", p_new);
|
|
||||||
+ if (aborted)
|
|
||||||
+ p_new = 100;
|
|
||||||
print_etr(p_new, started);
|
|
||||||
started = 1;
|
|
||||||
}
|
|
||||||
@@ -284,11 +288,17 @@ static void evaluate_format_error(dasdfm
|
|
||||||
unsigned int kl = 0;
|
|
||||||
int blksize = cdata->expect.blksize;
|
|
||||||
|
|
||||||
+ if (info->print_progressbar || info->print_hashmarks)
|
|
||||||
+ printf("\n");
|
|
||||||
+
|
|
||||||
/*
|
|
||||||
- * Reading record zero will never happen. If the record in error is 0
|
|
||||||
- * nonetheless, the device is not formatted at all!
|
|
||||||
+ * If mode is not QUICK and a device format couldn't be determined, the
|
|
||||||
+ * device is considered not formatted.
|
|
||||||
+ * Also, reading record zero will never happen. If the record in error
|
|
||||||
+ * is 0 nonetheless, the device is not formatted at all as well!
|
|
||||||
*/
|
|
||||||
- if (cdata->rec == 0) {
|
|
||||||
+ if ((info->dasd_info.format == DASD_FORMAT_NONE && mode != QUICK) ||
|
|
||||||
+ cdata->rec == 0) {
|
|
||||||
ERRMSG("WARNING: The specified device is not "
|
|
||||||
"formatted at all.\n");
|
|
||||||
return;
|
|
||||||
@@ -529,6 +539,35 @@ static void check_blocksize(dasdfmt_info
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Check whether a specified layout matches the layout
|
|
||||||
+ * a device is formatted with.
|
|
||||||
+ */
|
|
||||||
+static void check_layout(dasdfmt_info_t *info, unsigned int intensity)
|
|
||||||
+{
|
|
||||||
+ char layout[4];
|
|
||||||
+
|
|
||||||
+ if (!info->layout_specified ||
|
|
||||||
+ info->dasd_info.format == DASD_FORMAT_NONE)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ if ((intensity & DASD_FMT_INT_COMPAT) &&
|
|
||||||
+ info->dasd_info.format == DASD_FORMAT_CDL)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ if (!(intensity & DASD_FMT_INT_COMPAT) &&
|
|
||||||
+ info->dasd_info.format == DASD_FORMAT_LDL)
|
|
||||||
+ return;
|
|
||||||
+
|
|
||||||
+ if (info->dasd_info.format == DASD_FORMAT_CDL)
|
|
||||||
+ sprintf(layout, "CDL");
|
|
||||||
+ if (info->dasd_info.format == DASD_FORMAT_LDL)
|
|
||||||
+ sprintf(layout, "LDL");
|
|
||||||
+
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "WARNING: Device is formatted with a "
|
|
||||||
+ "different layout (%s).\n", layout);
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* check for disk type and set some variables (e.g. usage count)
|
|
||||||
*/
|
|
||||||
static void check_disk(dasdfmt_info_t *info)
|
|
||||||
@@ -715,10 +754,29 @@ static void set_label(dasdfmt_info_t *in
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * Check whether hashsteps are within the correct interval.
|
|
||||||
+ */
|
|
||||||
+static void check_hashmarks(dasdfmt_info_t *info)
|
|
||||||
+{
|
|
||||||
+ if (info->print_hashmarks) {
|
|
||||||
+ if (info->hashstep < reqsize)
|
|
||||||
+ info->hashstep = reqsize;
|
|
||||||
+ if ((info->hashstep < 1) || (info->hashstep > 1000)) {
|
|
||||||
+ printf("Hashmark increment is not in range <1,1000>, "
|
|
||||||
+ "using the default.\n");
|
|
||||||
+ info->hashstep = 10;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ printf("Printing hashmark every %d cylinders.\n",
|
|
||||||
+ info->hashstep);
|
|
||||||
+ }
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* This function checks whether a range of tracks is in regular format
|
|
||||||
* with the specified block size.
|
|
||||||
*/
|
|
||||||
-static format_check_t check_track_format(format_data_t *p)
|
|
||||||
+static format_check_t check_track_format(dasdfmt_info_t *info, format_data_t *p)
|
|
||||||
{
|
|
||||||
format_check_t cdata = {
|
|
||||||
.expect = {
|
|
||||||
@@ -731,9 +789,11 @@ static format_check_t check_track_format
|
|
||||||
|
|
||||||
if (ioctl(filedes, BIODASDCHECKFMT, &cdata)) {
|
|
||||||
if (errno == ENOTTY) {
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: Missing kernel support "
|
|
||||||
- "for format checking (--force to "
|
|
||||||
- "override)\n", prog_name);
|
|
||||||
+ ERRMSG("%s: Missing kernel support for format checking",
|
|
||||||
+ prog_name);
|
|
||||||
+ if (!info->check)
|
|
||||||
+ ERRMSG(" (--force to override)");
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, ".\n");
|
|
||||||
}
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Could no check format: %s\n",
|
|
||||||
prog_name, strerror(errno));
|
|
||||||
@@ -742,6 +802,97 @@ static format_check_t check_track_format
|
|
||||||
return cdata;
|
|
||||||
}
|
|
||||||
|
|
||||||
+/*
|
|
||||||
+ * Either do the actual format or check depending on the check-value.
|
|
||||||
+ */
|
|
||||||
+static int process_tracks(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
+ unsigned int heads, format_data_t *format_params)
|
|
||||||
+{
|
|
||||||
+ format_check_t cdata = { .expect = {0}, 0};
|
|
||||||
+ format_data_t step = *format_params;
|
|
||||||
+ unsigned long step_value;
|
|
||||||
+ unsigned long cur_trk;
|
|
||||||
+ int cyl = 0;
|
|
||||||
+
|
|
||||||
+ check_hashmarks(info);
|
|
||||||
+
|
|
||||||
+ cur_trk = format_params->start_unit;
|
|
||||||
+
|
|
||||||
+ while (cur_trk < format_params->stop_unit) {
|
|
||||||
+ step_value = reqsize * heads - (cur_trk % heads);
|
|
||||||
+ step.start_unit = cur_trk;
|
|
||||||
+ if (cur_trk + heads * reqsize >= format_params->stop_unit)
|
|
||||||
+ step.stop_unit = format_params->stop_unit;
|
|
||||||
+ else
|
|
||||||
+ step.stop_unit = cur_trk + step_value - 1;
|
|
||||||
+
|
|
||||||
+ if (info->check) {
|
|
||||||
+ cdata = check_track_format(info, &step);
|
|
||||||
+ if (cdata.result) {
|
|
||||||
+ cyl = cur_trk / heads + 1;
|
|
||||||
+ draw_progress(info, cyl, cylinders, 1);
|
|
||||||
+ evaluate_format_error(info, &cdata, heads);
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+ } else {
|
|
||||||
+ if (ioctl(filedes, BIODASDFMT, &step) != 0)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: the ioctl call "
|
|
||||||
+ "to format tracks failed. (%s)\n",
|
|
||||||
+ prog_name, strerror(errno));
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ cyl = cur_trk / heads + 1;
|
|
||||||
+ draw_progress(info, cyl, cylinders, 0);
|
|
||||||
+
|
|
||||||
+ cur_trk += step_value;
|
|
||||||
+ }
|
|
||||||
+ /* We're done, draw the 100% mark */
|
|
||||||
+ if (!cdata.result) {
|
|
||||||
+ cyl = step.stop_unit / heads + 1;
|
|
||||||
+ draw_progress(info, cyl, cylinders, 0);
|
|
||||||
+ printf("\n");
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return cdata.result;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
+ * This function checks the format of the entire disk.
|
|
||||||
+ */
|
|
||||||
+static void check_disk_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
+ unsigned int heads, format_data_t *check_params)
|
|
||||||
+{
|
|
||||||
+ check_params->start_unit = 0;
|
|
||||||
+ check_params->stop_unit = (cylinders * heads) - 1;
|
|
||||||
+
|
|
||||||
+ printf("Checking format of the entire disk...\n");
|
|
||||||
+
|
|
||||||
+ if (info->testmode) {
|
|
||||||
+ printf("Test mode active, omitting ioctl.\n");
|
|
||||||
+ return;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ check_blocksize(info, check_params->blksize);
|
|
||||||
+ check_layout(info, check_params->intensity);
|
|
||||||
+
|
|
||||||
+ /*
|
|
||||||
+ * If no layout was specified, set the intensity
|
|
||||||
+ * according to what the layout seems to be.
|
|
||||||
+ */
|
|
||||||
+ if (!info->layout_specified) {
|
|
||||||
+ if (info->dasd_info.format == DASD_FORMAT_CDL)
|
|
||||||
+ check_params->intensity |= DASD_FMT_INT_COMPAT;
|
|
||||||
+ else if (info->dasd_info.format == DASD_FORMAT_LDL)
|
|
||||||
+ check_params->intensity &= ~DASD_FMT_INT_COMPAT;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (process_tracks(info, cylinders, heads, check_params)) {
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "Use --mode=full to perform a "
|
|
||||||
+ "clean format.\n");
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ printf("Done. Disk is fine.\n");
|
|
||||||
+}
|
|
||||||
|
|
||||||
/*
|
|
||||||
* ask the user to specify a blocksize
|
|
||||||
@@ -1023,51 +1174,7 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
static void dasdfmt_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
unsigned int heads, format_data_t *format_params)
|
|
||||||
{
|
|
||||||
- unsigned int step_value;
|
|
||||||
- unsigned long cur_trk;
|
|
||||||
- format_data_t step;
|
|
||||||
- int cyl = 0;
|
|
||||||
-
|
|
||||||
- if (info->print_hashmarks) {
|
|
||||||
- if (info->hashstep < reqsize)
|
|
||||||
- info->hashstep = reqsize;
|
|
||||||
- if ((info->hashstep < 1) || (info->hashstep > 1000)) {
|
|
||||||
- printf("Hashmark increment is not in range <1,1000>, "
|
|
||||||
- "using the default.\n");
|
|
||||||
- info->hashstep = 10;
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- if(!info->yast_mode) printf("Printing hashmark every %d cylinders.\n",
|
|
||||||
- info->hashstep);
|
|
||||||
- }
|
|
||||||
-
|
|
||||||
- step = *format_params;
|
|
||||||
- cur_trk = format_params->start_unit;
|
|
||||||
-
|
|
||||||
- while (cur_trk < format_params->stop_unit) {
|
|
||||||
- step_value = reqsize * heads - (cur_trk % heads);
|
|
||||||
- step.start_unit = cur_trk;
|
|
||||||
- if (cur_trk + reqsize * heads >= format_params->stop_unit)
|
|
||||||
- step.stop_unit = format_params->stop_unit;
|
|
||||||
- else
|
|
||||||
- step.stop_unit = cur_trk + step_value - 1;
|
|
||||||
-
|
|
||||||
- if (ioctl(filedes, BIODASDFMT, &step) != 0)
|
|
||||||
- ERRMSG_EXIT(EXIT_FAILURE, "%s: (format cylinder) IOCTL "
|
|
||||||
- "BIODASDFMT failed. (%s)\n",
|
|
||||||
- prog_name, strerror(errno));
|
|
||||||
-
|
|
||||||
- cyl = cur_trk / heads + 1;
|
|
||||||
- draw_progress(info, cyl, cylinders);
|
|
||||||
-
|
|
||||||
- cur_trk += step_value;
|
|
||||||
- }
|
|
||||||
- /* We're done, draw the 100% mark */
|
|
||||||
- cyl = step.stop_unit / heads + 1;
|
|
||||||
- draw_progress(info, cyl, cylinders);
|
|
||||||
-
|
|
||||||
- if ((info->print_progressbar || info->print_hashmarks) && !info->yast_mode)
|
|
||||||
- printf("\n");
|
|
||||||
+ process_tracks(info, cylinders, heads, format_params);
|
|
||||||
}
|
|
||||||
|
|
||||||
static void dasdfmt_prepare_and_format(dasdfmt_info_t *info,
|
|
||||||
@@ -1082,6 +1189,10 @@ static void dasdfmt_prepare_and_format(d
|
|
||||||
| DASD_FMT_INT_INVAL)
|
|
||||||
};
|
|
||||||
|
|
||||||
+ if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
+ printf("Formatting the device. This may take a while "
|
|
||||||
+ "(get yourself a coffee).\n");
|
|
||||||
+
|
|
||||||
if (info->verbosity > 0)
|
|
||||||
printf("Detaching the device...\n");
|
|
||||||
|
|
||||||
@@ -1147,11 +1258,11 @@ static void dasdfmt_quick_format(dasdfmt
|
|
||||||
/* Check device format on the first and last 3 regular tracks */
|
|
||||||
tmp.start_unit = 2;
|
|
||||||
tmp.stop_unit = 4;
|
|
||||||
- cdata = check_track_format(&tmp);
|
|
||||||
+ cdata = check_track_format(info, &tmp);
|
|
||||||
if (!cdata.result) {
|
|
||||||
tmp.start_unit = (cylinders * heads) - 3;
|
|
||||||
tmp.stop_unit = (cylinders * heads) - 1;
|
|
||||||
- cdata = check_track_format(&tmp);
|
|
||||||
+ cdata = check_track_format(info, &tmp);
|
|
||||||
}
|
|
||||||
if (cdata.result) {
|
|
||||||
evaluate_format_error(info, &cdata, heads);
|
|
||||||
@@ -1243,9 +1354,6 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
|
|
||||||
switch (mode) {
|
|
||||||
case FULL:
|
|
||||||
- if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
- printf("Formatting the device. This may take a "
|
|
||||||
- "while (get yourself a coffee).\n");
|
|
||||||
dasdfmt_prepare_and_format(info, cylinders, heads, p);
|
|
||||||
break;
|
|
||||||
case QUICK:
|
|
||||||
@@ -1337,6 +1445,7 @@ int main(int argc, char *argv[])
|
|
||||||
printf("%s is not a valid option!\n", optarg);
|
|
||||||
exit(1);
|
|
||||||
}
|
|
||||||
+ info.layout_specified = 1;
|
|
||||||
break;
|
|
||||||
case 'y':
|
|
||||||
info.withoutprompt = 1;
|
|
||||||
@@ -1424,6 +1533,9 @@ int main(int argc, char *argv[])
|
|
||||||
"more information.\n",
|
|
||||||
prog_name, optarg);
|
|
||||||
break;
|
|
||||||
+ case OPT_CHECK:
|
|
||||||
+ info.check = 1;
|
|
||||||
+ break;
|
|
||||||
case -1:
|
|
||||||
/* End of options string - start of devices list */
|
|
||||||
info.device_id = optind;
|
|
||||||
@@ -1539,7 +1651,7 @@ int main(int argc, char *argv[])
|
|
||||||
/* Either let the user specify the blksize or get it from the kernel */
|
|
||||||
if (!info.blksize_specified) {
|
|
||||||
if (!(mode == FULL ||
|
|
||||||
- info.dasd_info.format == DASD_FORMAT_NONE))
|
|
||||||
+ info.dasd_info.format == DASD_FORMAT_NONE) || info.check)
|
|
||||||
get_blocksize(&format_params.blksize);
|
|
||||||
else
|
|
||||||
format_params = ask_user_for_blksize(format_params);
|
|
||||||
@@ -1568,8 +1680,14 @@ int main(int argc, char *argv[])
|
|
||||||
|
|
||||||
set_geo(&info, &cylinders, &heads);
|
|
||||||
set_label(&info, &vlabel, &format_params, cylinders);
|
|
||||||
- do_format_dasd(&info, &vlabel, &format_params,
|
|
||||||
- cylinders, heads);
|
|
||||||
+
|
|
||||||
+ if (info.check) {
|
|
||||||
+ check_disk_format(&info, cylinders, heads,
|
|
||||||
+ &format_params);
|
|
||||||
+ } else {
|
|
||||||
+ do_format_dasd(&info, &vlabel, &format_params,
|
|
||||||
+ cylinders, heads);
|
|
||||||
+ }
|
|
||||||
|
|
||||||
if (close(filedes) != 0)
|
|
||||||
ERRMSG("%s: error during close: %s\ncontinuing...\n",
|
|
||||||
--- a/dasdfmt/dasdfmt.h
|
|
||||||
+++ b/dasdfmt/dasdfmt.h
|
|
||||||
@@ -273,6 +273,7 @@ typedef struct format_check_t {
|
|
||||||
if (*endptr) ERRMSG_EXIT(EXIT_MISUSE,"%s: " str " " \
|
|
||||||
"is in invalid format\n",prog_name);}
|
|
||||||
|
|
||||||
+#define OPT_CHECK 128
|
|
||||||
#define dasdfmt_getopt_string "b:n:l:f:d:m:M:r:hpQLtyvVFkCYP:"
|
|
||||||
|
|
||||||
static struct option dasdfmt_getopt_long_options[]=
|
|
||||||
@@ -296,6 +297,7 @@ static struct option dasdfmt_getopt_long
|
|
||||||
{ "norecordzero", 0, 0, 'z'},
|
|
||||||
{ "check_host_count", 0, 0, 'C'},
|
|
||||||
{ "mode", 1, 0, 'M'},
|
|
||||||
+ { "check", 0, 0, OPT_CHECK},
|
|
||||||
{0, 0, 0, 0}
|
|
||||||
};
|
|
||||||
|
|
||||||
@@ -328,6 +330,8 @@ typedef struct dasdfmt_info {
|
|
||||||
int device_id;
|
|
||||||
int keep_volser;
|
|
||||||
int force_host;
|
|
||||||
+ int layout_specified;
|
|
||||||
+ int check;
|
|
||||||
int yast_mode;
|
|
||||||
int procnum;
|
|
||||||
} dasdfmt_info_t;
|
|
@ -1,266 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1501] dasdfmt: Add new formatting modes
|
|
||||||
From: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dasdfmt: Add new formatting modes
|
|
||||||
Description: Introduce new formatting modes 'quick' and 'expand' to either
|
|
||||||
format an earlier formatted DASD that could potentially be
|
|
||||||
re-initialized very easily or format unformatted tracks at the
|
|
||||||
end of a device that was previously extended.
|
|
||||||
|
|
||||||
Also add the command line argument --check to provide a function
|
|
||||||
that checks a DASD volume for correct formatting.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1501
|
|
||||||
|
|
||||||
Upstream-Description:
|
|
||||||
|
|
||||||
dasdfmt: Add expand format mode
|
|
||||||
|
|
||||||
If a DASD was extended, the format of the first part of the disk
|
|
||||||
can be assumed to be correct. Usually, a full format would be necessary
|
|
||||||
to ensure a fully functional disk. However, this would also format
|
|
||||||
the already formatted part resulting in the loss of the data stored in
|
|
||||||
that part.
|
|
||||||
|
|
||||||
Add an expand mode which will search for the start of the unformatted
|
|
||||||
area and begin formatting from there.
|
|
||||||
|
|
||||||
The mode is being specified by --mode=expand (or -M expand for short).
|
|
||||||
|
|
||||||
Furthermore:
|
|
||||||
- Add string array for the individual modes for output purposes
|
|
||||||
- Avoid writing labels when EXPAND mode is active since they can be
|
|
||||||
assumed to be correct
|
|
||||||
- Add man page description
|
|
||||||
|
|
||||||
|
|
||||||
Signed-off-by: Jan Höppner <hoeppner@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
dasdfmt/dasdfmt.8 | 7 +++
|
|
||||||
dasdfmt/dasdfmt.c | 120 +++++++++++++++++++++++++++++++++++++++++++++++++-----
|
|
||||||
dasdfmt/dasdfmt.h | 5 ++
|
|
||||||
3 files changed, 123 insertions(+), 9 deletions(-)
|
|
||||||
|
|
||||||
--- a/dasdfmt/dasdfmt.8
|
|
||||||
+++ b/dasdfmt/dasdfmt.8
|
|
||||||
@@ -118,6 +118,13 @@ Format the first two tracks and write la
|
|
||||||
this option if you are sure that the target DASD already contains a regular
|
|
||||||
format with the specified blocksize. A blocksize can optionally be specified
|
|
||||||
using \fB-b\fR (\fB--blocksize\fR).
|
|
||||||
+.IP expand
|
|
||||||
+Format all unformatted tracks at the end of the target DASD. This mode assumes
|
|
||||||
+that tracks at the beginning of the DASD volume have already been correctly
|
|
||||||
+formatted, while a consecutive set of tracks at the end are unformatted. You can
|
|
||||||
+use this mode to make added space available for Linux use after dynamically
|
|
||||||
+increasing the size of a DASD volume. A blocksize can optionally be specified
|
|
||||||
+using \fB-b\fR (\fB--blocksize\fR).
|
|
||||||
.RE
|
|
||||||
|
|
||||||
.TP
|
|
||||||
--- a/dasdfmt/dasdfmt.c
|
|
||||||
+++ b/dasdfmt/dasdfmt.c
|
|
||||||
@@ -88,7 +88,9 @@ static void exit_usage(int exitcode)
|
|
||||||
" <device> device node of the device to format\n"
|
|
||||||
" <mode> is either\n"
|
|
||||||
" 'full' to fully format the device (default)\n"
|
|
||||||
- " 'quick' to format only the first two tracks\n");
|
|
||||||
+ " 'quick' to format only the first two tracks\n"
|
|
||||||
+ " 'expand' to format only the unformatted end"
|
|
||||||
+ " of a device\n");
|
|
||||||
exit(exitcode);
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -791,8 +793,11 @@ static format_check_t check_track_format
|
|
||||||
if (errno == ENOTTY) {
|
|
||||||
ERRMSG("%s: Missing kernel support for format checking",
|
|
||||||
prog_name);
|
|
||||||
- if (!info->check)
|
|
||||||
+ if (mode == EXPAND) {
|
|
||||||
+ ERRMSG(". Mode 'expand' cannot be used");
|
|
||||||
+ } else if (!info->check) {
|
|
||||||
ERRMSG(" (--force to override)");
|
|
||||||
+ }
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, ".\n");
|
|
||||||
}
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE, "%s: Could no check format: %s\n",
|
|
||||||
@@ -957,8 +962,7 @@ static void dasdfmt_print_info(dasdfmt_i
|
|
||||||
printf(" Compatible Disk Layout : %s\n",
|
|
||||||
(p->intensity & DASD_FMT_INT_COMPAT) ? "yes" : "no");
|
|
||||||
printf(" Blocksize : %d\n", p->blksize);
|
|
||||||
- printf(" Mode : %s\n",
|
|
||||||
- (mode == FULL) ? "Full" : "Quick");
|
|
||||||
+ printf(" Mode : %s\n", mode_str[mode]);
|
|
||||||
|
|
||||||
if (info->testmode)
|
|
||||||
printf("Test mode active, omitting ioctl.\n");
|
|
||||||
@@ -1169,6 +1173,60 @@ static void dasdfmt_write_labels(dasdfmt
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * This function will search for the beginning of an unformatted area
|
|
||||||
+ * on the device. It checks selected tracks beforehand and makes sure
|
|
||||||
+ * that the device is formatted to a certain extent. Otherwise the
|
|
||||||
+ * process is terminated.
|
|
||||||
+ */
|
|
||||||
+static void dasdfmt_find_start(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
+ unsigned heads, format_data_t *format_params)
|
|
||||||
+{
|
|
||||||
+ format_check_t cdata;
|
|
||||||
+ unsigned int middle;
|
|
||||||
+ unsigned int left = 2;
|
|
||||||
+ unsigned int right = (cylinders * heads) - 1;
|
|
||||||
+ unsigned int first = left;
|
|
||||||
+
|
|
||||||
+ check_blocksize(info, format_params->blksize);
|
|
||||||
+
|
|
||||||
+ format_params->start_unit = 0;
|
|
||||||
+ format_params->stop_unit = 4;
|
|
||||||
+ cdata = check_track_format(info, format_params);
|
|
||||||
+
|
|
||||||
+ if (cdata.result) {
|
|
||||||
+ evaluate_format_error(info, &cdata, heads);
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "Use --mode=full to perform a "
|
|
||||||
+ "clean format.\n");
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ printf("Expansion mode active. Searching for starting position...\n");
|
|
||||||
+
|
|
||||||
+ while (left <= right) {
|
|
||||||
+ /* new track number to look at */
|
|
||||||
+ middle = left + ((right - left) / 2);
|
|
||||||
+
|
|
||||||
+ format_params->start_unit = middle;
|
|
||||||
+ format_params->stop_unit = middle;
|
|
||||||
+ cdata = check_track_format(info, format_params);
|
|
||||||
+ if (cdata.blksize != format_params->blksize) {
|
|
||||||
+ first = middle;
|
|
||||||
+ right = middle - 1;
|
|
||||||
+ } else {
|
|
||||||
+ left = middle + 1;
|
|
||||||
+ }
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ if (first == 2 && cdata.blksize == format_params->blksize)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
+ "No unformatted part found, aborting.\n");
|
|
||||||
+
|
|
||||||
+ printf("Done. Unformatted part starts at track %d.\n", first);
|
|
||||||
+
|
|
||||||
+ /* return format_params with start_unit set to the correct value */
|
|
||||||
+ format_params->start_unit = first;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* formats the disk cylinderwise
|
|
||||||
*/
|
|
||||||
static void dasdfmt_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
@@ -1239,6 +1297,40 @@ static void dasdfmt_prepare_and_format(d
|
|
||||||
}
|
|
||||||
|
|
||||||
/*
|
|
||||||
+ * This function will start the expand format process.
|
|
||||||
+ */
|
|
||||||
+static void dasdfmt_expand_format(dasdfmt_info_t *info, unsigned int cylinders,
|
|
||||||
+ unsigned int heads, format_data_t *p)
|
|
||||||
+{
|
|
||||||
+ if (!((info->withoutprompt) && (info->verbosity < 1)))
|
|
||||||
+ printf("Formatting the device. This may take a while "
|
|
||||||
+ "(get yourself a coffee).\n");
|
|
||||||
+
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Detaching the device...\n");
|
|
||||||
+
|
|
||||||
+ if (ioctl(filedes, BIODASDDISABLE, p) != 0)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
+ "BIODASDDISABLE failed. (%s)\n", prog_name,
|
|
||||||
+ strerror(errno));
|
|
||||||
+ disk_disabled = 1;
|
|
||||||
+
|
|
||||||
+ dasdfmt_format(info, cylinders, heads, p);
|
|
||||||
+
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Formatting tracks complete...\n");
|
|
||||||
+
|
|
||||||
+ if (info->verbosity > 0)
|
|
||||||
+ printf("Re-accessing the device...\n");
|
|
||||||
+
|
|
||||||
+ if (ioctl(filedes, BIODASDENABLE, p) != 0)
|
|
||||||
+ ERRMSG_EXIT(EXIT_FAILURE, "%s: (prepare device) IOCTL "
|
|
||||||
+ "BIODASDENABLE failed. (%s)\n", prog_name,
|
|
||||||
+ strerror(errno));
|
|
||||||
+ disk_disabled = 0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/*
|
|
||||||
* This function will only format the first two tracks of a DASD.
|
|
||||||
* The rest of the DASD is untouched and left as is.
|
|
||||||
*/
|
|
||||||
@@ -1310,6 +1402,10 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
case QUICK: /* just the first two */
|
|
||||||
p->stop_unit = 1;
|
|
||||||
break;
|
|
||||||
+ case EXPAND: /* only the end of the disk */
|
|
||||||
+ dasdfmt_find_start(info, cylinders, heads, p);
|
|
||||||
+ p->stop_unit = (cylinders * heads) - 1;
|
|
||||||
+ break;
|
|
||||||
}
|
|
||||||
|
|
||||||
if ((info->verbosity > 0) || !info->withoutprompt || info->testmode)
|
|
||||||
@@ -1338,10 +1434,12 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
|
|
||||||
if (!info->testmode) {
|
|
||||||
if (!info->withoutprompt) {
|
|
||||||
- printf("\n--->> ATTENTION! <<---\n");
|
|
||||||
- printf("All data of that device will be lost.\nType "
|
|
||||||
- "\"yes\" to continue, no will leave the disk "
|
|
||||||
- "untouched: ");
|
|
||||||
+ printf("\n");
|
|
||||||
+ if (mode != EXPAND)
|
|
||||||
+ printf("--->> ATTENTION! <<---\nAll data of "
|
|
||||||
+ "that device will be lost.\n");
|
|
||||||
+ printf("Type \"yes\" to continue, no will leave the "
|
|
||||||
+ "disk untouched: ");
|
|
||||||
if (fgets(inp_buffer, sizeof(inp_buffer), stdin) == NULL)
|
|
||||||
return;
|
|
||||||
if (strcasecmp(inp_buffer, "yes") &&
|
|
||||||
@@ -1359,12 +1457,14 @@ static void do_format_dasd(dasdfmt_info_
|
|
||||||
case QUICK:
|
|
||||||
dasdfmt_quick_format(info, cylinders, heads, p);
|
|
||||||
break;
|
|
||||||
+ case EXPAND:
|
|
||||||
+ dasdfmt_expand_format(info, cylinders, heads, p);
|
|
||||||
}
|
|
||||||
|
|
||||||
if (!info->yast_mode)
|
|
||||||
printf("Finished formatting the device.\n");
|
|
||||||
|
|
||||||
- if (!info->writenolabel)
|
|
||||||
+ if (!(info->writenolabel || mode == EXPAND))
|
|
||||||
dasdfmt_write_labels(info, vlabel, cylinders, heads);
|
|
||||||
|
|
||||||
if (!info->yast_mode)
|
|
||||||
@@ -1526,6 +1626,8 @@ int main(int argc, char *argv[])
|
|
||||||
mode = FULL;
|
|
||||||
else if (strcasecmp(optarg, "quick") == 0)
|
|
||||||
mode = QUICK;
|
|
||||||
+ else if (strcasecmp(optarg, "expand") == 0)
|
|
||||||
+ mode = EXPAND;
|
|
||||||
else
|
|
||||||
ERRMSG_EXIT(EXIT_FAILURE,
|
|
||||||
"%s: The specified mode '%s' is "
|
|
||||||
--- a/dasdfmt/dasdfmt.h
|
|
||||||
+++ b/dasdfmt/dasdfmt.h
|
|
||||||
@@ -150,8 +150,13 @@ struct dasd_eckd_characteristics {
|
|
||||||
typedef enum format_mode_t {
|
|
||||||
FULL, /* default mode */
|
|
||||||
QUICK, /* format only the first 2 tracks */
|
|
||||||
+ EXPAND, /* search for unformatted area and format only that part*/
|
|
||||||
} format_mode_t;
|
|
||||||
|
|
||||||
+static const char mode_str[3][10] = {
|
|
||||||
+ "Full", "Quick", "Expand"
|
|
||||||
+};
|
|
||||||
+
|
|
||||||
/*
|
|
||||||
* struct format_data_t
|
|
||||||
* represents all data necessary to format a dasd
|
|
File diff suppressed because it is too large
Load Diff
File diff suppressed because it is too large
Load Diff
@ -1,72 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT RTL1601] dbginfo.sh: Make use of sysfs collection helper
|
|
||||||
From: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: dbginfo.sh: Make use of sysfs collection helper
|
|
||||||
Description: If available, use dump2tar in dbginfo.sh for sysfs
|
|
||||||
file collection to significantly speed up dbginfo.sh
|
|
||||||
processing. Example speedup on an LPAR with ~190k
|
|
||||||
sysfs files:
|
|
||||||
|
|
||||||
Unpatched:
|
|
||||||
# time ./dbginfo.sh
|
|
||||||
real 1m19.624s
|
|
||||||
user 0m44.985s
|
|
||||||
sys 0m45.173s
|
|
||||||
|
|
||||||
Patched:
|
|
||||||
# time ./dbginfo.sh
|
|
||||||
real 0m5.822s
|
|
||||||
user 0m4.523s
|
|
||||||
sys 0m2.636s
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: RTL1601
|
|
||||||
|
|
||||||
Signed-off-by: Peter Oberparleiter <oberpar@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
scripts/dbginfo.sh | 33 +++++++++++++++++++++------------
|
|
||||||
1 file changed, 21 insertions(+), 12 deletions(-)
|
|
||||||
|
|
||||||
--- a/scripts/dbginfo.sh
|
|
||||||
+++ b/scripts/dbginfo.sh
|
|
||||||
@@ -620,20 +620,29 @@ collect_sysfs() {
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
|
|
||||||
- call_run_command "find /sys -print0 | sort -z | xargs -0 -n 10 ls -ld" "${OUTPUT_FILE_SYSFS}"
|
|
||||||
+ # Collect sysfs files using multiple threads (-J 1) while excluding
|
|
||||||
+ # files known to block on read (-x). Stop reading a file that takes
|
|
||||||
+ # more than 5 seconds (-T 5) such as an active ftrace buffer.
|
|
||||||
+ dump2tar /sys -z -o "${WORKPATH}/sysfs.tgz" -x '*/tracing/trace_pipe*' \
|
|
||||||
+ -x '*/tracing/per_cpu/*' --ignore-failed-read -J 1 -T 5
|
|
||||||
|
|
||||||
- find /sys -noleaf -type d 2>/dev/null | while IFS= read -r dir_name; do
|
|
||||||
- mkdir -p "${WORKPATH}${dir_name}"
|
|
||||||
- done
|
|
||||||
+ if [ $? -ne 0 ] ; then
|
|
||||||
+ echo "${SCRIPTNAME}: Warning: dump2tar failed or is unavailable - falling back to slow path"
|
|
||||||
+ call_run_command "find /sys -print0 | sort -z | xargs -0 -n 10 ls -ld" "${OUTPUT_FILE_SYSFS}"
|
|
||||||
|
|
||||||
- find /sys -noleaf -type f -perm /444\
|
|
||||||
- -a -not -name "*trace_pipe*"\
|
|
||||||
- 2>/dev/null | while IFS= read -r file_name; do
|
|
||||||
- echo " ${file_name}"
|
|
||||||
- if ! dd if="${file_name}" status=noxfer iflag=nonblock of="${WORKPATH}${file_name}" >/dev/null 2>&1; then
|
|
||||||
- echo "${SCRIPTNAME}: Warning: failed to copy \"${file_name}\""
|
|
||||||
- fi
|
|
||||||
- done
|
|
||||||
+ find /sys -noleaf -type d 2>/dev/null | while IFS= read -r dir_name; do
|
|
||||||
+ mkdir -p "${WORKPATH}${dir_name}"
|
|
||||||
+ done
|
|
||||||
+
|
|
||||||
+ find /sys -noleaf -type f -perm /444\
|
|
||||||
+ -a -not -name "*trace_pipe*"\
|
|
||||||
+ 2>/dev/null | while IFS= read -r file_name; do
|
|
||||||
+ echo " ${file_name}"
|
|
||||||
+ if ! dd if="${file_name}" status=noxfer iflag=nonblock of="${WORKPATH}${file_name}" >/dev/null 2>&1; then
|
|
||||||
+ echo "${SCRIPTNAME}: Warning: failed to copy \"${file_name}\""
|
|
||||||
+ fi
|
|
||||||
+ done
|
|
||||||
+ fi
|
|
||||||
|
|
||||||
if test ${debugfs_mounted} -eq 1; then
|
|
||||||
umount "${MOUNT_POINT_DEBUGFS}"
|
|
@ -1,142 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 151594] dbginfo: Collect docker debug output.
|
|
||||||
From: Karsten Graul <kgraul@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: dbginfo: Collect docker debug output.
|
|
||||||
Symptom: dbginfo.sh output does not contain docker debug output.
|
|
||||||
Problem: dbginfo.sh does not collect docker debug output.
|
|
||||||
Solution: Add invocation of docker debug commands to dbginfo.sh.
|
|
||||||
Reproduction: -
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 151594
|
|
||||||
|
|
||||||
Signed-off-by: Karsten Graul <kgraul@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
scripts/dbginfo.sh | 58 +++++++++++++++++++++++++++++++++++++++++++++++++----
|
|
||||||
1 file changed, 54 insertions(+), 4 deletions(-)
|
|
||||||
|
|
||||||
--- a/scripts/dbginfo.sh
|
|
||||||
+++ b/scripts/dbginfo.sh
|
|
||||||
@@ -2,7 +2,7 @@
|
|
||||||
#
|
|
||||||
# dbginfo.sh - Tool to collect runtime, configuration, and trace information
|
|
||||||
#
|
|
||||||
-# Copyright IBM Corp. 2002, 2016
|
|
||||||
+# Copyright IBM Corp. 2002, 2017
|
|
||||||
#
|
|
||||||
|
|
||||||
# Switching to neutral locale
|
|
||||||
@@ -18,7 +18,7 @@ readonly SCRIPTNAME="${0##*/}"
|
|
||||||
print_version() {
|
|
||||||
cat <<EOF
|
|
||||||
${SCRIPTNAME}: Debug information script version %S390_TOOLS_VERSION%
|
|
||||||
-Copyright IBM Corp. 2002, 2016
|
|
||||||
+Copyright IBM Corp. 2002, 2017
|
|
||||||
EOF
|
|
||||||
}
|
|
||||||
|
|
||||||
@@ -177,11 +177,14 @@ readonly OUTPUT_FILE_OVS="${WORKPATH}ope
|
|
||||||
# File that includes the KVM domain xml file
|
|
||||||
readonly OUTPUT_FILE_XML="${WORKPATH}domain_xml"
|
|
||||||
|
|
||||||
+# File that includes the docker inspect output
|
|
||||||
+readonly OUTPUT_FILE_DOCKER="${WORKPATH}docker_inspect.out"
|
|
||||||
+
|
|
||||||
# Mount point of the debug file system
|
|
||||||
readonly MOUNT_POINT_DEBUGFS="/sys/kernel/debug"
|
|
||||||
|
|
||||||
# The amount of steps running the whole collections
|
|
||||||
-readonly COLLECTION_COUNT=10
|
|
||||||
+readonly COLLECTION_COUNT=11
|
|
||||||
|
|
||||||
# The kernel version (e.g. '2' from 2.6.32 or '3' from 3.2.1)
|
|
||||||
readonly KERNEL_VERSION=$(uname -r 2>/dev/null | cut -d'.' -f1)
|
|
||||||
@@ -301,6 +304,8 @@ LOGFILES="\
|
|
||||||
/var/log/yum.log\
|
|
||||||
/var/log/openvswitch/ovs-vswitchd.log\
|
|
||||||
/var/log/openvswitch/ovsdb-server.log\
|
|
||||||
+ /var/run/docker/libcontainerd/containerd/events.log\
|
|
||||||
+ /run/containerd/events.log\
|
|
||||||
"
|
|
||||||
|
|
||||||
########################################
|
|
||||||
@@ -351,6 +356,9 @@ CONFIGFILES="\
|
|
||||||
/etc/xinet.d\
|
|
||||||
/etc/*release\
|
|
||||||
$(find /lib/modules -name modules.dep 2>/dev/null)\
|
|
||||||
+ /etc/docker\
|
|
||||||
+ /usr/lib/systemd\
|
|
||||||
+ /etc/apparmor.d\
|
|
||||||
"
|
|
||||||
|
|
||||||
########################################
|
|
||||||
@@ -436,6 +444,16 @@ CMDS="uname -a\
|
|
||||||
:systemctl --all --no-pager show\
|
|
||||||
:systemctl --all --no-pager list-units\
|
|
||||||
:systemctl --all --no-pager list-unit-files\
|
|
||||||
+ :docker info\
|
|
||||||
+ :docker images\
|
|
||||||
+ :docker network ls\
|
|
||||||
+ :docker ps\
|
|
||||||
+ :docker ps -a\
|
|
||||||
+ :docker stats --no-stream\
|
|
||||||
+ :docker version\
|
|
||||||
+ :systemctl status docker.service\
|
|
||||||
+ :df /var/lib/docker\
|
|
||||||
+ :df --inodes /var/lib/docker\
|
|
||||||
"
|
|
||||||
|
|
||||||
########################################
|
|
||||||
@@ -767,13 +785,43 @@ collect_domain_xml() {
|
|
||||||
}
|
|
||||||
|
|
||||||
########################################
|
|
||||||
+collect_docker() {
|
|
||||||
+ local item_list
|
|
||||||
+ local item
|
|
||||||
+
|
|
||||||
+ # call docker inspect for all containers
|
|
||||||
+ item_list=$(docker ps -qa)
|
|
||||||
+ if test -n "${item_list}"; then
|
|
||||||
+ pr_syslog_stdout "10a of ${COLLECTION_COUNT}: Collecting docker container output"
|
|
||||||
+ for item in ${item_list}; do
|
|
||||||
+ call_run_command "docker inspect ${item}" "${OUTPUT_FILE_DOCKER}"
|
|
||||||
+ done
|
|
||||||
+ else
|
|
||||||
+ pr_syslog_stdout "10a of ${COLLECTION_COUNT}: Collecting docker container output skipped"
|
|
||||||
+ fi
|
|
||||||
+
|
|
||||||
+ # call docker inspect for all networks
|
|
||||||
+ item_list=$(docker network ls -q)
|
|
||||||
+ if test -n "${item_list}"; then
|
|
||||||
+ pr_syslog_stdout "10b of ${COLLECTION_COUNT}: Collecting docker network output"
|
|
||||||
+ for item in ${item_list}; do
|
|
||||||
+ call_run_command "docker network inspect ${item}" "${OUTPUT_FILE_DOCKER}"
|
|
||||||
+ done
|
|
||||||
+ else
|
|
||||||
+ pr_syslog_stdout "10b of ${COLLECTION_COUNT}: Collecting docker network output skipped"
|
|
||||||
+ fi
|
|
||||||
+
|
|
||||||
+ pr_log_stdout " "
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+########################################
|
|
||||||
post_processing() {
|
|
||||||
local file_mtime
|
|
||||||
local file_mtime_epoche
|
|
||||||
local tmp_file
|
|
||||||
local file_name
|
|
||||||
|
|
||||||
- pr_syslog_stdout "10 of ${COLLECTION_COUNT}: Postprocessing"
|
|
||||||
+ pr_syslog_stdout "11 of ${COLLECTION_COUNT}: Postprocessing"
|
|
||||||
|
|
||||||
find "${WORKPATH}etc/libvirt/qemu/" -maxdepth 1 -name "*.xml" 2>/dev/null | while IFS= read -r file_name; do
|
|
||||||
file_mtime_epoche=$(stat --format=%Y "${file_name}")
|
|
||||||
@@ -1056,6 +1104,8 @@ collect_ovs
|
|
||||||
|
|
||||||
collect_domain_xml
|
|
||||||
|
|
||||||
+collect_docker
|
|
||||||
+
|
|
||||||
post_processing
|
|
||||||
|
|
||||||
create_package
|
|
@ -1,558 +0,0 @@
|
|||||||
Subject: [PATCH] [FEAT LS1502] lsdasd/tunedasd: Add channel path aware erp
|
|
||||||
From: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Summary: lsdasd/tunedasd: Add channel path aware erp
|
|
||||||
Description: Add tools support for channel path aware error recovery.
|
|
||||||
lsdasd shows the newly added IFCC path mask and HPF availability.
|
|
||||||
tunedasd gets an option to reset channel paths for a device.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: LS1502
|
|
||||||
|
|
||||||
Signed-off-by: Stefan Haberland <sth@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
include/dasd_sys.h | 1
|
|
||||||
libdasd/dasd_sys.c | 94 +++++++++++++++++++++++++++++++++++++
|
|
||||||
tunedasd/include/disk.h | 3 -
|
|
||||||
tunedasd/man/tunedasd.8 | 17 ++++++
|
|
||||||
tunedasd/src/Makefile | 2
|
|
||||||
tunedasd/src/disk.c | 35 ++++++++++++++
|
|
||||||
tunedasd/src/tunedasd.c | 120 ++++++++++++++++++++++++++++--------------------
|
|
||||||
zconf/lsdasd | 36 +++++++++++---
|
|
||||||
8 files changed, 251 insertions(+), 57 deletions(-)
|
|
||||||
|
|
||||||
--- a/include/dasd_sys.h
|
|
||||||
+++ b/include/dasd_sys.h
|
|
||||||
@@ -13,5 +13,6 @@
|
|
||||||
#include "u2s.h"
|
|
||||||
|
|
||||||
int dasd_sys_raw_track_access(char *);
|
|
||||||
+int dasd_reset_chpid(char *, char *);
|
|
||||||
|
|
||||||
#endif /* DASD_SYS_H */
|
|
||||||
--- a/libdasd/dasd_sys.c
|
|
||||||
+++ b/libdasd/dasd_sys.c
|
|
||||||
@@ -6,6 +6,9 @@
|
|
||||||
* Copyright IBM Corp. 2016
|
|
||||||
*/
|
|
||||||
|
|
||||||
+#include <stdlib.h>
|
|
||||||
+#include <errno.h>
|
|
||||||
+
|
|
||||||
#include "dasd_sys.h"
|
|
||||||
|
|
||||||
/**
|
|
||||||
@@ -44,3 +47,94 @@ int dasd_sys_raw_track_access(char *devn
|
|
||||||
|
|
||||||
return (rc == 1) ? 1 : 0;
|
|
||||||
}
|
|
||||||
+
|
|
||||||
+
|
|
||||||
+int dasd_get_pm_from_chpid(char *busid, unsigned int chpid, int *mask)
|
|
||||||
+{
|
|
||||||
+ unsigned int val;
|
|
||||||
+ char path[40];
|
|
||||||
+ int count, i;
|
|
||||||
+ FILE *fp;
|
|
||||||
+
|
|
||||||
+ sprintf(path, "/sys/bus/ccw/devices/%s/../chpids", busid);
|
|
||||||
+ *mask = 0;
|
|
||||||
+ fp = fopen(path, "r");
|
|
||||||
+ if (!fp)
|
|
||||||
+ return ENODEV;
|
|
||||||
+
|
|
||||||
+ for (i = 0; i < 8; i++) {
|
|
||||||
+ count = fscanf(fp, " %x", &val);
|
|
||||||
+ if (count != 1) {
|
|
||||||
+ fclose(fp);
|
|
||||||
+ return EIO;
|
|
||||||
+ }
|
|
||||||
+ if (val == chpid)
|
|
||||||
+ *mask = 0x80 >> i;
|
|
||||||
+ }
|
|
||||||
+ fclose(fp);
|
|
||||||
+
|
|
||||||
+ return 0;
|
|
||||||
+}
|
|
||||||
+
|
|
||||||
+/**
|
|
||||||
+ * reset chpid
|
|
||||||
+ *
|
|
||||||
+ * The "devnode" parameter can be any valid relative or absolute path to
|
|
||||||
+ * a DASD device node, for example:
|
|
||||||
+ *
|
|
||||||
+ * - /dev/dasda
|
|
||||||
+ * - /dev/disk/by-path/ccw-0.0.bf20
|
|
||||||
+ *
|
|
||||||
+ * @param[in] devnode Device node of interest
|
|
||||||
+ * @param[in] chpid The chpid to reset
|
|
||||||
+ * If NULL all chpids will be reset
|
|
||||||
+ *
|
|
||||||
+ * @return 0 on success, otherwise one of the following error codes:
|
|
||||||
+ * - EINVAL No valid chpid specified.
|
|
||||||
+ * - ENODEV Could not open device.
|
|
||||||
+ * - ENOENT Specified chpid not found.
|
|
||||||
+ * - EIO Other I/O error
|
|
||||||
+ *
|
|
||||||
+ */
|
|
||||||
+int dasd_reset_chpid(char *devnode, char *chpid_char)
|
|
||||||
+{
|
|
||||||
+ unsigned int chpid;
|
|
||||||
+ char path[41];
|
|
||||||
+ char busid[9];
|
|
||||||
+ int mask, rc;
|
|
||||||
+ char *endptr;
|
|
||||||
+ FILE *fp;
|
|
||||||
+
|
|
||||||
+ if (u2s_getbusid(devnode, busid))
|
|
||||||
+ return ENODEV;
|
|
||||||
+
|
|
||||||
+ if (!chpid_char) {
|
|
||||||
+ sprintf(path, "/sys/bus/ccw/devices/%s/path_reset", busid);
|
|
||||||
+ fp = fopen(path, "w");
|
|
||||||
+ if (!fp)
|
|
||||||
+ return ENODEV;
|
|
||||||
+ fprintf(fp, "%s", "all\n");
|
|
||||||
+ fclose(fp);
|
|
||||||
+ return 0;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ errno = 0;
|
|
||||||
+ chpid = strtoul(chpid_char, &endptr, 16);
|
|
||||||
+ if (errno || (endptr && (*endptr != '\0')))
|
|
||||||
+ return EINVAL;
|
|
||||||
+
|
|
||||||
+ rc = dasd_get_pm_from_chpid(busid, chpid, &mask);
|
|
||||||
+ if (rc)
|
|
||||||
+ return rc;
|
|
||||||
+ if (!mask)
|
|
||||||
+ return ENOENT;
|
|
||||||
+
|
|
||||||
+ sprintf(path, "/sys/bus/ccw/devices/%s/path_reset", busid);
|
|
||||||
+ fp = fopen(path, "w");
|
|
||||||
+ if (!fp)
|
|
||||||
+ return ENODEV;
|
|
||||||
+ fprintf(fp, "%02x", mask);
|
|
||||||
+ fclose(fp);
|
|
||||||
+
|
|
||||||
+ return 0;
|
|
||||||
+}
|
|
||||||
--- a/tunedasd/include/disk.h
|
|
||||||
+++ b/tunedasd/include/disk.h
|
|
||||||
@@ -27,7 +27,8 @@ int disk_release (char* device);
|
|
||||||
int disk_slock (char* device);
|
|
||||||
int disk_query_reserve_status(char* device);
|
|
||||||
int disk_profile (char* device, char* prof_item);
|
|
||||||
-int disk_reset_prof (char* device);
|
|
||||||
+int disk_reset_prof(char *device);
|
|
||||||
+int disk_reset_chpid(char *device, char *chpid);
|
|
||||||
|
|
||||||
#endif /* not DISK_H */
|
|
||||||
|
|
||||||
--- a/tunedasd/man/tunedasd.8
|
|
||||||
+++ b/tunedasd/man/tunedasd.8
|
|
||||||
@@ -149,6 +149,18 @@ Following rows are supported:
|
|
||||||
.TP
|
|
||||||
.BR "\-R" " or " "\-\-reset_prof"
|
|
||||||
Reset profile info of device.
|
|
||||||
+.TP
|
|
||||||
+.BR "\-p" " or " "\-\-path_reset <chpid>"
|
|
||||||
+Reset a channel path <chpid> of a selected device. A channel path
|
|
||||||
+might be suspended due to high IFCC error rates or a High Performance
|
|
||||||
+FICON failure. Use this option to resume considering the channel path
|
|
||||||
+for I/O.
|
|
||||||
+.TP
|
|
||||||
+.BR "\-\-path_reset_all"
|
|
||||||
+Reset all channel paths of the selected device. The channel paths
|
|
||||||
+might be suspended due to high IFCC error rates or a High Performance
|
|
||||||
+FICON failure. Use this option to resume considering all defined
|
|
||||||
+channel paths for I/O.
|
|
||||||
.\"
|
|
||||||
.\".TP
|
|
||||||
.\".BR "\-o" " or " "\-\-online"
|
|
||||||
@@ -166,8 +178,13 @@ Reset profile info of device.
|
|
||||||
.br
|
|
||||||
|
|
||||||
tunedasd -c prestage -n 1 /dev/dasdc
|
|
||||||
+
|
|
||||||
+.br
|
|
||||||
+3. Scenario: Reset failed channel path with CHPID 45
|
|
||||||
.br
|
|
||||||
|
|
||||||
+ tunedasd -p 45 /dev/dasdc
|
|
||||||
+.br
|
|
||||||
.SH "SEE ALSO"
|
|
||||||
.BR dasdview (8),
|
|
||||||
.BR dasdfmt (8),
|
|
||||||
--- a/tunedasd/src/Makefile
|
|
||||||
+++ b/tunedasd/src/Makefile
|
|
||||||
@@ -5,7 +5,7 @@ includes = $(wildcard ../include/*.h)
|
|
||||||
|
|
||||||
all: tunedasd
|
|
||||||
|
|
||||||
-objects = tunedasd.o disk.o
|
|
||||||
+objects = tunedasd.o disk.o ../../libdasd/dasd_sys.o ../../libu2s/u2s.o
|
|
||||||
$(objects): $(includes)
|
|
||||||
|
|
||||||
tunedasd: $(objects)
|
|
||||||
--- a/tunedasd/src/disk.c
|
|
||||||
+++ b/tunedasd/src/disk.c
|
|
||||||
@@ -9,6 +9,7 @@
|
|
||||||
|
|
||||||
#include "disk.h"
|
|
||||||
#include "tunedasd.h"
|
|
||||||
+#include "dasd_sys.h"
|
|
||||||
|
|
||||||
#include <sys/types.h>
|
|
||||||
#include <sys/ioctl.h>
|
|
||||||
@@ -682,3 +683,37 @@ disk_reset_prof (char* device)
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
+int disk_reset_chpid(char *device, char *chpid)
|
|
||||||
+{
|
|
||||||
+ int rc;
|
|
||||||
+
|
|
||||||
+ if (chpid)
|
|
||||||
+ printf("Resetting chpid %s for device <%s>...\n", chpid,
|
|
||||||
+ device);
|
|
||||||
+ else
|
|
||||||
+ printf("Resetting all chpids for device <%s>...\n", device);
|
|
||||||
+
|
|
||||||
+ rc = dasd_reset_chpid(device, chpid);
|
|
||||||
+ switch (rc) {
|
|
||||||
+ case 0:
|
|
||||||
+ printf("Done.\n");
|
|
||||||
+ return 0;
|
|
||||||
+ case ENODEV:
|
|
||||||
+ error_print("%s: %s", device, strerror(errno));
|
|
||||||
+ break;
|
|
||||||
+ case EINVAL:
|
|
||||||
+ error_print("%s: Could not reset chpid %s: Invalid CHPID",
|
|
||||||
+ device, chpid);
|
|
||||||
+ break;
|
|
||||||
+ case ENOENT:
|
|
||||||
+ error_print("%s: Could not reset chpid %s: CHPID not defined for device",
|
|
||||||
+ device, chpid);
|
|
||||||
+ break;
|
|
||||||
+ default:
|
|
||||||
+ error_print("%s: Could not reset chpid %s",
|
|
||||||
+ device, chpid);
|
|
||||||
+ break;
|
|
||||||
+ }
|
|
||||||
+
|
|
||||||
+ return -1;
|
|
||||||
+}
|
|
||||||
--- a/tunedasd/src/tunedasd.c
|
|
||||||
+++ b/tunedasd/src/tunedasd.c
|
|
||||||
@@ -34,28 +34,30 @@ static const char* usage_text[] = {
|
|
||||||
"(e.g. '/dev/dasda') or a list of devices separated by a space "
|
|
||||||
"character.",
|
|
||||||
"",
|
|
||||||
- "-h, --help Print this help, then exit",
|
|
||||||
- "-v, --version Print version information, then exit",
|
|
||||||
- "-g, --get_cache Get current storage server caching behaviour",
|
|
||||||
- "-c, --cache <behavior> Define caching behavior on storage server",
|
|
||||||
- " (normal/bypass/inhibit/sequential/prestage/"
|
|
||||||
- "record)",
|
|
||||||
- "-n, --no_cyl <n> Number of cylinders to be cached ",
|
|
||||||
- " (only valid together with --cache)",
|
|
||||||
- "-S, --reserve Reserve device",
|
|
||||||
- "-L, --release Release device",
|
|
||||||
- "-O, --slock Unconditional reserve device",
|
|
||||||
- " Note: Use with care, this breaks an existing "
|
|
||||||
- "lock",
|
|
||||||
- "-Q, --query_reserve Print reserve status of device ",
|
|
||||||
- "-P, --profile Print profile info of device",
|
|
||||||
- "-I, --prof_item Print single profile item",
|
|
||||||
- " (reqs/sects/sizes/total/totsect/start/irq/",
|
|
||||||
- " irqsect/end/queue)",
|
|
||||||
- "-R, --reset_prof Reset profile info of device"
|
|
||||||
+ "-h, --help Print this help, then exit",
|
|
||||||
+ "-v, --version Print version information, then exit",
|
|
||||||
+ "-g, --get_cache Get current storage server caching behaviour",
|
|
||||||
+ "-c, --cache <behavior> Define caching behavior on storage server",
|
|
||||||
+ " (normal/bypass/inhibit/sequential/prestage/"
|
|
||||||
+ "record)",
|
|
||||||
+ "-n, --no_cyl <n> Number of cylinders to be cached ",
|
|
||||||
+ " (only valid together with --cache)",
|
|
||||||
+ "-S, --reserve Reserve device",
|
|
||||||
+ "-L, --release Release device",
|
|
||||||
+ "-O, --slock Unconditional reserve device",
|
|
||||||
+ " Note: Use with care, this breaks an existing "
|
|
||||||
+ "lock",
|
|
||||||
+ "-Q, --query_reserve Print reserve status of device ",
|
|
||||||
+ "-P, --profile Print profile info of device",
|
|
||||||
+ "-I, --prof_item Print single profile item",
|
|
||||||
+ " (reqs/sects/sizes/total/totsect/start/irq/",
|
|
||||||
+ " irqsect/end/queue)",
|
|
||||||
+ "-R, --reset_prof Reset profile info of device",
|
|
||||||
+ "-p, --path_reset <chpid> Reset channel path <chpid> of a device",
|
|
||||||
+ " --path_reset_all Reset all channel paths of a device"
|
|
||||||
};
|
|
||||||
|
|
||||||
-#define CMD_KEYWORD_NUM 12
|
|
||||||
+#define CMD_KEYWORD_NUM 14
|
|
||||||
#define DEVICES_NUM 256
|
|
||||||
|
|
||||||
enum cmd_keyword_id {
|
|
||||||
@@ -71,6 +73,8 @@ enum cmd_keyword_id {
|
|
||||||
cmd_keyword_prof_item = 9,
|
|
||||||
cmd_keyword_reset_prof = 10,
|
|
||||||
cmd_keyword_query_reserve = 11,
|
|
||||||
+ cmd_keyword_path = 12,
|
|
||||||
+ cmd_keyword_path_all = 13,
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
@@ -79,18 +83,20 @@ static const struct {
|
|
||||||
char* keyword;
|
|
||||||
enum cmd_keyword_id id;
|
|
||||||
} keyword_list[] = {
|
|
||||||
- { "help", cmd_keyword_help },
|
|
||||||
- { "version", cmd_keyword_version },
|
|
||||||
- { "get_cache", cmd_keyword_get_cache },
|
|
||||||
- { "cache", cmd_keyword_cache },
|
|
||||||
- { "no_cyl", cmd_keyword_no_cyl },
|
|
||||||
- { "reserve", cmd_keyword_reserve },
|
|
||||||
- { "release", cmd_keyword_release },
|
|
||||||
- { "slock", cmd_keyword_slock },
|
|
||||||
- { "profile", cmd_keyword_profile },
|
|
||||||
- { "prof_item", cmd_keyword_prof_item },
|
|
||||||
- { "reset_prof", cmd_keyword_reset_prof },
|
|
||||||
- { "query_reserve", cmd_keyword_query_reserve }
|
|
||||||
+ { "help", cmd_keyword_help },
|
|
||||||
+ { "version", cmd_keyword_version },
|
|
||||||
+ { "get_cache", cmd_keyword_get_cache },
|
|
||||||
+ { "cache", cmd_keyword_cache },
|
|
||||||
+ { "no_cyl", cmd_keyword_no_cyl },
|
|
||||||
+ { "reserve", cmd_keyword_reserve },
|
|
||||||
+ { "release", cmd_keyword_release },
|
|
||||||
+ { "slock", cmd_keyword_slock },
|
|
||||||
+ { "profile", cmd_keyword_profile },
|
|
||||||
+ { "prof_item", cmd_keyword_prof_item },
|
|
||||||
+ { "reset_prof", cmd_keyword_reset_prof },
|
|
||||||
+ { "query_reserve", cmd_keyword_query_reserve },
|
|
||||||
+ { "path_reset", cmd_keyword_path },
|
|
||||||
+ { "path_reset_all", cmd_keyword_path_all }
|
|
||||||
};
|
|
||||||
|
|
||||||
|
|
||||||
@@ -103,22 +109,24 @@ enum cmd_key_state {
|
|
||||||
|
|
||||||
/* Determines which combination of keywords are valid */
|
|
||||||
enum cmd_key_state cmd_key_table[CMD_KEYWORD_NUM][CMD_KEYWORD_NUM] = {
|
|
||||||
- /* help vers get_ cach no_c rese rele sloc prof prof rese quer
|
|
||||||
- * ion cach e yl rve ase k ile _ite t_pr y_re
|
|
||||||
+ /* help vers get_ cach no_c rese rele sloc prof prof rese quer path path
|
|
||||||
+ * ion cach e yl rve ase k ile _ite t_pr y_re _all
|
|
||||||
* e m of serv
|
|
||||||
*/
|
|
||||||
- /* help */ { req, opt, opt, opt, opt, opt, opt, opt, opt, opt, opt, inv },
|
|
||||||
- /* version */ { inv, req, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
- /* get_cache */ { opt, opt, req, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
- /* cache */ { opt, opt, inv, req, opt, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
- /* no_cyl */ { opt, opt, inv, req, req, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
- /* reserve */ { opt, opt, inv, inv, inv, req, inv, inv, inv, inv, inv, inv },
|
|
||||||
- /* release */ { opt, opt, inv, inv, inv, inv, req, inv, inv, inv, inv, inv },
|
|
||||||
- /* slock */ { opt, opt, inv, inv, inv, inv, inv, req, inv, inv, inv, inv },
|
|
||||||
- /* profile */ { opt, opt, inv, inv, inv, inv, inv, inv, req, opt, inv, inv },
|
|
||||||
- /* prof_item */ { opt, opt, inv, inv, inv, inv, inv, inv, req, req, inv, inv },
|
|
||||||
- /* reset_prof */ { opt, opt, inv, inv, inv, inv, inv, inv, inv, inv, req, inv },
|
|
||||||
- /* query_reserve */ { inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, req },
|
|
||||||
+ /* help */ { req, opt, opt, opt, opt, opt, opt, opt, opt, opt, opt, inv, inv, inv },
|
|
||||||
+ /* version */ { inv, req, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* get_cache */ { opt, opt, req, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* cache */ { opt, opt, inv, req, opt, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* no_cyl */ { opt, opt, inv, req, req, inv, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* reserve */ { opt, opt, inv, inv, inv, req, inv, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* release */ { opt, opt, inv, inv, inv, inv, req, inv, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* slock */ { opt, opt, inv, inv, inv, inv, inv, req, inv, inv, inv, inv, inv, inv },
|
|
||||||
+ /* profile */ { opt, opt, inv, inv, inv, inv, inv, inv, req, opt, inv, inv, inv, inv },
|
|
||||||
+ /* prof_item */ { opt, opt, inv, inv, inv, inv, inv, inv, req, req, inv, inv, inv, inv },
|
|
||||||
+ /* reset_prof */ { opt, opt, inv, inv, inv, inv, inv, inv, inv, inv, req, inv, inv, inv },
|
|
||||||
+ /* query_reserve */ { inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, req, inv, inv },
|
|
||||||
+ /* path */ { inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, req, inv },
|
|
||||||
+ /* path_all */ { inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, inv, req },
|
|
||||||
};
|
|
||||||
|
|
||||||
struct parameter {
|
|
||||||
@@ -146,11 +154,13 @@ static struct option options[] = {
|
|
||||||
{ "prof_item", required_argument, NULL, 'I'},
|
|
||||||
{ "reset_prof", no_argument, NULL, 'R'},
|
|
||||||
{ "query_reserve", no_argument, NULL, 'Q'},
|
|
||||||
+ { "path_reset", required_argument, NULL, 'p'},
|
|
||||||
+ { "path_reset_all", no_argument, NULL, 'A'},
|
|
||||||
{ NULL, 0, NULL, 0 }
|
|
||||||
};
|
|
||||||
|
|
||||||
/* Command line option abbreviations */
|
|
||||||
-static const char option_string[] = "hvgc:n:SLOPI:RQ";
|
|
||||||
+static const char option_string[] = "hvgc:n:SLOPI:RQp:";
|
|
||||||
|
|
||||||
|
|
||||||
/* Error message string */
|
|
||||||
@@ -348,6 +358,14 @@ get_command_line (int argc, char* argv[]
|
|
||||||
optarg);
|
|
||||||
}
|
|
||||||
break;
|
|
||||||
+ case 'p':
|
|
||||||
+ rc = store_option(&cmdline, cmd_keyword_path,
|
|
||||||
+ optarg);
|
|
||||||
+ break;
|
|
||||||
+ case 'A':
|
|
||||||
+ rc = store_option(&cmdline, cmd_keyword_path_all,
|
|
||||||
+ optarg);
|
|
||||||
+ break;
|
|
||||||
case 'S':
|
|
||||||
rc = store_option (&cmdline, cmd_keyword_reserve,
|
|
||||||
optarg);
|
|
||||||
@@ -400,7 +418,6 @@ get_command_line (int argc, char* argv[]
|
|
||||||
return 0;
|
|
||||||
}
|
|
||||||
|
|
||||||
-
|
|
||||||
/*
|
|
||||||
* Execute the command.
|
|
||||||
*/
|
|
||||||
@@ -444,6 +461,13 @@ do_command (char* device, struct command
|
|
||||||
case cmd_keyword_query_reserve:
|
|
||||||
rc = disk_query_reserve_status(device);
|
|
||||||
break;
|
|
||||||
+ case cmd_keyword_path:
|
|
||||||
+ rc = disk_reset_chpid(device,
|
|
||||||
+ cmdline.parm[cmd_keyword_path].data);
|
|
||||||
+ break;
|
|
||||||
+ case cmd_keyword_path_all:
|
|
||||||
+ rc = disk_reset_chpid(device, NULL);
|
|
||||||
+ break;
|
|
||||||
default:
|
|
||||||
error_print ("Unknown command '%s' specified",
|
|
||||||
get_keyword_name (i));
|
|
||||||
--- a/zconf/lsdasd
|
|
||||||
+++ b/zconf/lsdasd
|
|
||||||
@@ -368,13 +368,15 @@ function extended()
|
|
||||||
CABLEPM=0
|
|
||||||
CUIRPM=0
|
|
||||||
HPFPM=0
|
|
||||||
+ IFCCPM=0
|
|
||||||
|
|
||||||
# additional information
|
|
||||||
read DIAG 2> /dev/null < $DEVPATH/use_diag || continue
|
|
||||||
read EER 2> /dev/null < $DEVPATH/eer_enabled || continue
|
|
||||||
read ERP 2> /dev/null < $DEVPATH/erplog || continue
|
|
||||||
+ read HPF 2> /dev/null < $DEVPATH/hpf
|
|
||||||
# in case the path_masks do not exist simply ignore it
|
|
||||||
- read OPM NPPM CABLEPM CUIRPM HPFPM 2> /dev/null < $DEVPATH/path_masks
|
|
||||||
+ read OPM NPPM CABLEPM CUIRPM HPFPM IFCCPM 2> /dev/null < $DEVPATH/path_masks
|
|
||||||
read -a C 2> /dev/null < $DEVPATH/../chpids || continue
|
|
||||||
read PIM PAM POM 2> /dev/null < $DEVPATH/../pimpampom || continue
|
|
||||||
|
|
||||||
@@ -385,6 +387,7 @@ function extended()
|
|
||||||
CABLEPM=0x$CABLEPM
|
|
||||||
CUIRPM=0x$CUIRPM
|
|
||||||
HPFPM=0x$HPFPM
|
|
||||||
+ IFCCPM=0x$IFCCPM
|
|
||||||
|
|
||||||
#-----------------------------------------------------------#
|
|
||||||
# aggregate chpids and path mask to useful information #
|
|
||||||
@@ -397,6 +400,7 @@ function extended()
|
|
||||||
CUIR_PATHS=(" " " " " " " " " " " " " " " ")
|
|
||||||
CABLE_PATHS=(" " " " " " " " " " " " " " " ")
|
|
||||||
HPF_PATHS=(" " " " " " " " " " " " " " " ")
|
|
||||||
+ IFCC_PATHS=(" " " " " " " " " " " " " " " ")
|
|
||||||
|
|
||||||
# installed paths
|
|
||||||
j=0
|
|
||||||
@@ -470,13 +474,25 @@ function extended()
|
|
||||||
(( mask>>=1 ))
|
|
||||||
done
|
|
||||||
|
|
||||||
+ # IFCC unusable paths
|
|
||||||
+ j=0
|
|
||||||
+ mask=0x80
|
|
||||||
+ for (( i=0; i<8; i++ )) ;do
|
|
||||||
+ PM=$(($IFCCPM&$mask))
|
|
||||||
+ if [ $PM -gt 0 ] ;then
|
|
||||||
+ IFCC_PATHS[j]=${C[$i]} ;
|
|
||||||
+ ((j++)) ;
|
|
||||||
+ fi
|
|
||||||
+ (( mask>>=1 ))
|
|
||||||
+ done
|
|
||||||
+
|
|
||||||
#-------------------------------------------#
|
|
||||||
# format data for output #
|
|
||||||
#-------------------------------------------#
|
|
||||||
|
|
||||||
if [[ "$ONLINE" == 0 ]]; then
|
|
||||||
ACTIVE="offline"
|
|
||||||
- printf "%s:%s:%s# status:\t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s# uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
+ printf "%s:%s:%s# status:\t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s# hpf:\t\t\t\t\t%s# uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s# paths_error_threshold_exceeded: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
"$SORTKEYLEN" "$SORTKEY" \
|
|
||||||
"$BUSID" \
|
|
||||||
"$ACTIVE" \
|
|
||||||
@@ -484,18 +500,20 @@ function extended()
|
|
||||||
"$READONLY" \
|
|
||||||
"$EER" \
|
|
||||||
"$ERP" \
|
|
||||||
+ "$HPF" \
|
|
||||||
"$DEV_UID" \
|
|
||||||
"${INSTALLED_PATHS[@]}" \
|
|
||||||
"${USED_PATHS[@]}" \
|
|
||||||
"${NP_PATHS[@]}" \
|
|
||||||
"${CABLE_PATHS[@]}" \
|
|
||||||
"${CUIR_PATHS[@]}" \
|
|
||||||
- "${HPF_PATHS[@]}" ;
|
|
||||||
+ "${HPF_PATHS[@]}" \
|
|
||||||
+ "${IFCC_PATHS[@]}" ;
|
|
||||||
continue
|
|
||||||
elif [[ "$ALIAS" == 1 ]]; then
|
|
||||||
if [[ "$BASEONLY" == "false" ]]; then
|
|
||||||
ACTIVE="alias"
|
|
||||||
- printf "%s:%s:%s# status:\t\t\t\t%s# type: \t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s # uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
+ printf "%s:%s:%s# status:\t\t\t\t%s# type: \t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s# hpf:\t\t\t\t\t%s # uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s# paths_error_threshold_exceeded: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
"$SORTKEYLEN" "$SORTKEY" \
|
|
||||||
"$BUSID" \
|
|
||||||
"$ACTIVE" \
|
|
||||||
@@ -504,13 +522,15 @@ function extended()
|
|
||||||
"$READONLY" \
|
|
||||||
"$EER" \
|
|
||||||
"$ERP" \
|
|
||||||
+ "$HPF" \
|
|
||||||
"$DEV_UID" \
|
|
||||||
"${INSTALLED_PATHS[@]}" \
|
|
||||||
"${USED_PATHS[@]}" \
|
|
||||||
"${NP_PATHS[@]}" \
|
|
||||||
"${CABLE_PATHS[@]}" \
|
|
||||||
"${CUIR_PATHS[@]}" \
|
|
||||||
- "${HPF_PATHS[@]}" ;
|
|
||||||
+ "${HPF_PATHS[@]}" \
|
|
||||||
+ "${IFCC_PATHS[@]}" ;
|
|
||||||
continue
|
|
||||||
else
|
|
||||||
continue
|
|
||||||
@@ -533,7 +553,7 @@ function extended()
|
|
||||||
COLON=":"
|
|
||||||
fi
|
|
||||||
|
|
||||||
- printf "%s:%s:%s/%s/%s%s%s# status:\t\t\t\t%s# type: \t\t\t\t%s# blksz:\t\t\t\t%s# size: \t\t\t\t%s# blocks:\t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s# uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
+ printf "%s:%s:%s/%s/%s%s%s# status:\t\t\t\t%s# type: \t\t\t\t%s# blksz:\t\t\t\t%s# size: \t\t\t\t%s# blocks:\t\t\t\t%s# use_diag:\t\t\t\t%s# readonly:\t\t\t\t%s# eer_enabled:\t\t\t\t%s# erplog:\t\t\t\t%s# hpf:\t\t\t\t\t%s# uid: \t\t\t\t%s# paths_installed: \t\t\t%s %s %s %s %s %s %s %s# paths_in_use: \t\t\t%s %s %s %s %s %s %s %s# paths_non_preferred: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_cabling: \t\t%s %s %s %s %s %s %s %s# paths_cuir_quiesced: \t\t\t%s %s %s %s %s %s %s %s# paths_invalid_hpf_characteristics: \t%s %s %s %s %s %s %s %s# paths_error_threshold_exceeded: \t%s %s %s %s %s %s %s %s#\n" \
|
|
||||||
"$SORTKEYLEN" "$SORTKEY" \
|
|
||||||
"$BUSID" \
|
|
||||||
"$BLOCKNAME" \
|
|
||||||
@@ -549,13 +569,15 @@ function extended()
|
|
||||||
"$READONLY" \
|
|
||||||
"$EER" \
|
|
||||||
"$ERP" \
|
|
||||||
+ "$HPF" \
|
|
||||||
"$DEV_UID" \
|
|
||||||
"${INSTALLED_PATHS[@]}" \
|
|
||||||
"${USED_PATHS[@]}" \
|
|
||||||
"${NP_PATHS[@]}" \
|
|
||||||
"${CABLE_PATHS[@]}" \
|
|
||||||
"${CUIR_PATHS[@]}" \
|
|
||||||
- "${HPF_PATHS[@]}" ;
|
|
||||||
+ "${HPF_PATHS[@]}" \
|
|
||||||
+ "${IFCC_PATHS[@]}" ;
|
|
||||||
}
|
|
||||||
|
|
||||||
function host()
|
|
@ -1,65 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 151416] mon_fsstatd: fix double free in error path and skip virtual fs
|
|
||||||
From: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
|
||||||
|
|
||||||
Description: mon_fsstatd: fix double free in error path and skip virtual fs
|
|
||||||
Symptom: The daemon is stopped and the following messages can be found
|
|
||||||
in syslog: "statvfs error on /run/user/0: Permission denied"
|
|
||||||
and "double free or corruption (!prev)".
|
|
||||||
Problem: The error handling code for a failing statvfs() call erroneously
|
|
||||||
does an extra fclose(), conflicting with the later fclose().
|
|
||||||
Also, breaking out of the inner loop at this point doesn't make
|
|
||||||
sense, because there may be other mounted filesystems that would
|
|
||||||
be skipped.
|
|
||||||
The reason for the failing statvfs() (on /run/user/0) is a wrong
|
|
||||||
selinux context (when started via systemctl), and this error will
|
|
||||||
spam the syslog if we only fix the double free. Since /run/user/0
|
|
||||||
is a tmpfs, and mon_fsstatd is supposed to collect only physical
|
|
||||||
filesystem data, it is wrong to even try to access /run/user/0.
|
|
||||||
Solution: Remove the extra fclose(), replace the break with a continue,
|
|
||||||
and add tmpfs (and others) to the list of ignored virtual
|
|
||||||
filesystems.
|
|
||||||
Reproduction: Start mon_fsstatd via service/systemctl.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 151416
|
|
||||||
|
|
||||||
Signed-off-by: Gerald Schaefer <gerald.schaefer@de.ibm.com>
|
|
||||||
---
|
|
||||||
mon_tools/mon_fsstatd.c | 19 +++++++++++++++++--
|
|
||||||
1 file changed, 17 insertions(+), 2 deletions(-)
|
|
||||||
|
|
||||||
--- a/mon_tools/mon_fsstatd.c
|
|
||||||
+++ b/mon_tools/mon_fsstatd.c
|
|
||||||
@@ -323,16 +323,31 @@ static int fsstatd_do_work(void)
|
|
||||||
strncmp(ent->mnt_type, "none", 4) == 0 ||
|
|
||||||
strncmp(ent->mnt_type, "proc", 4) == 0 ||
|
|
||||||
strncmp(ent->mnt_type, "subfs", 5) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "nfsd", 4) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "tmpfs", 5) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "sysfs", 5) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "pstore", 6) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "cgroup", 6) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "mqueue", 6) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "devpts", 6) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "debugfs", 7) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "devtmpfs", 8) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "configfs", 8) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "selinuxfs", 9) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "hugetlbfs", 9) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "securityfs", 10) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "rpc_pipefs", 10) == 0 ||
|
|
||||||
+ strncmp(ent->mnt_type, "binfmt_misc", 11) == 0 ||
|
|
||||||
strncmp(ent->mnt_type, "ignore", 6) == 0)) {
|
|
||||||
ent = getmntent(mnttab);
|
|
||||||
continue;
|
|
||||||
}
|
|
||||||
result = statvfs(ent->mnt_dir, &buf);
|
|
||||||
if (result != 0) {
|
|
||||||
- fclose(mnttab);
|
|
||||||
syslog(LOG_ERR, "statvfs error on %s: %s\n",
|
|
||||||
ent->mnt_dir, strerror(errno));
|
|
||||||
- break;
|
|
||||||
+ ent = getmntent(mnttab);
|
|
||||||
+ continue;
|
|
||||||
}
|
|
||||||
|
|
||||||
if (buf.f_blocks > 0)
|
|
@ -1,30 +0,0 @@
|
|||||||
util_proc: Fix memory allocation error messages
|
|
||||||
|
|
||||||
Signed-off-by: Michael Holzheu <holzheu@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
libutil/util_proc.c | 7 +++----
|
|
||||||
1 file changed, 3 insertions(+), 4 deletions(-)
|
|
||||||
|
|
||||||
--- a/libutil/util_proc.c
|
|
||||||
+++ b/libutil/util_proc.c
|
|
||||||
@@ -54,8 +54,7 @@ util_proc_read_special_file(const char *
|
|
||||||
count = 0;
|
|
||||||
data = (char *) malloc(current_size);
|
|
||||||
if (data == NULL) {
|
|
||||||
- printf("Could not allocate %lld bytes of memory",
|
|
||||||
- (unsigned long long) size);
|
|
||||||
+ printf("Could not allocate %zu bytes of memory", current_size);
|
|
||||||
fclose(file);
|
|
||||||
return -1;
|
|
||||||
}
|
|
||||||
@@ -69,8 +68,8 @@ util_proc_read_special_file(const char *
|
|
||||||
if (count >= current_size) {
|
|
||||||
new_data = (char *) malloc(current_size * 2);
|
|
||||||
if (new_data == NULL) {
|
|
||||||
- printf("Could not allocate %lld bytes of memory",
|
|
||||||
- (unsigned long long) size);
|
|
||||||
+ printf("Could not allocate %zu bytes of memory",
|
|
||||||
+ current_size * 2);
|
|
||||||
free(data);
|
|
||||||
fclose(file);
|
|
||||||
return -1;
|
|
@ -1,144 +0,0 @@
|
|||||||
Subject: [PATCH] [BZ 149058] ziomon: no blktrace kill which can corrupt kernel blktrace state
|
|
||||||
From: Steffen Maier <maier@linux.vnet.ibm.com>
|
|
||||||
|
|
||||||
Description: ziomon: no blktrace kill which can corrupt kernel blktrace state
|
|
||||||
Symptom: Ziomon terminates with the following error messages:
|
|
||||||
|
|
||||||
$ ziomon -d <duration> -o <logfile> <device>...
|
|
||||||
...
|
|
||||||
ziomon: Failed to stop trace on /dev/sdX
|
|
||||||
...
|
|
||||||
ziomon: Failed to stop trace on /dev/sdY
|
|
||||||
ziomon: blktrace has leftovers, manual cleanup required!
|
|
||||||
|
|
||||||
Subsequent ziomon runs fail likely until the next reboot:
|
|
||||||
|
|
||||||
$ ziomon -d <duration> -o <logfile> <device>...
|
|
||||||
...
|
|
||||||
Collecting data...BLKTRACESETUP(2) /dev/sdX failed: \
|
|
||||||
2/No such file or directory
|
|
||||||
BLKTRACESETUP(2) /dev/sdY failed: 2/No such file or directory
|
|
||||||
...
|
|
||||||
Thread Z failed open /sys/kernel/debug/block/(null)/traceZ: \
|
|
||||||
2/No such file or directory
|
|
||||||
FAILED to start thread on CPU 0: 1/Operation not permitted
|
|
||||||
...
|
|
||||||
Error: blktrace has errors, aborting
|
|
||||||
...
|
|
||||||
ziomon: Failed to stop trace on /dev/sdX
|
|
||||||
...
|
|
||||||
ziomon: Failed to stop trace on /dev/sdY
|
|
||||||
ziomon: blktrace has leftovers, manual cleanup required!
|
|
||||||
Problem: While we call blktrace with stopwatch option '-w $WRP_DURATION'
|
|
||||||
to have itself terminate automatically after the (mandatory)
|
|
||||||
sampling duration, there might be a race
|
|
||||||
with our own timed blktrace checking loop between "Collecting
|
|
||||||
data..." and "done"
|
|
||||||
or any of SIGHUP SIGTERM SIGINT SIGQUIT from the user might
|
|
||||||
prematurely trigger emergency_shutdown(),
|
|
||||||
so blktrace might still be running or not have completed its
|
|
||||||
cleanup when we reach the blktrace leftover checks in shutdown().
|
|
||||||
|
|
||||||
In that case, ziomon uses the meanwhile hidden kill option of
|
|
||||||
blktrace which can corrupt kernel state if blktrace user space
|
|
||||||
has not yet completed its regular cleanup.
|
|
||||||
Solution: The correct way to have the blktrace process terminate and
|
|
||||||
cleanup properly including any dependent kernel state, before
|
|
||||||
blktrace's stopwatch makes it terminate and cleanup
|
|
||||||
automatically, is to only send SIGINT to it.
|
|
||||||
|
|
||||||
http://git.kernel.org/cgit/linux/kernel/git/axboe/blktrace.git
|
|
||||||
86596c7579c6 ("blktrace: remove -k from manpage synopsis")
|
|
||||||
fb7f86674a51 ("blktrace: disable kill option - take 2")
|
|
||||||
Additional explanation for blktrace -k:
|
|
||||||
http://marc.info/?l=linux-btrace&m=131245973528087&w=2i
|
|
||||||
linux-btrace ("Re: Recent changes")
|
|
||||||
The following kernel commits do not change above termination
|
|
||||||
statement:
|
|
||||||
http://git.kernel.org/cgit/linux/kernel/git/torvalds/linux.git
|
|
||||||
39cbb602b543 ("Remove double removal of blktrace directory")
|
|
||||||
fd51d251e4cd ("blktrace: remove debugfs entries on bad path")
|
|
||||||
f48fc4d32e24
|
|
||||||
("block: get rid of the manual directory counting in blktrace")
|
|
||||||
|
|
||||||
As of this writing, the (multithreaded) blktrace also wires
|
|
||||||
SIGHUP SIGTERM SIGALRM with the same signal handler
|
|
||||||
handle_sigint(), but to adhere to its documentation move from
|
|
||||||
SIGTERM to SIGINT anyway.
|
|
||||||
|
|
||||||
We must not use the meanwhile hidden kill option of blktrace
|
|
||||||
because this corrupts kernel state if blktrace user space has not
|
|
||||||
yet completed its regular cleanup.
|
|
||||||
|
|
||||||
In order to avoid zombies we wait for all children. After all, we
|
|
||||||
want everything to be completed before ziomon terminates and the
|
|
||||||
user could safely run another instance of ziomon. Also, we get
|
|
||||||
the possibility for users to detect and report issues with
|
|
||||||
children that don't finish timely.
|
|
||||||
|
|
||||||
Since we do not know how to manually cleanup, drop the check for
|
|
||||||
blktrace leftovers in shutdown().
|
|
||||||
Reproduction: Run ziomon with many devices on the command line.
|
|
||||||
Possibly (other) load on the system increases probability.
|
|
||||||
Upstream-ID: -
|
|
||||||
Problem-ID: 149058
|
|
||||||
|
|
||||||
Signed-off-by: Steffen Maier <maier@linux.vnet.ibm.com>
|
|
||||||
---
|
|
||||||
ziomon/ziomon | 17 ++++++-----------
|
|
||||||
1 file changed, 6 insertions(+), 11 deletions(-)
|
|
||||||
|
|
||||||
--- a/ziomon/ziomon
|
|
||||||
+++ b/ziomon/ziomon
|
|
||||||
@@ -5,7 +5,7 @@
|
|
||||||
#
|
|
||||||
# Wrapper script to start all processes
|
|
||||||
#
|
|
||||||
-# Copyright IBM Corp. 2008
|
|
||||||
+# Copyright IBM Corp. 2008, 2016
|
|
||||||
#
|
|
||||||
# Author(s): Stefan Raspl <raspl@linux.vnet.ibm.com>
|
|
||||||
#
|
|
||||||
@@ -84,7 +84,7 @@ function check_for_int() {
|
|
||||||
|
|
||||||
function print_version() {
|
|
||||||
echo "$WRP_TOOLNAME: I/O data collection utility, version %S390_TOOLS_VERSION%";
|
|
||||||
- echo "Copyright IBM Corp. 2008";
|
|
||||||
+ echo "Copyright IBM Corp. 2008, 2016";
|
|
||||||
}
|
|
||||||
|
|
||||||
|
|
||||||
@@ -356,8 +356,6 @@ function start_trace() {
|
|
||||||
|
|
||||||
|
|
||||||
function shutdown() {
|
|
||||||
- local failed=0;
|
|
||||||
-
|
|
||||||
echo "Shutting down";
|
|
||||||
# one more second to write final result
|
|
||||||
sleep 2;
|
|
||||||
@@ -365,7 +363,7 @@ function shutdown() {
|
|
||||||
[ -d /proc/$WRP_ZIOMON_UTIL_PID ] && echo "Shutting down utilization process" && kill -s SIGTERM $WRP_ZIOMON_UTIL_PID;
|
|
||||||
fi
|
|
||||||
if [ "$WRP_BLKTRACE_PID" != "" ]; then
|
|
||||||
- [ -d /proc/$WRP_BLKTRACE_PID ] && echo "Shutting down blktrace process" && kill -s SIGTERM $WRP_BLKTRACE_PID;
|
|
||||||
+ [ -d /proc/$WRP_BLKTRACE_PID ] && echo "Shutting down blktrace process" && kill -s SIGINT $WRP_BLKTRACE_PID;
|
|
||||||
fi
|
|
||||||
if [ "$WRP_BLKIOMON_PID" != "" ]; then
|
|
||||||
[ -d /proc/$WRP_BLKIOMON_PID ] && echo "Shutting down blkiomon process" && kill -s SIGTERM $WRP_BLKIOMON_PID;
|
|
||||||
@@ -381,12 +379,9 @@ function shutdown() {
|
|
||||||
kill -s SIGTERM $WRP_ZIOMON_MGR_PID;
|
|
||||||
fi
|
|
||||||
fi
|
|
||||||
- # kill running traces on devices
|
|
||||||
- for dev in ${WRP_DEVICES[@]}; do
|
|
||||||
- [ -d /sys/kernel/debug/block/${dev##*/} ] && debug "Trace on $dev exists, attempt to kill..." && blktrace -k $dev >/dev/null 2>&1;
|
|
||||||
- [ -d /sys/kernel/debug/block/${dev##*/} ] && echo "$WRP_TOOLNAME: Failed to stop trace on $dev" && (( failed++ ));
|
|
||||||
- done
|
|
||||||
- [ $failed -ne 0 ] && echo "$WRP_TOOLNAME: blktrace has leftovers, manual cleanup required!";
|
|
||||||
+ # synchronize with all children to avoid zombies
|
|
||||||
+ # and to prepare for a clean subsequent re-run of ziomon
|
|
||||||
+ wait
|
|
||||||
|
|
||||||
if [ -e $WRP_MSG_Q_PATH ]; then
|
|
||||||
if [ $WRP_DEBUG -gt 1 ]; then
|
|
@ -1,3 +1,181 @@
|
|||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Oct 5 20:47:52 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Modified mkdump perl script to work with the updated version
|
||||||
|
of the IBM tools dasdview, zipl and zgetdump. (bsc#1020336).
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Wed Oct 4 19:45:29 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Upgraded to version 2.1.0 (Fate#323291).
|
||||||
|
Changes from 2.0.0 to 2.1.0
|
||||||
|
* Added the following tools:
|
||||||
|
netboot: Scripts for building a PXE-style netboot image for KVM
|
||||||
|
90-cpi.rules/cpictl: New udev rule to update CPI when KVM is used
|
||||||
|
* Modified lsqeth/zdev to add VNIC Characteristics support
|
||||||
|
Bug fixes
|
||||||
|
* chzcrypt: Corrected handling of insufficient permissions
|
||||||
|
* cpacfstats: Add size setting to perf event
|
||||||
|
* fdasd: Skip partition check with the force option
|
||||||
|
* ttyrun: Fix deprecated BindTo usage in ttyrun-getty@.service.in
|
||||||
|
* lszcrypt: Fix core dump caused by stack overwrite
|
||||||
|
* lszcrypt: Fix random domain printout when no config available
|
||||||
|
* zdev: Fix segfault with unknown qeth attribute
|
||||||
|
* zdev: Fix IPv6 NDP proxy description
|
||||||
|
* zdev: Fix zdev dracut module temp file location
|
||||||
|
* zkey: Correctly detect abbreviated commands
|
||||||
|
* zkey: Validate XTS key: ignore domain and card
|
||||||
|
* zkey: Use octal values instead of S_IRWX* constants
|
||||||
|
* zkey: Properly set umask to prohibit permissions to group and others
|
||||||
|
* zkey: Add -ldl to LDLIBS (not LDFLAGS)
|
||||||
|
* znetconf: Re-add missing line in lsznet.raw
|
||||||
|
* Fix several gcc 7 warnings
|
||||||
|
- Modified s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
|
||||||
|
to apply cleanly to this version.
|
||||||
|
- Removed the following obsolete patches:
|
||||||
|
* s390-tools-sles15-zgetdump-Fix-gcc-7-warning.patch
|
||||||
|
* s390-tools-sles15-lscss-Get-rid-of-gcc-7-buffer-truncation-warnings.patch
|
||||||
|
* s390-tools-sles15-Get-rid-of-gcc-7-fall-through-warnings.patch
|
||||||
|
* s390-tools-sles15-lszcrypt-Fix-core-dump-caused-by-stack-overwrite.patch
|
||||||
|
* s390-tools-sles15-dasdinfo-Fix-GCC-7-overflow-warning.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Thu Sep 8 21:06:37 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Added the following patches (bsc#1056498)
|
||||||
|
- s390-tools-sles15-zgetdump-Fix-gcc-7-warning.patch
|
||||||
|
- s390-tools-sles15-lscss-Get-rid-of-gcc-7-buffer-truncation-warnings.patch
|
||||||
|
- s390-tools-sles15-Get-rid-of-gcc-7-fall-through-warnings.patch
|
||||||
|
- s390-tools-sles15-lszcrypt-Fix-core-dump-caused-by-stack-overwrite.patch
|
||||||
|
- s390-tools-sles15-dasdinfo-Fix-GCC-7-overflow-warning.patch
|
||||||
|
|
||||||
|
-------------------------------------------------------------------
|
||||||
|
Tue Sep 8 20:01:35 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
- Upgraded to version 2.0.0 (Fate#323291).
|
||||||
|
- Changes from 1.34.0 to 1.35.0
|
||||||
|
- cpuplugd: Make default config file location more distribution agnostic
|
||||||
|
Add systemd service unit to start/stop the cpuplug daemon
|
||||||
|
Add force-reload action to init script for LSB-compliance
|
||||||
|
- mon_statd: Add force-reload action to init script for LSB-compliance
|
||||||
|
- chiucvallow: corrected verification return code
|
||||||
|
- lczdev/chzdev: Add support for resolving iSCSI block devices
|
||||||
|
Bug fixes
|
||||||
|
- chzdev, lszdev: Fix incorrect zfcp module parameter name
|
||||||
|
- chreipl: Fix chreipl node for virtio devices
|
||||||
|
- libus2s: Fix busid parsing
|
||||||
|
- zipl/boot: Fix failed start subchannel in FBA loader
|
||||||
|
- Changes from 1.35.0 to 1.36.0
|
||||||
|
- chzdev/lszdev: Add device resolution for vlan and bonding devices
|
||||||
|
- dasdfmt: Add quick format support
|
||||||
|
- lsdasd/fdasd/dasdfmt/zdsfs: Add query host access to volume support
|
||||||
|
- zfcpdbf: Make timestamp the first field in record output
|
||||||
|
Exclude Payload hex field from log message record output
|
||||||
|
Add Area field to record output
|
||||||
|
Add missing header fields to area record output
|
||||||
|
Print the Record id field for Area area class records
|
||||||
|
Mark oldest and newest trace area records
|
||||||
|
Mark oldest and newest def_err pseudo area records
|
||||||
|
Mark oldest and newest foreign area records
|
||||||
|
Mark oldest and newest log message records
|
||||||
|
Add a warning about low resolution timestamps
|
||||||
|
Add Trace Area Statistics table to script output
|
||||||
|
Add time zone command line option
|
||||||
|
Add collection of domain xml files
|
||||||
|
Bug fixes
|
||||||
|
- zfcpdbf: Move and fix CPU id field output to print_header function
|
||||||
|
Include microseconds in warning threshold calculation
|
||||||
|
Fix parsing of precise syslog timestamps
|
||||||
|
Fix labels for REC ERP action status and ERP step fields
|
||||||
|
- Changes from 1.36.0 to 1.36.1
|
||||||
|
- zfcpdbf: Support basic HBA record type without warning
|
||||||
|
Restore tracing of handle for port and LUN with HBA records
|
||||||
|
Print full payload for all SAN traces (req, resp, iels)
|
||||||
|
Print payload length everywhere applicable
|
||||||
|
Disambiguate printing of payload record content
|
||||||
|
Bug fixes
|
||||||
|
- fdasd: Prevent buffer overflow
|
||||||
|
- znetconf: Fix detection of chpids as OSX instead of OSM
|
||||||
|
- Changes from 1.36.1 to 1.37.0
|
||||||
|
- Added dump2tar: sysfs collection helper for dbginfo.sh
|
||||||
|
- qethconf: Remove check for OSN-device
|
||||||
|
- znetconf: Remove OSN-support
|
||||||
|
- lsdasd/tunedasd: Add channel path aware erp
|
||||||
|
- zcrypt: Add multi domain support for zcrypt device driver
|
||||||
|
- scm: Reimplement lsscm in C
|
||||||
|
- chp: Reimplement chchp and lschp in C
|
||||||
|
- dbginfo.sh: Make use of sysinfo collection helper
|
||||||
|
Bug fixes
|
||||||
|
- zfcpdbf: Only cap SAN short payload if pl_len exists
|
||||||
|
- chzdev: Fix bug when configuring QETH devices
|
||||||
|
- libu2s: Prevent buffer overflow
|
||||||
|
- ziomon: No blktrace kill which can corrupt kernel blktrace state
|
||||||
|
- Changes from 1.37.0 to 1.37.1
|
||||||
|
- dbginfo.sh: Add Docker debug data
|
||||||
|
Bug fixes
|
||||||
|
- lsdasd: Replace continue with return
|
||||||
|
- lscss: Allow to specify devices from subchannel set 3
|
||||||
|
- mon_fsstatd: Only use physical filesystems
|
||||||
|
Fix double free in error path
|
||||||
|
- mon_procd: Fix segmentation fault
|
||||||
|
- Changes from 1.37.1 to 1.38.0
|
||||||
|
- systemd: Add new units for cpi, dumpconf, mon_fsstatd, and mon_procd
|
||||||
|
- fdasd: Add new command action 'l' to list known partition types
|
||||||
|
- chmem: Try to online memory to zone movable
|
||||||
|
Starting with kernel 4.13 (commit f1dd2cd1), the default zone for
|
||||||
|
hotplug memory is changed from zone movable to zone normal. In order
|
||||||
|
to preserve the previous default behaviour, chmem will now always try
|
||||||
|
to set memory online to the zone movable, before trying to set it
|
||||||
|
online to the default zone.
|
||||||
|
- zfcpdbf: Print high part of "new" 64 bit SCSI LUN
|
||||||
|
Print payload with full FCP_RSP IU in SCSI trace records
|
||||||
|
- util_opt: Add command specific command line parsing
|
||||||
|
- util_rec: Implement util_rec_iterate() function
|
||||||
|
- util_rec: Record field values can be stored and processed in argz format
|
||||||
|
Bug fixes
|
||||||
|
- zipl/zgetdump: Add missing SCSI multipath dump information to man pages
|
||||||
|
- lsqeth: Fix attributes name: ipa -> ipa_takeover and parp -> rxip
|
||||||
|
Fix lsqeth output of ipa/vipa/rxip addresses of interfaces
|
||||||
|
- zfcpdbf: Fix payload length for zfcp_dbf_hba_bit_err
|
||||||
|
- chzdev: Add implicit qeth layer settings handling
|
||||||
|
- qethqoat: Fix OSA 6S detection
|
||||||
|
- Changes from 1.38.0 to 2.0.0 (also known as 1.39.0)
|
||||||
|
- IBM changed the license to MIT.
|
||||||
|
- Added zkey: Generate, re-encipher, and validate secure AES keys
|
||||||
|
- cpumf: Add hardware counters for z13 and z13s
|
||||||
|
- lscss: Reimplement lscss script in C
|
||||||
|
- lsqeth: Reimplement lsqeth script in C
|
||||||
|
Bug fixes
|
||||||
|
- lscpumf: Fix Perl warnings
|
||||||
|
- Removed the following obsolete patches:
|
||||||
|
s390-tools-sles12sp2-chiucvallow-verify.patch
|
||||||
|
s390-tools-sles12sp2-chreipl-virtio.patch
|
||||||
|
s390-tools-sles12sp2-chzdev-disable-root-update.patch
|
||||||
|
s390-tools-sles12sp2-feat-01-dasd-query-host.patch
|
||||||
|
s390-tools-sles12sp2-lscss-allow-to-specify-devices-from-ssid-3.patch
|
||||||
|
s390-tools-sles12sp2-zipl-fix-failed-start-subchannel.patch
|
||||||
|
s390-tools-sles12sp3-chmem-try-to-online-zone-movable.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-01-Fix-behaviour-of-t-combined-with-y.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-02-Fix-trailing-whitespace.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-03-Apply-coding-convention.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-04-Use-enhanced-DASD-information.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-05-Refactor-do_format_dasd.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-06-Make-the-IOCTL-BLKSSZGET-reusable.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-07-Add-quick-format-support.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-08-Make-progress-output-reusable-and-add-ETR.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-09-Add-command-line-argument-check.patch
|
||||||
|
s390-tools-sles12sp3-dasdfmt-10-Add-expand-format-mode.patch
|
||||||
|
s390-tools-sles12sp3-dbginfo-01-libutil-Add-utility-functions.patch
|
||||||
|
s390-tools-sles12sp3-dbginfo-02-dump2tar-Add-sysfs-collection-helper-for-dbginfo.sh-v2.patch
|
||||||
|
s390-tools-sles12sp3-dbginfo-03-dbginfo.sh-Make-use-of-sysinfo-collection-helper.patch
|
||||||
|
s390-tools-sles12sp3-dbginfo-Collect-docker-debug-data.patch
|
||||||
|
s390-tools-sles12sp2-libu2s-Fix-busid-parsing.patch
|
||||||
|
s390-tools-sles12sp3-lsdasd-tunedasd-Add-channel-path-aware-erp.patch
|
||||||
|
s390-tools-sles12sp3-mon_fsstatd-fix-double-free-in-error-path-and-skip-virtual-fs.patch
|
||||||
|
s390-tools-sles12sp3-util_proc-fix-memory-allocation-error-messages.patch
|
||||||
|
s390-tools-sles12sp3-ziomon-no-blktrace-kill-which-can-corrupt-kernel-blk.patch
|
||||||
|
- Added s390-tools-sles15-add--ldl-to-LDLIBS.patch to fix a problem with zkey/Makefile.
|
||||||
|
|
||||||
-------------------------------------------------------------------
|
-------------------------------------------------------------------
|
||||||
Thu Sep 7 19:41:39 UTC 2017 - mpost@suse.com
|
Thu Sep 7 19:41:39 UTC 2017 - mpost@suse.com
|
||||||
|
|
||||||
|
139
s390-tools.spec
139
s390-tools.spec
@ -17,11 +17,11 @@
|
|||||||
|
|
||||||
|
|
||||||
Name: s390-tools
|
Name: s390-tools
|
||||||
Version: 1.34.0
|
Version: 2.1.0
|
||||||
Release: 0
|
Release: 0
|
||||||
Url: https://www.ibm.com/developerworks/linux/linux390/
|
Url: https://github.com/ibm-s390-tools/s390-tools
|
||||||
Summary: S/390 tools like zipl and dasdfmt
|
Summary: S/390 tools like zipl and dasdfmt
|
||||||
License: GPL-2.0+ and BSD-2-Clause
|
License: MIT
|
||||||
Group: System/Kernel
|
Group: System/Kernel
|
||||||
BuildRequires: dracut
|
BuildRequires: dracut
|
||||||
BuildRequires: fuse-devel
|
BuildRequires: fuse-devel
|
||||||
@ -46,7 +46,7 @@ Requires: util-linux
|
|||||||
Provides: s390utils:/sbin/dasdfmt
|
Provides: s390utils:/sbin/dasdfmt
|
||||||
# Don't build with pie to avoid problems with zipl
|
# Don't build with pie to avoid problems with zipl
|
||||||
#!BuildIgnore: gcc-PIE
|
#!BuildIgnore: gcc-PIE
|
||||||
Source: s390-tools-%{version}.tar.bz2
|
Source: s390-tools-%{version}.tar.gz
|
||||||
Source1: s390-tools-rpmlintrc
|
Source1: s390-tools-rpmlintrc
|
||||||
Source2: zipl.conf
|
Source2: zipl.conf
|
||||||
Source3: hsnc
|
Source3: hsnc
|
||||||
@ -62,8 +62,6 @@ Source12: mkdump.pl
|
|||||||
Source13: sysconfig.osasnmpd
|
Source13: sysconfig.osasnmpd
|
||||||
Source14: zfcp_san_disc
|
Source14: zfcp_san_disc
|
||||||
Source15: mkdump.8
|
Source15: mkdump.8
|
||||||
Source16: boot.cpi
|
|
||||||
Source17: sysconfig.cpi
|
|
||||||
Source18: zpxe.rexx
|
Source18: zpxe.rexx
|
||||||
Source19: rules.xpram
|
Source19: rules.xpram
|
||||||
Source20: rules.hw_random
|
Source20: rules.hw_random
|
||||||
@ -106,36 +104,10 @@ Patch1: s390-tools-sles12-zipl_boot_msg.patch
|
|||||||
Patch2: s390-tools-sles12-sysconfig-compatible-dumpconf.patch
|
Patch2: s390-tools-sles12-sysconfig-compatible-dumpconf.patch
|
||||||
Patch3: s390-tools-sles12-create-filesystem-links.patch
|
Patch3: s390-tools-sles12-create-filesystem-links.patch
|
||||||
Patch4: s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch
|
Patch4: s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch
|
||||||
Patch5: s390-tools-sles12sp2-feat-01-dasd-query-host.patch
|
Patch5: s390-tools-sles12-pardasdfmt.patch
|
||||||
Patch6: s390-tools-sles12-pardasdfmt.patch
|
Patch6: dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch
|
||||||
Patch7: dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch
|
Patch7: 59-dasd.rules-wait_for.patch
|
||||||
Patch8: 59-dasd.rules-wait_for.patch
|
Patch8: s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
|
||||||
Patch9: s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
|
|
||||||
Patch10: s390-tools-sles12sp2-libu2s-Fix-busid-parsing.patch
|
|
||||||
Patch11: s390-tools-sles12sp2-chiucvallow-verify.patch
|
|
||||||
Patch12: s390-tools-sles12sp2-zipl-fix-failed-start-subchannel.patch
|
|
||||||
Patch13: s390-tools-sles12sp2-chreipl-virtio.patch
|
|
||||||
Patch14: s390-tools-sles12sp2-chzdev-disable-root-update.patch
|
|
||||||
Patch15: s390-tools-sles12sp2-lscss-allow-to-specify-devices-from-ssid-3.patch
|
|
||||||
Patch16: s390-tools-sles12sp3-dbginfo-01-libutil-Add-utility-functions.patch
|
|
||||||
Patch17: s390-tools-sles12sp3-dbginfo-02-dump2tar-Add-sysfs-collection-helper-for-dbginfo.sh-v2.patch
|
|
||||||
Patch18: s390-tools-sles12sp3-dbginfo-03-dbginfo.sh-Make-use-of-sysinfo-collection-helper.patch
|
|
||||||
Patch19: s390-tools-sles12sp3-lsdasd-tunedasd-Add-channel-path-aware-erp.patch
|
|
||||||
Patch20: s390-tools-sles12sp3-dasdfmt-01-Fix-behaviour-of-t-combined-with-y.patch
|
|
||||||
Patch21: s390-tools-sles12sp3-dasdfmt-02-Fix-trailing-whitespace.patch
|
|
||||||
Patch22: s390-tools-sles12sp3-dasdfmt-03-Apply-coding-convention.patch
|
|
||||||
Patch23: s390-tools-sles12sp3-dasdfmt-04-Use-enhanced-DASD-information.patch
|
|
||||||
Patch24: s390-tools-sles12sp3-dasdfmt-05-Refactor-do_format_dasd.patch
|
|
||||||
Patch25: s390-tools-sles12sp3-dasdfmt-06-Make-the-IOCTL-BLKSSZGET-reusable.patch
|
|
||||||
Patch26: s390-tools-sles12sp3-dasdfmt-07-Add-quick-format-support.patch
|
|
||||||
Patch27: s390-tools-sles12sp3-dasdfmt-08-Make-progress-output-reusable-and-add-ETR.patch
|
|
||||||
Patch28: s390-tools-sles12sp3-dasdfmt-09-Add-command-line-argument-check.patch
|
|
||||||
Patch29: s390-tools-sles12sp3-dasdfmt-10-Add-expand-format-mode.patch
|
|
||||||
Patch30: s390-tools-sles12sp3-util_proc-fix-memory-allocation-error-messages.patch
|
|
||||||
Patch31: s390-tools-sles12sp3-mon_fsstatd-fix-double-free-in-error-path-and-skip-virtual-fs.patch
|
|
||||||
Patch32: s390-tools-sles12sp3-dbginfo-Collect-docker-debug-data.patch
|
|
||||||
Patch33: s390-tools-sles12sp3-ziomon-no-blktrace-kill-which-can-corrupt-kernel-blk.patch
|
|
||||||
Patch34: s390-tools-sles12sp3-chmem-try-to-online-zone-movable.patch
|
|
||||||
|
|
||||||
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
BuildRoot: %{_tmppath}/%{name}-%{version}-build
|
||||||
ExclusiveArch: s390 s390x
|
ExclusiveArch: s390 s390x
|
||||||
@ -196,36 +168,10 @@ to list files and directories.
|
|||||||
%patch2 -p1
|
%patch2 -p1
|
||||||
%patch3 -p1
|
%patch3 -p1
|
||||||
%patch4 -p1
|
%patch4 -p1
|
||||||
%patch5 -p1
|
#patch5 -p1
|
||||||
%patch6 -p1
|
%patch6 -p1
|
||||||
%patch7 -p1
|
%patch7 -p1
|
||||||
%patch8 -p1
|
%patch8 -p1
|
||||||
%patch9 -p1
|
|
||||||
%patch10 -p1
|
|
||||||
%patch11 -p1
|
|
||||||
%patch12 -p1
|
|
||||||
%patch13 -p1
|
|
||||||
%patch14 -p1
|
|
||||||
%patch15 -p1
|
|
||||||
%patch16 -p1
|
|
||||||
%patch17 -p1
|
|
||||||
%patch18 -p1
|
|
||||||
%patch19 -p1
|
|
||||||
%patch20 -p1
|
|
||||||
%patch21 -p1
|
|
||||||
%patch22 -p1
|
|
||||||
%patch23 -p1
|
|
||||||
%patch24 -p1
|
|
||||||
%patch25 -p1
|
|
||||||
%patch26 -p1
|
|
||||||
%patch27 -p1
|
|
||||||
%patch28 -p1
|
|
||||||
%patch29 -p1
|
|
||||||
%patch30 -p1
|
|
||||||
%patch31 -p1
|
|
||||||
%patch32 -p1
|
|
||||||
%patch33 -p1
|
|
||||||
%patch34 -p1
|
|
||||||
|
|
||||||
cp -vi %{S:22} CAUTION
|
cp -vi %{S:22} CAUTION
|
||||||
|
|
||||||
@ -253,15 +199,15 @@ install -m644 -t $RPM_BUILD_ROOT/%{_mandir}/man8 %{S:87}
|
|||||||
export ROOT_BUILD_DIR="$RPM_BUILD_DIR/%{name}-%{version}/zfcpdump/kernel"
|
export ROOT_BUILD_DIR="$RPM_BUILD_DIR/%{name}-%{version}/zfcpdump/kernel"
|
||||||
install -D -m600 /boot/image-*-zfcpdump $RPM_BUILD_ROOT/usr/lib/s390-tools/zfcpdump/zfcpdump_part.image
|
install -D -m600 /boot/image-*-zfcpdump $RPM_BUILD_ROOT/usr/lib/s390-tools/zfcpdump/zfcpdump_part.image
|
||||||
|
|
||||||
install -D -m644 etc/sysconfig/dumpconf $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.dumpconf
|
|
||||||
install -D -m755 etc/init.d/dumpconf $RPM_BUILD_ROOT/etc/init.d/dumpconf
|
|
||||||
install -D -m644 etc/udev/rules.d/40-z90crypt.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/40-z90crypt.rules
|
install -D -m644 etc/udev/rules.d/40-z90crypt.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/40-z90crypt.rules
|
||||||
install -D -m644 etc/udev/rules.d/59-dasd.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/59-dasd.rules
|
|
||||||
install -D -m644 etc/udev/rules.d/57-osasnmpd.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/57-osasnmpd.rules
|
install -D -m644 etc/udev/rules.d/57-osasnmpd.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/57-osasnmpd.rules
|
||||||
|
install -D -m644 etc/udev/rules.d/59-dasd.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/59-dasd.rules
|
||||||
|
install -D -m644 etc/udev/rules.d/90-cpi.rules $RPM_BUILD_ROOT/usr/lib/udev/rules.d/90-cpi.rules
|
||||||
|
install -D -m644 etc/sysconfig/cpi $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.cpi
|
||||||
|
install -D -m644 etc/sysconfig/dumpconf $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.dumpconf
|
||||||
|
install -D -m644 etc/sysconfig/mon_fsstatd $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.mon_fsstatd
|
||||||
|
install -D -m644 etc/sysconfig/mon_procd $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.mon_procd
|
||||||
install -D -m644 etc/sysconfig/mon_statd $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.mon_statd
|
install -D -m644 etc/sysconfig/mon_statd $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.mon_statd
|
||||||
install -D -m755 etc/init.d/mon_statd $RPM_BUILD_ROOT/etc/init.d/mon_statd
|
|
||||||
install -D -m644 etc/sysconfig/cpuplugd $RPM_BUILD_ROOT/var/adm/fillup-templates/sysconfig.cpuplugd
|
|
||||||
install -D -m755 etc/init.d/cpuplugd $RPM_BUILD_ROOT/etc/init.d/cpuplugd
|
|
||||||
mv iucvterm/doc/ts-shell/iucvconn_on_login $RPM_BUILD_ROOT/usr/bin/iucvconn_on_login
|
mv iucvterm/doc/ts-shell/iucvconn_on_login $RPM_BUILD_ROOT/usr/bin/iucvconn_on_login
|
||||||
install -D -m644 %{S:26} $RPM_BUILD_ROOT/%{_unitdir}/cio_ignore.service
|
install -D -m644 %{S:26} $RPM_BUILD_ROOT/%{_unitdir}/cio_ignore.service
|
||||||
install -D -m755 %{S:27} $RPM_BUILD_ROOT/usr/lib/systemd/scripts/setup_cio_ignore.sh
|
install -D -m755 %{S:27} $RPM_BUILD_ROOT/usr/lib/systemd/scripts/setup_cio_ignore.sh
|
||||||
@ -287,8 +233,6 @@ install -D -m755 %{S:12} sbin/mkdump
|
|||||||
install -D -m644 %{S:13} var/adm/fillup-templates/sysconfig.osasnmpd
|
install -D -m644 %{S:13} var/adm/fillup-templates/sysconfig.osasnmpd
|
||||||
install -D -m755 %{S:14} sbin/zfcp_san_disc
|
install -D -m755 %{S:14} sbin/zfcp_san_disc
|
||||||
install -D -m644 %{S:15} $RPM_BUILD_ROOT/%{_mandir}/man8
|
install -D -m644 %{S:15} $RPM_BUILD_ROOT/%{_mandir}/man8
|
||||||
install -D -m755 %{S:16} etc/init.d/boot.cpi
|
|
||||||
install -D -m644 %{S:17} var/adm/fillup-templates/sysconfig.cpi
|
|
||||||
install -D -m644 %{S:19} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/52-xpram.rules
|
install -D -m644 %{S:19} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/52-xpram.rules
|
||||||
install -D -m644 %{S:20} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/52-hw_random.rules
|
install -D -m644 %{S:20} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/52-hw_random.rules
|
||||||
install -D -m644 %{S:21} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/59-graf.rules
|
install -D -m644 %{S:21} $RPM_BUILD_ROOT/usr/lib/udev/rules.d/59-graf.rules
|
||||||
@ -304,14 +248,16 @@ if [ ! -d %{_sbindir} ]; then
|
|||||||
mkdir -p %{_sbindir}
|
mkdir -p %{_sbindir}
|
||||||
fi
|
fi
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/appldata rcappldata)
|
(cd usr/sbin; ln -s ../../etc/init.d/appldata rcappldata)
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/cpuplugd rccpuplugd)
|
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/dumpconf rcdumpconf)
|
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/hsnc rchsnc)
|
(cd usr/sbin; ln -s ../../etc/init.d/hsnc rchsnc)
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/mon_statd rcmon_statd)
|
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/vmlogrdr rcvmlogrdr)
|
(cd usr/sbin; ln -s ../../etc/init.d/vmlogrdr rcvmlogrdr)
|
||||||
(cd usr/sbin; ln -s ../../etc/init.d/xpram rcxpram)
|
(cd usr/sbin; ln -s ../../etc/init.d/xpram rcxpram)
|
||||||
(cd usr/sbin; ln -s service rccio_ignore)
|
(cd usr/sbin; ln -s service rccio_ignore)
|
||||||
(cd usr/sbin; ln -s service rccpacfstatsd)
|
(cd usr/sbin; ln -s service rccpacfstatsd)
|
||||||
|
(cd usr/sbin; ln -s service rccpi)
|
||||||
|
(cd usr/sbin; ln -s service rccpuplugd)
|
||||||
|
(cd usr/sbin; ln -s service rcdumpconf)
|
||||||
|
(cd usr/sbin; ln -s service rcmon_fsstatd)
|
||||||
|
(cd usr/sbin; ln -s service rcmon_procd)
|
||||||
(cd usr/sbin; ln -s service rcvirtsetup)
|
(cd usr/sbin; ln -s service rcvirtsetup)
|
||||||
|
|
||||||
if [ ! -d %{_bindir} ]; then
|
if [ ! -d %{_bindir} ]; then
|
||||||
@ -364,6 +310,13 @@ chmod 755 osasnmpd
|
|||||||
getent group ts-shell >/dev/null 2>&1 || groupadd -r ts-shell
|
getent group ts-shell >/dev/null 2>&1 || groupadd -r ts-shell
|
||||||
%service_add_pre cio_ignore.service
|
%service_add_pre cio_ignore.service
|
||||||
%service_add_pre cpacfstatsd.service
|
%service_add_pre cpacfstatsd.service
|
||||||
|
%service_add_pre cpi.service
|
||||||
|
%service_add_pre cpuplugd.service
|
||||||
|
%service_add_pre dumpconf.service
|
||||||
|
%service_add_pre iucvtty-login@.service
|
||||||
|
%service_add_pre mon_fsstatd.service
|
||||||
|
%service_add_pre mon_procd.service
|
||||||
|
%service_add_pre ttyrun-getty@.service
|
||||||
%service_add_pre virtsetup.service
|
%service_add_pre virtsetup.service
|
||||||
|
|
||||||
%post
|
%post
|
||||||
@ -378,17 +331,25 @@ fi
|
|||||||
# Create symbolic links to the scripts from setup and boot directories
|
# Create symbolic links to the scripts from setup and boot directories
|
||||||
%service_add_post cio_ignore.service
|
%service_add_post cio_ignore.service
|
||||||
%service_add_post cpacfstatsd.service
|
%service_add_post cpacfstatsd.service
|
||||||
|
%service_add_post cpi.service
|
||||||
|
%service_add_post cpuplugd.service
|
||||||
|
%service_add_post dumpconf.service
|
||||||
|
%service_add_post iucvtty-login@.service
|
||||||
|
%service_add_post mon_fsstatd.service
|
||||||
|
%service_add_post mon_procd.service
|
||||||
|
%service_add_post ttyrun-getty@.service
|
||||||
%service_add_post virtsetup.service
|
%service_add_post virtsetup.service
|
||||||
|
|
||||||
# -i: skip insserv parts - has to be configured before use:
|
# -i: skip insserv parts - has to be configured before use:
|
||||||
%{fillup_and_insserv -i -n appldata}
|
%{fillup_and_insserv -i -n appldata}
|
||||||
%{fillup_and_insserv -i -n cpuplugd}
|
%{fillup_and_insserv -i -n cpi}
|
||||||
%{fillup_and_insserv -i -n dumpconf}
|
%{fillup_and_insserv -i -n dumpconf}
|
||||||
%{fillup_and_insserv -i -n hsnc}
|
%{fillup_and_insserv -i -n hsnc}
|
||||||
|
%{fillup_and_insserv -i -n mon_fsstatd}
|
||||||
|
%{fillup_and_insserv -i -n mon_procd}
|
||||||
%{fillup_and_insserv -i -n mon_statd}
|
%{fillup_and_insserv -i -n mon_statd}
|
||||||
%{fillup_and_insserv -i -n vmlogrdr}
|
|
||||||
%{fillup_and_insserv -i -n virtsetup}
|
%{fillup_and_insserv -i -n virtsetup}
|
||||||
%{fillup_and_insserv -i -n xpram}
|
%{fillup_and_insserv -i -n xpram}
|
||||||
%{fillup_and_insserv -y -n cpi boot.cpi}
|
|
||||||
|
|
||||||
%triggerin -- kernel-default
|
%triggerin -- kernel-default
|
||||||
grep -q '^/usr/bin/ts-shell$' /etc/shells \
|
grep -q '^/usr/bin/ts-shell$' /etc/shells \
|
||||||
@ -399,28 +360,35 @@ grep -q '^/usr/bin/ts-shell$' /etc/shells \
|
|||||||
|
|
||||||
%preun
|
%preun
|
||||||
%{stop_on_removal appldata}
|
%{stop_on_removal appldata}
|
||||||
%{stop_on_removal cpuplugd}
|
|
||||||
%{stop_on_removal dumpconf}
|
|
||||||
%{stop_on_removal hsnc}
|
%{stop_on_removal hsnc}
|
||||||
%{stop_on_removal mon_statd}
|
|
||||||
%{stop_on_removal vmlogrdr}
|
%{stop_on_removal vmlogrdr}
|
||||||
%{stop_on_removal xpram}
|
%{stop_on_removal xpram}
|
||||||
%service_del_preun cio_ignore.service
|
%service_del_preun cio_ignore.service
|
||||||
%service_del_preun cpacfstatsd.service
|
%service_del_preun cpacfstatsd.service
|
||||||
|
%service_del_preun cpi.service
|
||||||
|
%service_del_preun cpuplugd.service
|
||||||
|
%service_del_preun dumpconf.service
|
||||||
|
%service_del_preun iucvtty-login@.service
|
||||||
|
%service_del_preun mon_fsstatd.service
|
||||||
|
%service_del_preun mon_procd.service
|
||||||
%service_del_preun virtsetup.service
|
%service_del_preun virtsetup.service
|
||||||
|
|
||||||
%postun
|
%postun
|
||||||
%{restart_on_update boot.cpi}
|
|
||||||
%{restart_on_update appldata}
|
%{restart_on_update appldata}
|
||||||
%{restart_on_update cpuplugd}
|
|
||||||
%{restart_on_update dumpconf}
|
|
||||||
%{restart_on_update hsnc}
|
%{restart_on_update hsnc}
|
||||||
%{restart_on_update mon_statd}
|
|
||||||
%{restart_on_update vmlogrdr}
|
%{restart_on_update vmlogrdr}
|
||||||
%{restart_on_update xpram}
|
%{restart_on_update xpram}
|
||||||
%service_del_postun cio_ignore.service
|
%service_del_postun cio_ignore.service
|
||||||
%service_del_postun cpacfstatsd.service
|
%service_del_postun cpacfstatsd.service
|
||||||
|
%service_del_postun cpi.service
|
||||||
|
%service_del_postun cpuplugd.service
|
||||||
|
%service_del_postun dumpconf.service
|
||||||
|
%service_del_postun iucvtty-login@.service
|
||||||
|
%service_del_postun mon_fsstatd.service
|
||||||
|
%service_del_postun mon_procd.service
|
||||||
|
%service_del_postun ttyrun-getty@.service
|
||||||
%service_del_postun virtsetup.service
|
%service_del_postun virtsetup.service
|
||||||
|
|
||||||
read INITPGM < /proc/1/comm
|
read INITPGM < /proc/1/comm
|
||||||
if [ "${INITPGM}" == "systemd" ]; then
|
if [ "${INITPGM}" == "systemd" ]; then
|
||||||
echo "Running systemctl daemon-reload."
|
echo "Running systemctl daemon-reload."
|
||||||
@ -447,7 +415,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
|
|
||||||
%files -f %{_builddir}/%{name}.list
|
%files -f %{_builddir}/%{name}.list
|
||||||
%defattr(-,root,root)
|
%defattr(-,root,root)
|
||||||
%doc README
|
%doc README.md
|
||||||
%doc README.SUSE
|
%doc README.SUSE
|
||||||
|
|
||||||
%doc iucvterm/doc/ts-shell
|
%doc iucvterm/doc/ts-shell
|
||||||
@ -470,6 +438,7 @@ rm -rf $RPM_BUILD_ROOT
|
|||||||
%dir %{_unitdir}
|
%dir %{_unitdir}
|
||||||
%dir /usr/share/s390-tools
|
%dir /usr/share/s390-tools
|
||||||
%dir /usr/share/s390-tools/cpumf
|
%dir /usr/share/s390-tools/cpumf
|
||||||
|
%dir /usr/share/s390-tools/netboot
|
||||||
%dir /boot/zipl
|
%dir /boot/zipl
|
||||||
%dir /lib/s390-tools/
|
%dir /lib/s390-tools/
|
||||||
%exclude /usr/lib/udev/rules.d/57-osasnmpd.rules
|
%exclude /usr/lib/udev/rules.d/57-osasnmpd.rules
|
||||||
|
@ -1,22 +0,0 @@
|
|||||||
## Path: Kernel/CPI
|
|
||||||
## Description: set Control Program Indentification data
|
|
||||||
## Type: list(yes,no)
|
|
||||||
## Default: no
|
|
||||||
#
|
|
||||||
# Set Control Program Identification data
|
|
||||||
#
|
|
||||||
CPI_SET="yes"
|
|
||||||
|
|
||||||
## Type: string
|
|
||||||
## Default: ""
|
|
||||||
#
|
|
||||||
# CPI system name
|
|
||||||
#
|
|
||||||
CPI_SYSTEM_NAME=""
|
|
||||||
|
|
||||||
## Type: string
|
|
||||||
## Default: ""
|
|
||||||
#
|
|
||||||
# CPI sysplex name
|
|
||||||
#
|
|
||||||
CPI_SYSPLEX_NAME=""
|
|
Loading…
Reference in New Issue
Block a user