diff --git a/_service b/_service
new file mode 100644
index 0000000..bc6bf7b
--- /dev/null
+++ b/_service
@@ -0,0 +1,15 @@
+
+
+ s390-tools-2.29.0.tar.gz
+ zst
+ true
+ ../../vendor
+ /rust/pvsecret/Cargo.toml
+ /rust/pv/Cargo.toml
+ /rust/pv/openssl_extentions/Cargo.toml
+ /rust/utils/Cargo.toml
+
+
+ s390-tools-2.29.0.tar.gz
+
+
diff --git a/cargo_config b/cargo_config
new file mode 100644
index 0000000..f0c3455
--- /dev/null
+++ b/cargo_config
@@ -0,0 +1,5 @@
+[source.crates-io]
+replace-with = "vendored-sources"
+
+[source.vendored-sources]
+directory = "vendor/"
diff --git a/read_values.c b/read_values.c
index 2e2072d..e227889 100644
--- a/read_values.c
+++ b/read_values.c
@@ -76,8 +76,10 @@ struct machinetype {
{ QC_TYPE_FAMILY_LINUXONE, "8561", "8561 = IBM LinuxONE III LT1" },
{ QC_TYPE_FAMILY_IBMZ, "8562", "8562 = z15 T02 IBM z15 T02" },
{ QC_TYPE_FAMILY_LINUXONE, "8562", "8562 = IBM LinuxONE III LT2" },
- { QC_TYPE_FAMILY_IBMZ, "3931", "3931 = z16 IBM z16 A01" },
+ { QC_TYPE_FAMILY_IBMZ, "3931", "3931 = z16 A01 IBM z16 A01" },
{ QC_TYPE_FAMILY_LINUXONE, "3931", "3931 = IBM LinuxONE Emperor 4" },
+ { QC_TYPE_FAMILY_IBMZ, "3932", "3932 = z16 A02 IBM z16 A02" },
+ { QC_TYPE_FAMILY_LINUXONE, "3932", "3932 = IBM LinuxONE Rockhopper 4" },
};
int debug = 0;
@@ -260,6 +262,40 @@ if (layers > 2) {
return;
} /* print_scc */
+
+/******************************************************************************/
+/* */
+/* Secure boot support models ( check_model () ) */
+/* Only the following machines support secure boot: */
+/* z14, z14 ZR1, z15, z16 */
+/* */
+/******************************************************************************/
+
+int check_model (const char *cpu) {
+
+ #define IBM_Models 6 /* Number of IBM models listed below */
+ char *types[IBM_Models] = {
+ "3906",
+ "3907",
+ "8561",
+ "8562",
+ "3931",
+ "3932",
+ };
+
+ int i;
+ int models = sizeof(types) / sizeof(types[0]);
+
+ for ( i = 0; i < models; i++) {
+
+ if ( !strcmp(cpu,types[i]) ) {
+ return 1;
+ };
+ }
+ return 0;
+} /* check_model */
+
+
/******************************************************************************/
/* */
/* print out whether secure boot is enabled */
@@ -310,17 +346,14 @@ struct utsname uts;
printf("Print_secure called\n");
#endif
/*
- * Only the following machines support secure boot: z14, z14 ZR1, z15
- * 3906, 3907, 8561
+ * Only the following machines support secure boot: z14, z14 ZR1, z15, z16
+ * 3906, 3907, 8561, 8562, 3931, 3932
*/
erg = qc_get_attribute_string(configuration_handle, qc_type, 0, &cpu_type);
if (erg == 1 && cpu_type != NULL) {
- if (strcmp(cpu_type, "3906") != 0) {
- if (strcmp(cpu_type, "3907") != 0) {
- if (strcmp(cpu_type, "8561") != 0) {
- goto return_does_not_exist;
- } /* endif */
- } /* endif */
+
+ if ( check_model(cpu_type) ) {
+ goto return_does_not_exist;
} /* endif */
} /* endif */
print_attribute("Secure mode on", 1, qc_has_secure, integer, WITH_KEY);
@@ -335,6 +368,7 @@ return_does_not_exist:
return;
} /* print_secure_mode */
+
/******************************************************************************/
/* */
/* print out the uuid for this machine */
diff --git a/s390-tools-2.27.0.tar.gz b/s390-tools-2.27.0.tar.gz
deleted file mode 100644
index ce73dcb..0000000
--- a/s390-tools-2.27.0.tar.gz
+++ /dev/null
@@ -1,3 +0,0 @@
-version https://git-lfs.github.com/spec/v1
-oid sha256:4315e64cf2fe0240ff9bd9929501db731d5bf3e7acf964ecf323d48d90e08f6e
-size 1848002
diff --git a/s390-tools-2.29.0.tar.gz b/s390-tools-2.29.0.tar.gz
new file mode 100644
index 0000000..95d81d9
--- /dev/null
+++ b/s390-tools-2.29.0.tar.gz
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:849ff400dc6c1eb7eebe4aa3e7a4871721c25bcee6cfdd0535a056a038fd3ab0
+size 1950182
diff --git a/s390-tools-ALP-zdev-live.patch b/s390-tools-ALP-zdev-live.patch
index 4b48c2c..c9881d4 100644
--- a/s390-tools-ALP-zdev-live.patch
+++ b/s390-tools-ALP-zdev-live.patch
@@ -5,8 +5,10 @@
zdev/dracut/Makefile | 15 ++++++++++--
4 files changed, 92 insertions(+), 2 deletions(-)
+Index: s390-tools-2.29.0/zdev/dracut/96zdev-live/module-setup.sh
+===================================================================
--- /dev/null
-+++ b/zdev/dracut/96zdev-live/module-setup.sh
++++ s390-tools-2.29.0/zdev/dracut/96zdev-live/module-setup.sh
@@ -0,0 +1,32 @@
+#!/bin/bash
+
@@ -40,8 +42,10 @@
+ inst_hook cleanup 41 "$moddir/write-udev-live.sh"
+ inst_multiple chzdev
+}
+Index: s390-tools-2.29.0/zdev/dracut/96zdev-live/parse-zdev-live.sh
+===================================================================
--- /dev/null
-+++ b/zdev/dracut/96zdev-live/parse-zdev-live.sh
++++ s390-tools-2.29.0/zdev/dracut/96zdev-live/parse-zdev-live.sh
@@ -0,0 +1,36 @@
+#!/bin/bash
+#
@@ -79,8 +83,10 @@
+ fi
+done
+
+Index: s390-tools-2.29.0/zdev/dracut/96zdev-live/write-udev-live.sh
+===================================================================
--- /dev/null
-+++ b/zdev/dracut/96zdev-live/write-udev-live.sh
++++ s390-tools-2.29.0/zdev/dracut/96zdev-live/write-udev-live.sh
@@ -0,0 +1,11 @@
+#!/bin/sh
+#
@@ -93,9 +99,11 @@
+if [ -w /sysroot/etc/udev/rules.d ]; then
+ cp -p /etc/udev/rules.d/41-* /sysroot/etc/udev/rules.d
+fi
---- a/zdev/dracut/Makefile
-+++ b/zdev/dracut/Makefile
-@@ -3,17 +3,23 @@
+Index: s390-tools-2.29.0/zdev/dracut/Makefile
+===================================================================
+--- s390-tools-2.29.0.orig/zdev/dracut/Makefile
++++ s390-tools-2.29.0/zdev/dracut/Makefile
+@@ -3,17 +3,23 @@ include ../../common.mak
ZDEVDIR := 95zdev
ZDEVKDUMPDIR := 95zdev-kdump
@@ -121,7 +129,7 @@
ifeq ($(HAVE_DRACUT),1)
install:
$(INSTALL) -m 755 -d $(DESTDIR)$(DRACUTMODDIR)/
-@@ -25,4 +31,9 @@
+@@ -25,4 +31,9 @@ install:
$(INSTALL) -m 755 -d $(DESTDIR)$(DRACUTMODDIR)/$(ZDEVKDUMPDIR)
$(INSTALL) -m 755 $(ZDEVKDUMPDIR)/module-setup.sh \
$(DESTDIR)$(DRACUTMODDIR)/$(ZDEVKDUMPDIR)/
diff --git a/s390-tools-sles12-create-filesystem-links.patch b/s390-tools-sles12-create-filesystem-links.patch
index 5052d3c..aefbac4 100644
--- a/s390-tools-sles12-create-filesystem-links.patch
+++ b/s390-tools-sles12-create-filesystem-links.patch
@@ -2,9 +2,11 @@
etc/udev/rules.d/59-dasd.rules | 10 +++++++++-
1 file changed, 9 insertions(+), 1 deletion(-)
---- a/etc/udev/rules.d/59-dasd.rules
-+++ b/etc/udev/rules.d/59-dasd.rules
-@@ -15,7 +15,7 @@
+Index: s390-tools-2.29.0/etc/udev/rules.d/59-dasd.rules
+===================================================================
+--- s390-tools-2.29.0.orig/etc/udev/rules.d/59-dasd.rules
++++ s390-tools-2.29.0/etc/udev/rules.d/59-dasd.rules
+@@ -15,7 +15,7 @@ KERNEL=="dasd*[!0-9]", ENV{ID_XUID}=="?*
LABEL="dasd_block_end"
@@ -13,7 +15,7 @@
# for partitions import parent information
KERNEL=="dasd*[0-9]", IMPORT{parent}=="ID_*"
-@@ -24,6 +24,14 @@
+@@ -24,6 +24,14 @@ KERNEL=="dasd*[0-9]", ENV{ID_SERIAL}=="?
KERNEL=="dasd*[0-9]", ENV{ID_UID}=="?*", SYMLINK+="disk/by-id/$env{ID_BUS}-$env{ID_UID}-part%n"
KERNEL=="dasd*[0-9]", ENV{ID_XUID}=="?*", SYMLINK+="disk/by-id/$env{ID_BUS}-$env{ID_XUID}-part%n"
diff --git a/s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch b/s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
index 16e2a0d..49a2123 100644
--- a/s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
+++ b/s390-tools-sles12-fdasd-skip-partition-check-and-BLKRRPART-ioctl.patch
@@ -15,9 +15,11 @@ Signed-off-by: Hannes Reinecke
fdasd/fdasd.c | 4 +++-
1 file changed, 3 insertions(+), 1 deletion(-)
---- a/fdasd/fdasd.c
-+++ b/fdasd/fdasd.c
-@@ -1231,10 +1231,12 @@
+Index: s390-tools-2.29.0/fdasd/fdasd.c
+===================================================================
+--- s390-tools-2.29.0.orig/fdasd/fdasd.c
++++ s390-tools-2.29.0/fdasd/fdasd.c
+@@ -1231,10 +1231,12 @@ static int fdasd_get_volser(fdasd_anchor
*/
static void fdasd_reread_partition_table(fdasd_anchor_t *anc)
{
diff --git a/s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch.suse b/s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch.suse
index d8ec409..9c6a1d7 100644
--- a/s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch.suse
+++ b/s390-tools-sles12-update-by_id-links-on-change-and-add-action.patch.suse
@@ -13,8 +13,10 @@ Signed-off-by: Robert Milasan
etc/udev/rules.d/59-dasd.rules | 2 +-
1 file changed, 1 insertion(+), 1 deletion(-)
---- a/etc/udev/rules.d/59-dasd.rules
-+++ b/etc/udev/rules.d/59-dasd.rules
+Index: s390-tools-2.29.0/etc/udev/rules.d/59-dasd.rules
+===================================================================
+--- s390-tools-2.29.0.orig/etc/udev/rules.d/59-dasd.rules
++++ s390-tools-2.29.0/etc/udev/rules.d/59-dasd.rules
@@ -6,7 +6,7 @@
SUBSYSTEM!="block", GOTO="dasd_symlinks_end"
KERNEL!="dasd*", GOTO="dasd_symlinks_end"
diff --git a/s390-tools-sles12-zipl_boot_msg.patch b/s390-tools-sles12-zipl_boot_msg.patch
index 4cd2231..158455e 100644
--- a/s390-tools-sles12-zipl_boot_msg.patch
+++ b/s390-tools-sles12-zipl_boot_msg.patch
@@ -2,9 +2,11 @@
zipl/boot/menu.c | 7 +++++--
1 file changed, 5 insertions(+), 2 deletions(-)
---- a/zipl/boot/menu.c
-+++ b/zipl/boot/menu.c
-@@ -168,8 +168,11 @@
+Index: s390-tools-2.29.0/zipl/boot/menu.c
+===================================================================
+--- s390-tools-2.29.0.orig/zipl/boot/menu.c
++++ s390-tools-2.29.0/zipl/boot/menu.c
+@@ -168,8 +168,11 @@ int menu(void)
/* print config list */
menu_list();
diff --git a/s390-tools-sles15-sysconfig-compatible-dumpconf.patch b/s390-tools-sles15-sysconfig-compatible-dumpconf.patch
index 510ba60..fca4db9 100644
--- a/s390-tools-sles15-sysconfig-compatible-dumpconf.patch
+++ b/s390-tools-sles15-sysconfig-compatible-dumpconf.patch
@@ -2,8 +2,10 @@
etc/sysconfig/dumpconf | 162 ++++++++++++++++++++++++++++++++++---------------
1 file changed, 114 insertions(+), 48 deletions(-)
---- a/etc/sysconfig/dumpconf
-+++ b/etc/sysconfig/dumpconf
+Index: s390-tools-2.29.0/etc/sysconfig/dumpconf
+===================================================================
+--- s390-tools-2.29.0.orig/etc/sysconfig/dumpconf
++++ s390-tools-2.29.0/etc/sysconfig/dumpconf
@@ -1,71 +1,137 @@
+## Path: System/Dumpconf
+## Description: Configures the actions which should be performed after a kernel panic
diff --git a/s390-tools-sles15sp1-11-zdev-Do-not-call-zipl-on-initrd-update.patch b/s390-tools-sles15sp1-11-zdev-Do-not-call-zipl-on-initrd-update.patch
index 4b32289..0572a92 100644
--- a/s390-tools-sles15sp1-11-zdev-Do-not-call-zipl-on-initrd-update.patch
+++ b/s390-tools-sles15sp1-11-zdev-Do-not-call-zipl-on-initrd-update.patch
@@ -35,9 +35,11 @@ Signed-off-by: Peter Oberparleiter
zdev/src/zdev-root-update.dracut | 6 ------
1 file changed, 6 deletions(-)
---- a/zdev/src/zdev-root-update.dracut
-+++ b/zdev/src/zdev-root-update.dracut
-@@ -20,10 +20,4 @@
+Index: s390-tools-2.29.0/zdev/src/zdev-root-update.dracut
+===================================================================
+--- s390-tools-2.29.0.orig/zdev/src/zdev-root-update.dracut
++++ s390-tools-2.29.0/zdev/src/zdev-root-update.dracut
+@@ -20,10 +20,4 @@ dracut -f || {
exit 1
}
diff --git a/s390-tools-sles15sp3-Allow-multiple-device-arguments.patch b/s390-tools-sles15sp3-Allow-multiple-device-arguments.patch
index bca6b59..aead870 100644
--- a/s390-tools-sles15sp3-Allow-multiple-device-arguments.patch
+++ b/s390-tools-sles15sp3-Allow-multiple-device-arguments.patch
@@ -11,9 +11,11 @@ Signed-off-by: Hannes Reinecke
dasdfmt/dasdfmt.c | 197 +++++++++++++++++++++++++++++++-----------------------
2 files changed, 119 insertions(+), 83 deletions(-)
---- a/dasdfmt/dasdfmt.8
-+++ b/dasdfmt/dasdfmt.8
-@@ -11,14 +11,15 @@
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.8
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.8
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.8
+@@ -11,14 +11,15 @@ dasdfmt \- formatting of DASD (ECKD) dis
.br
[-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
.br
@@ -31,8 +33,10 @@ Signed-off-by: Hannes Reinecke
.br
\fBWARNING\fR: Careless usage of \fBdasdfmt\fR can result in
---- a/dasdfmt/dasdfmt.c
-+++ b/dasdfmt/dasdfmt.c
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.c
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.c
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.c
@@ -25,6 +25,8 @@
#include "dasdfmt.h"
@@ -42,7 +46,7 @@ Signed-off-by: Hannes Reinecke
#define BUSIDSIZE 8
#define SEC_PER_DAY (60 * 60 * 24)
#define SEC_PER_HOUR (60 * 60)
-@@ -57,7 +59,9 @@
+@@ -57,7 +59,9 @@ static const struct util_prg prg = {
static struct dasdfmt_globals {
dasd_information2_t dasd_info;
char *dev_path; /* device path entered by user */
@@ -52,7 +56,7 @@ Signed-off-by: Hannes Reinecke
int verbosity;
int testmode;
int withoutprompt;
-@@ -484,15 +488,15 @@
+@@ -484,15 +488,15 @@ static void program_interrupt_signal(int
program_interrupt_in_progress = 1;
if (disk_disabled) {
@@ -71,7 +75,7 @@ Signed-off-by: Hannes Reinecke
} else {
printf("Exiting...\n");
}
-@@ -512,9 +516,6 @@
+@@ -512,9 +516,6 @@ static void get_device_name(int optind,
unsigned int maj, min;
struct stat dev_stat;
@@ -81,7 +85,7 @@ Signed-off-by: Hannes Reinecke
if (optind >= argc)
error("No device specified!");
-@@ -610,10 +611,10 @@
+@@ -610,10 +611,10 @@ static void check_disk(void)
error("the ioctl call to retrieve read/write status information failed: %s",
strerror(err));
if (ro)
@@ -94,7 +98,7 @@ Signed-off-by: Hannes Reinecke
}
if (strncmp(g.dasd_info.type, "ECKD", 4) != 0) {
warnx("Unsupported disk type");
-@@ -700,7 +701,7 @@
+@@ -700,7 +701,7 @@ static void set_geo(unsigned int *cylind
struct dasd_eckd_characteristics *characteristics;
if (g.verbosity > 0)
@@ -103,7 +107,7 @@ Signed-off-by: Hannes Reinecke
characteristics = (struct dasd_eckd_characteristics *)
&g.dasd_info.characteristics;
-@@ -728,13 +729,13 @@
+@@ -728,13 +729,13 @@ static void set_label(volume_label_t *vl
"Cylinders above this limit will not be"
" accessible as a linux partition!\n"
"Type \"yes\" to continue, no will leave"
@@ -120,7 +124,7 @@ Signed-off-by: Hannes Reinecke
return;
}
}
-@@ -872,7 +873,7 @@
+@@ -872,7 +873,7 @@ static void check_disk_format(unsigned i
check_params->start_unit = 0;
check_params->stop_unit = (cylinders * heads) - 1;
@@ -129,7 +133,7 @@ Signed-off-by: Hannes Reinecke
if (g.testmode) {
printf("Test mode active, omitting ioctl.\n");
-@@ -896,7 +897,7 @@
+@@ -896,7 +897,7 @@ static void check_disk_format(unsigned i
if (process_tracks(cylinders, heads, check_params))
error("Use --mode=full to perform a clean format.");
@@ -138,7 +142,7 @@ Signed-off-by: Hannes Reinecke
}
/*
-@@ -946,8 +947,8 @@
+@@ -946,8 +947,8 @@ static void dasdfmt_print_info(volume_la
printf("Device Type: %s Provisioned\n",
g.ese ? "Thinly" : "Fully");
@@ -149,7 +153,7 @@ Signed-off-by: Hannes Reinecke
printf(" Device number of device : 0x%x\n", g.dasd_info.devno);
printf(" Labelling device : %s\n",
(g.writenolabel) ? "no" : "yes");
-@@ -1012,7 +1013,7 @@
+@@ -1012,7 +1013,7 @@ static void dasdfmt_write_labels(volume_
int ipl1_record_len, ipl2_record_len;
if (g.verbosity > 0)
@@ -158,7 +162,7 @@ Signed-off-by: Hannes Reinecke
get_blocksize(&blksize);
-@@ -1030,7 +1031,7 @@
+@@ -1030,7 +1031,7 @@ static void dasdfmt_write_labels(volume_
/* write empty bootstrap (initial IPL records) */
if (g.verbosity > 0)
@@ -167,7 +171,7 @@ Signed-off-by: Hannes Reinecke
/*
* Note: ldl labels do not contain the key field
-@@ -1089,7 +1090,7 @@
+@@ -1089,7 +1090,7 @@ static void dasdfmt_write_labels(volume_
label_position = g.dasd_info.label_block * blksize;
if (g.verbosity > 0)
@@ -176,7 +180,7 @@ Signed-off-by: Hannes Reinecke
rc = lseek(fd, label_position, SEEK_SET);
if (rc != label_position) {
-@@ -1120,7 +1121,7 @@
+@@ -1120,7 +1121,7 @@ static void dasdfmt_write_labels(volume_
}
if (g.verbosity > 0)
@@ -185,7 +189,7 @@ Signed-off-by: Hannes Reinecke
label_position = (VTOC_START_CC * heads + VTOC_START_HH) *
geo.sectors * blksize;
-@@ -1242,7 +1243,7 @@
+@@ -1242,7 +1243,7 @@ static int dasdfmt_release_space(void)
if (!g.ese || g.no_discard)
return 0;
@@ -194,7 +198,7 @@ Signed-off-by: Hannes Reinecke
err = dasd_release_space(g.dev_node, &r);
/*
* Warn or Error on failing RAS depending on QUICK mode set explicitly or automatically
-@@ -1270,20 +1271,21 @@
+@@ -1270,20 +1271,21 @@ static void dasdfmt_prepare_and_format(u
int err;
if (!(g.withoutprompt && g.verbosity < 1))
@@ -221,7 +225,7 @@ Signed-off-by: Hannes Reinecke
/* except track 0 from standard formatting procss */
p->start_unit = 1;
-@@ -1291,19 +1293,19 @@
+@@ -1291,19 +1293,19 @@ static void dasdfmt_prepare_and_format(u
process_tracks(cylinders, heads, p);
if (g.verbosity > 0)
@@ -244,7 +248,7 @@ Signed-off-by: Hannes Reinecke
disk_enable();
}
-@@ -1315,18 +1317,18 @@
+@@ -1315,18 +1317,18 @@ static void dasdfmt_expand_format(unsign
format_data_t *p)
{
if (!(g.withoutprompt && g.verbosity < 1))
@@ -267,7 +271,7 @@ Signed-off-by: Hannes Reinecke
if (g.verbosity > 0)
printf("Re-accessing the device...\n");
-@@ -1435,16 +1437,16 @@
+@@ -1435,16 +1437,16 @@ static void do_format_dasd(volume_label_
if (!g.withoutprompt) {
printf("\n");
if (mode != EXPAND)
@@ -288,7 +292,7 @@ Signed-off-by: Hannes Reinecke
return;
}
}
-@@ -1466,12 +1468,12 @@
+@@ -1466,12 +1468,12 @@ static void do_format_dasd(volume_label_
break;
}
@@ -303,7 +307,7 @@ Signed-off-by: Hannes Reinecke
err = dasd_reread_partition_table(g.dev_node, 5);
if (err != 0) {
ERRMSG("%s: error during rereading the partition "
-@@ -1485,7 +1487,7 @@
+@@ -1485,7 +1487,7 @@ static void do_format_dasd(volume_label_
static void eval_format_mode(void)
{
if (!g.force && g.mode_specified && g.ese && mode == EXPAND) {
@@ -312,7 +316,7 @@ Signed-off-by: Hannes Reinecke
warnx("Format mode 'expand' is not feasible.");
error("Use --mode=full or --mode=quick to perform a clean format");
}
-@@ -1508,20 +1510,70 @@
+@@ -1508,20 +1510,70 @@ static void set_prog_name(char *s)
prog_name = p + 1;
}
@@ -387,7 +391,7 @@ Signed-off-by: Hannes Reinecke
/* Establish a handler for interrupt signals. */
signal(SIGTERM, program_interrupt_signal);
-@@ -1657,6 +1709,9 @@
+@@ -1657,6 +1709,9 @@ int main(int argc, char *argv[])
break; /* exit loop if finished */
}
@@ -397,7 +401,7 @@ Signed-off-by: Hannes Reinecke
CHECK_SPEC_MAX_ONCE(g.blksize_specified, "blocksize");
CHECK_SPEC_MAX_ONCE(g.labelspec, "label");
CHECK_SPEC_MAX_ONCE(g.writenolabel, "omit-label-writing flag");
-@@ -1675,48 +1730,28 @@
+@@ -1675,48 +1730,28 @@ int main(int argc, char *argv[])
if (g.print_hashmarks)
PARSE_PARAM_INTO(g.hashstep, hashstep_str, 10, "hashstep");
diff --git a/s390-tools-sles15sp3-Format-devices-in-parallel.patch b/s390-tools-sles15sp3-Format-devices-in-parallel.patch
index 94606ee..5d67800 100644
--- a/s390-tools-sles15sp3-Format-devices-in-parallel.patch
+++ b/s390-tools-sles15sp3-Format-devices-in-parallel.patch
@@ -11,8 +11,10 @@ Signed-off-by: Hannes Reinecke
dasdfmt/dasdfmt.c | 58 ++++++++++++++++++++++++++++++++++++++++++------------
2 files changed, 60 insertions(+), 14 deletions(-)
---- a/dasdfmt/dasdfmt.8
-+++ b/dasdfmt/dasdfmt.8
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.8
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.8
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.8
@@ -7,7 +7,7 @@
dasdfmt \- formatting of DASD (ECKD) disk drives.
@@ -22,7 +24,7 @@ Signed-off-by: Hannes Reinecke
.br
[-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
.br
-@@ -96,7 +96,7 @@
+@@ -96,7 +96,7 @@ Do not use this option if you are using
running in background or redirecting the output to a file.
.TP
@@ -31,7 +33,7 @@ Signed-off-by: Hannes Reinecke
Print one line for each formatted cylinder showing the number of the
cylinder and percentage of formatting process.
Intended to be used by higher level interfaces.
-@@ -164,6 +164,18 @@
+@@ -164,6 +164,18 @@ Specify blocksize to be used. \fIblksize
and always be a power of two. The recommended blocksize is 4096 bytes.
.TP
@@ -50,8 +52,10 @@ Signed-off-by: Hannes Reinecke
\fB-l\fR \fIvolser\fR or \fB--label\fR=\fIvolser\fR
Specify the volume serial number or volume identifier to be written
to disk after formatting. If no label is specified, a sensible default
---- a/dasdfmt/dasdfmt.c
-+++ b/dasdfmt/dasdfmt.c
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.c
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.c
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.c
@@ -13,6 +13,7 @@
#include
#include
@@ -60,7 +64,7 @@ Signed-off-by: Hannes Reinecke
#include "lib/dasd_base.h"
#include "lib/dasd_sys.h"
-@@ -81,6 +82,7 @@
+@@ -81,6 +82,7 @@ static struct dasdfmt_globals {
int mode_specified;
int ese;
int no_discard;
@@ -68,7 +72,7 @@ Signed-off-by: Hannes Reinecke
} g = {
.dasd_info = { 0 },
};
-@@ -105,6 +107,11 @@
+@@ -105,6 +107,11 @@ static struct util_opt opt_vec[] = {
.desc = "Perform complete format check on device",
.flags = UTIL_OPT_FLAG_NOSHORT,
},
@@ -80,7 +84,7 @@ Signed-off-by: Hannes Reinecke
UTIL_OPT_SECTION("FORMAT OPTIONS"),
{
.option = { "blocksize", required_argument, NULL, 'b' },
-@@ -162,7 +169,7 @@
+@@ -162,7 +169,7 @@ static struct util_opt opt_vec[] = {
.desc = "Show a progressbar",
},
{
@@ -89,7 +93,7 @@ Signed-off-by: Hannes Reinecke
.desc = "Show progress in percent",
},
UTIL_OPT_SECTION("MISC"),
-@@ -311,7 +318,7 @@
+@@ -311,7 +318,7 @@ static void draw_progress(int cyl, unsig
}
if (g.print_hashmarks && (cyl / g.hashstep - hashcount) != 0) {
@@ -98,7 +102,7 @@ Signed-off-by: Hannes Reinecke
fflush(stdout);
hashcount++;
}
-@@ -1573,7 +1580,11 @@
+@@ -1573,7 +1580,11 @@ int main(int argc, char *argv[])
char *reqsize_param_str = NULL;
char *hashstep_str = NULL;
@@ -111,7 +115,7 @@ Signed-off-by: Hannes Reinecke
/* Establish a handler for interrupt signals. */
signal(SIGTERM, program_interrupt_signal);
-@@ -1636,7 +1647,7 @@
+@@ -1636,7 +1647,7 @@ int main(int argc, char *argv[])
g.print_hashmarks = 1;
}
break;
@@ -120,7 +124,7 @@ Signed-off-by: Hannes Reinecke
if (!(g.print_hashmarks || g.print_progressbar))
g.print_percentage = 1;
break;
-@@ -1695,6 +1706,9 @@
+@@ -1695,6 +1706,9 @@ int main(int argc, char *argv[])
case OPT_NODISCARD:
g.no_discard = 1;
break;
@@ -130,7 +134,7 @@ Signed-off-by: Hannes Reinecke
case OPT_CHECK:
g.check = 1;
break;
-@@ -1746,15 +1760,35 @@
+@@ -1746,15 +1760,35 @@ int main(int argc, char *argv[])
if (numdev > 1 && g.labelspec)
error("Specifying a volser to be written doesn't make sense when formatting multiple DASD volumes.");
diff --git a/s390-tools-sles15sp3-Implement-Y-yast_mode.patch b/s390-tools-sles15sp3-Implement-Y-yast_mode.patch
index 3c7a5f5..4cabd78 100644
--- a/s390-tools-sles15sp3-Implement-Y-yast_mode.patch
+++ b/s390-tools-sles15sp3-Implement-Y-yast_mode.patch
@@ -11,8 +11,10 @@ Signed-off-by: Hannes Reinecke
dasdfmt/dasdfmt.c | 73 ++++++++++++++++++++++++++++++++++++++++++++++++------
2 files changed, 72 insertions(+), 8 deletions(-)
---- a/dasdfmt/dasdfmt.8
-+++ b/dasdfmt/dasdfmt.8
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.8
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.8
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.8
@@ -7,7 +7,7 @@
dasdfmt \- formatting of DASD (ECKD) disk drives.
@@ -22,7 +24,7 @@ Signed-off-by: Hannes Reinecke
.br
[-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
.br
-@@ -113,6 +113,11 @@
+@@ -113,6 +113,11 @@ The value will be at least as big as the
.br
.TP
@@ -34,9 +36,11 @@ Signed-off-by: Hannes Reinecke
\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
---- a/dasdfmt/dasdfmt.c
-+++ b/dasdfmt/dasdfmt.c
-@@ -83,6 +83,7 @@
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.c
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.c
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.c
+@@ -83,6 +83,7 @@ static struct dasdfmt_globals {
int ese;
int no_discard;
int procnum;
@@ -44,7 +48,7 @@ Signed-off-by: Hannes Reinecke
} g = {
.dasd_info = { 0 },
};
-@@ -172,6 +173,10 @@
+@@ -172,6 +173,10 @@ static struct util_opt opt_vec[] = {
.option = { "percentage", no_argument, NULL, 'Q' },
.desc = "Show progress in percent",
},
@@ -55,7 +59,7 @@ Signed-off-by: Hannes Reinecke
UTIL_OPT_SECTION("MISC"),
{
.option = { "check_host_count", no_argument, NULL, 'C' },
-@@ -318,7 +323,9 @@
+@@ -318,7 +323,9 @@ static void draw_progress(int cyl, unsig
}
if (g.print_hashmarks && (cyl / g.hashstep - hashcount) != 0) {
@@ -66,7 +70,7 @@ Signed-off-by: Hannes Reinecke
fflush(stdout);
hashcount++;
}
-@@ -392,7 +399,7 @@
+@@ -392,7 +399,7 @@ static void evaluate_format_error(format
unsigned int kl = 0;
int blksize = cdata->expect.blksize;
@@ -75,7 +79,7 @@ Signed-off-by: Hannes Reinecke
printf("\n");
/*
-@@ -780,8 +787,9 @@
+@@ -780,8 +787,9 @@ static void check_hashmarks(void)
g.hashstep = 10;
}
@@ -87,7 +91,7 @@ Signed-off-by: Hannes Reinecke
}
}
-@@ -1475,17 +1483,19 @@
+@@ -1475,17 +1483,19 @@ static void do_format_dasd(volume_label_
break;
}
@@ -110,7 +114,7 @@ Signed-off-by: Hannes Reinecke
printf("ok\n");
}
}
-@@ -1561,6 +1571,7 @@
+@@ -1561,6 +1571,7 @@ void process_dasd(volume_label_t *orig_v
error("%s", str);
set_geo(&cylinders, &heads);
@@ -118,7 +122,7 @@ Signed-off-by: Hannes Reinecke
set_label(&vlabel, &format_params, cylinders);
if (g.check)
-@@ -1570,6 +1581,29 @@
+@@ -1570,6 +1581,29 @@ void process_dasd(volume_label_t *orig_v
}
@@ -148,7 +152,7 @@ Signed-off-by: Hannes Reinecke
int main(int argc, char *argv[])
{
volume_label_t vlabel;
-@@ -1706,6 +1740,10 @@
+@@ -1706,6 +1740,10 @@ int main(int argc, char *argv[])
case OPT_NODISCARD:
g.no_discard = 1;
break;
@@ -159,7 +163,7 @@ Signed-off-by: Hannes Reinecke
case 'P':
max_parallel = atoi(optarg);
break;
-@@ -1741,6 +1779,21 @@
+@@ -1741,6 +1779,21 @@ int main(int argc, char *argv[])
reqsize = DEFAULT_REQUESTSIZE;
}
@@ -181,7 +185,7 @@ Signed-off-by: Hannes Reinecke
if (g.print_hashmarks)
PARSE_PARAM_INTO(g.hashstep, hashstep_str, 10, "hashstep");
-@@ -1760,6 +1813,12 @@
+@@ -1760,6 +1813,12 @@ int main(int argc, char *argv[])
if (numdev > 1 && g.labelspec)
error("Specifying a volser to be written doesn't make sense when formatting multiple DASD volumes.");
diff --git a/s390-tools-sles15sp3-Implement-f-for-backwards-compability.patch b/s390-tools-sles15sp3-Implement-f-for-backwards-compability.patch
index 0f48337..ef1c322 100644
--- a/s390-tools-sles15sp3-Implement-f-for-backwards-compability.patch
+++ b/s390-tools-sles15sp3-Implement-f-for-backwards-compability.patch
@@ -13,9 +13,11 @@ Signed-off-by: Hannes Reinecke
dasdfmt/dasdfmt.c | 10 ++++++++++
2 files changed, 15 insertions(+), 1 deletion(-)
---- a/dasdfmt/dasdfmt.8
-+++ b/dasdfmt/dasdfmt.8
-@@ -11,7 +11,7 @@
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.8
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.8
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.8
+@@ -11,7 +11,7 @@ dasdfmt \- formatting of DASD (ECKD) dis
.br
[-r \fIcylinder\fR] [-b \fIblksize\fR] [-l \fIvolser\fR] [-d \fIlayout\fR]
.br
@@ -24,7 +26,7 @@ Signed-off-by: Hannes Reinecke
.SH DESCRIPTION
\fBdasdfmt\fR formats one or several DASD (ECKD) disk drive to prepare it
-@@ -42,6 +42,10 @@
+@@ -42,6 +42,10 @@ out, what it \fBwould\fR do.
Increases verbosity.
.TP
@@ -35,9 +37,11 @@ Signed-off-by: Hannes Reinecke
\fB-y\fR
Start formatting without further user-confirmation.
---- a/dasdfmt/dasdfmt.c
-+++ b/dasdfmt/dasdfmt.c
-@@ -113,6 +113,10 @@
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.c
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.c
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.c
+@@ -113,6 +113,10 @@ static struct util_opt opt_vec[] = {
.desc = "Format devices in parallel",
.flags = UTIL_OPT_FLAG_NOLONG,
},
@@ -48,7 +52,7 @@ Signed-off-by: Hannes Reinecke
UTIL_OPT_SECTION("FORMAT OPTIONS"),
{
.option = { "blocksize", required_argument, NULL, 'b' },
-@@ -1662,6 +1666,12 @@
+@@ -1662,6 +1666,12 @@ int main(int argc, char *argv[])
}
g.layout_specified = 1;
break;
diff --git a/s390-tools-sles15sp3-dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch b/s390-tools-sles15sp3-dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch
index f0e79a5..e8350e3 100644
--- a/s390-tools-sles15sp3-dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch
+++ b/s390-tools-sles15sp3-dasdfmt-retry-BIODASDINFO-if-device-is-busy.patch
@@ -19,9 +19,11 @@ Signed-off-by: Hannes Reinecke
dasdfmt/dasdfmt.c | 19 ++++++++++++++++++-
1 file changed, 18 insertions(+), 1 deletion(-)
---- a/dasdfmt/dasdfmt.c
-+++ b/dasdfmt/dasdfmt.c
-@@ -621,7 +621,7 @@
+Index: s390-tools-2.29.0/dasdfmt/dasdfmt.c
+===================================================================
+--- s390-tools-2.29.0.orig/dasdfmt/dasdfmt.c
++++ s390-tools-2.29.0/dasdfmt/dasdfmt.c
+@@ -621,7 +621,7 @@ static void check_layout(unsigned int in
*/
static void check_disk(void)
{
@@ -30,7 +32,7 @@ Signed-off-by: Hannes Reinecke
bool ro;
err = dasd_is_ro(g.dev_node, &ro);
-@@ -631,6 +631,23 @@
+@@ -631,6 +631,23 @@ static void check_disk(void)
if (ro)
error("Disk %s is read only!", g.dev_path);
if (!g.force) {
diff --git a/s390-tools-sles15sp5-remove-no-pie-link-arguments.patch b/s390-tools-sles15sp5-remove-no-pie-link-arguments.patch
index 3aef336..4a62335 100644
--- a/s390-tools-sles15sp5-remove-no-pie-link-arguments.patch
+++ b/s390-tools-sles15sp5-remove-no-pie-link-arguments.patch
@@ -2,9 +2,11 @@
common.mak | 4 ++--
1 file changed, 2 insertions(+), 2 deletions(-)
---- a/common.mak
-+++ b/common.mak
-@@ -328,8 +328,8 @@
+Index: s390-tools-2.29.0/common.mak
+===================================================================
+--- s390-tools-2.29.0.orig/common.mak
++++ s390-tools-2.29.0/common.mak
+@@ -338,8 +338,8 @@ export INSTALL CFLAGS CXXFLAGS \
LDFLAGS CPPFLAGS ALL_CFLAGS ALL_CXXFLAGS ALL_LDFLAGS ALL_CPPFLAGS
ifneq ($(shell $(CC_SILENT) -dumpspecs 2>/dev/null | grep -e '[^f]no-pie'),)
diff --git a/s390-tools.changes b/s390-tools.changes
index 8c7869a..7d2aec5 100644
--- a/s390-tools.changes
+++ b/s390-tools.changes
@@ -1,3 +1,31 @@
+-------------------------------------------------------------------
+Mon Aug 28 15:52:15 UTC 2023 - Nikolay Gueorguiev
+
+- Amended read_value.c for newer z16 models (bsc#1214534)
+
+-------------------------------------------------------------------
+Tue Aug 8 08:00:14 UTC 2023 - Nikolay Gueorguiev
+
+- Upgrade to version 2.29.0 (jsc#PED-3275)
+ * s390-tools now supports tools written in Rust.
+ * Add compdb Makefile target to create 'compile_commands.json' to support LSP
+ backends in IDEs and editors
+- Add new tools / libraries:
+ * rust/pv: Library for pv tools written in rust
+ * rust/pvsecret: Tool to manage UV-secrets
+- Changes of existing tools:
+ * dbginfo.sh: Global IFS variable
+ * genprotimg: Add support for add-secret requests
+ * genprotimg: Build debuginfo files for bootloader
+ * hyptop: Add real SMT utilization field
+ * hyptop: Allow users to set speedup factor
+ * pvattest: Add yaml-output for verify command
+ * zipl: Build debuginfo files for bootloader
+- Bug Fixes:
+ * dump2tar: Fix truncated paths
+ * zdev/dracut: fix kdump build to integrate with site support
+- Amended .spec for version 2.29.0, including Rust integration
+
-------------------------------------------------------------------
Wed Jun 14 11:24:27 UTC 2023 - Nikolay Gueorguiev
diff --git a/s390-tools.spec b/s390-tools.spec
index a6c3459..f0782c5 100644
--- a/s390-tools.spec
+++ b/s390-tools.spec
@@ -33,7 +33,7 @@
%endif
Name: s390-tools
-Version: 2.27.0
+Version: 2.29.0
Release: 0
Summary: S/390 tools like zipl and dasdfmt
License: MIT
@@ -127,6 +127,9 @@ Source97: qeth_configure.8
Source98: zfcp_disk_configure.8
Source99: zfcp_host_configure.8
###
+Source200: cargo_config
+Source201: vendor.tar.gz
+###
# IBM patches
###
@@ -171,6 +174,12 @@ BuildRequires: qclib-devel-static
BuildRequires: systemd-devel
BuildRequires: tcpd-devel
BuildRequires: zlib-devel-static
+### Cargo
+BuildRequires: rust
+BuildRequires: cargo
+BuildRequires: cargo-packaging
+BuildRequires: openssl
+###
# Don't build with pie to avoid problems with zipl
#!BuildIgnore: gcc-PIE
Requires: coreutils
@@ -308,10 +317,19 @@ operational path.
%prep
%autosetup -p1
+#
cp -vi %{SOURCE22} CAUTION
+#
+
+###
+install -D -m 0644 %{SOURCE200} .cargo/config
+tar -xzvf %{SOURCE201}
+###
%build
+#
+#
# The "DISTRELEASE=%%{release}" needs to be on both the make and make install
# commands, since make install runs sed commands against various scripts to
# modify the "-v" output appropriately.
@@ -322,10 +340,13 @@ export KERNELIMAGE_MAKEFLAGS="%%{?_smp_mflags}"
ZFCPDUMP_DIR=%{_prefix}/lib/s390-tools/zfcpdump \
DISTRELEASE=%{release} \
UDEVRUNDIR=/run/udev \
+ HAVE_CARGO=1 \
HAVE_DRACUT=1
gcc -static -o read_values ${OPT_FLAGS} %{SOURCE86} -lqc
%install
+
+#
mkdir -p %{buildroot}/boot/zipl
mkdir -p %{buildroot}%{_sysconfdir}/zkey/repository
%make_install \
@@ -333,6 +354,7 @@ mkdir -p %{buildroot}%{_sysconfdir}/zkey/repository
DISTRELEASE=%{release} \
SYSTEMDSYSTEMUNITDIR=%{_unitdir} \
UDEVRUNDIR=/run/udev \
+ HAVE_CARGO=1 \
HAVE_DRACUT=1
# The make install command puts things in /etc/sysconfig and not the
@@ -422,7 +444,7 @@ if [ ! -d %{_bindir} ]; then
fi
install -D -m755 %{SOURCE24} %{buildroot}%{_bindir}/cputype
-install -m644 -t %{buildroot}/%{_mandir}/man8 %{SOURCE25}
+install -m644 -t %{buildroot}/%{_mandir}/man1 %{SOURCE25}
# If building for openSUSE, move all the binaries installed via
# the IBM-provided Makefile from /sbin to /usr/sbin/ to
diff --git a/vendor.tar.gz b/vendor.tar.gz
new file mode 100644
index 0000000..d8bf27d
--- /dev/null
+++ b/vendor.tar.gz
@@ -0,0 +1,3 @@
+version https://git-lfs.github.com/spec/v1
+oid sha256:d233de3dd3d74e7ce6fdedd99f6f0cc70ed80fe78b01c9321ca459ce06a7469c
+size 37524839