From 43a9af660e178856d5aedf1dba2d59ae2c85d1cb0e7aa3d62e6012ee46262f86 Mon Sep 17 00:00:00 2001 From: Jean Delvare Date: Fri, 24 May 2024 11:59:11 +0000 Subject: [PATCH] Accepting request 1175720 from home:jdelvare:branches:Base:System - Update to upstream version 3.6: * Support for SMBIOS 3.6.0. This includes new memory device types, new processor upgrades, and Loongarch support. * Support for SMBIOS 3.7.0. This includes new port types, new processor upgrades, new slot characteristics and new fields for memory modules. * Add bash completion. * Decode HPE OEM records 197, 239 and 245. * Implement options --list-strings and --list-types. * Update HPE OEM records 203, 212, 216, 221, 233, 236, 238 and 242. * Update Redfish support. * Bug fixes: Fix enabled slot characteristics not being printed * Minor improvements: Print slot width on its own line Use standard strings for slot width * Obsoletes arm-use-alignment-workaround.patch, dmioem-hpe-oem-record-237-firmware-change.patch and use-read_file-to-read-from-dump.patch. - dmioem-update-hpe-oem-type-238.patch: Decode PCI bus segment in HPE type 238 records. - Drop legacy Provides: and Obsoletes: tags. The split from the pmtools package happened 15 years ago so they are no longer relevant. OBS-URL: https://build.opensuse.org/request/show/1175720 OBS-URL: https://build.opensuse.org/package/show/Base:System/dmidecode?expand=0&rev=75 --- arm-use-alignment-workaround.patch | 25 -------- dmidecode-3.5.tar.xz | 3 - dmidecode-3.5.tar.xz.sig | Bin 566 -> 0 bytes dmidecode-3.6.tar.xz | 3 + dmidecode-3.6.tar.xz.sig | Bin 0 -> 566 bytes dmidecode.changes | 33 ++++++++++ dmidecode.spec | 13 ++-- ...m-hpe-oem-record-237-firmware-change.patch | 39 ------------ dmioem-update-hpe-oem-type-238.patch | 39 ++++++++++++ use-read_file-to-read-from-dump.patch | 58 ------------------ 10 files changed, 81 insertions(+), 132 deletions(-) delete mode 100644 arm-use-alignment-workaround.patch delete mode 100644 dmidecode-3.5.tar.xz delete mode 100644 dmidecode-3.5.tar.xz.sig create mode 100644 dmidecode-3.6.tar.xz create mode 100644 dmidecode-3.6.tar.xz.sig delete mode 100644 dmioem-hpe-oem-record-237-firmware-change.patch create mode 100644 dmioem-update-hpe-oem-type-238.patch delete mode 100644 use-read_file-to-read-from-dump.patch diff --git a/arm-use-alignment-workaround.patch b/arm-use-alignment-workaround.patch deleted file mode 100644 index 633e5ce..0000000 --- a/arm-use-alignment-workaround.patch +++ /dev/null @@ -1,25 +0,0 @@ -From: Jean Delvare -Subject: Use -DALIGNMENT_WORKAROUND on arm as well -Git-commit: a85ed8540993f4cba831e1d1d0224ba6640d9c4b - -The arm build log shows a lot warnings about casts increasing the -required alignment of target type. This suggests that this -architecture needs to use the slower byte access which is enabled by --DALIGNMENT_WORKAROUND. - -Signed-off-by: Jean Delvare ---- - config.h | 2 +- - 1 file changed, 1 insertion(+), 1 deletion(-) - ---- dmidecode-3.5.orig/config.h -+++ dmidecode-3.5/config.h -@@ -22,7 +22,7 @@ - #endif - - /* Use memory alignment workaround or not */ --#ifdef __ia64__ -+#if defined(__ia64__) || defined(__arm__) - #define ALIGNMENT_WORKAROUND - #endif - diff --git a/dmidecode-3.5.tar.xz b/dmidecode-3.5.tar.xz deleted file mode 100644 index 6d2397c..0000000 --- a/dmidecode-3.5.tar.xz +++ /dev/null @@ -1,3 +0,0 @@ -version https://git-lfs.github.com/spec/v1 -oid sha256:79d76735ee8e25196e2a722964cf9683f5a09581503537884b256b01389cc073 -size 65068 diff --git a/dmidecode-3.5.tar.xz.sig b/dmidecode-3.5.tar.xz.sig deleted file mode 100644 index 5d34c96e7962c4494b2f6d500e033d4fbbbe91d5067f52ea4dd8379d9d6d0722..0000000000000000000000000000000000000000000000000000000000000000 GIT binary patch literal 0 HcmV?d00001 literal 566 zcmV-60?GY}0y6{v0SEvc79j+Drk_M$@x8@&ucv?G`=hS}U5dxP zaGW>rA&_l7k&y`;fK$OH~cW5e$cS4`AMnNLOb9@{dYlu2V zc&s)W*CakG@+n?9iGPaGT_E>(IRJn{qvP<1Q-)sXuP1ukABTN7?Mb*>OETs$I^ zdB{-#znOhhm|7PJE5BHcd=IBq?Z(<5kbg48kQX{nfNqmS`~n9s>%`u2U?P`~he+x6 zYDLKvdwXuUKFFZrNUR4%g$0m4_`$L#K;>@UPz{DRLZx#j<4&BPyILxVUd^FD-DIJC zE$Q8*FeMza$J=KiU|9eu;qG&b;LS1AZ6hf@=b^#H3b)2Pd>U_^gOL`fa%Iwm=dy5GB814@M5uqk<4^Hvz>IyeVAu-yiEDuoI^~#OPY|ZP4KIh3dM-d zJ~+VkS-Vir?H%Vby9X0K;m*T$&87}Y(`GY@P&rOV7v z1YzrsTljeL-b^2gebs!-+(R$a&Bq9@ePsE0tfHnPrhnFMu2V^hLnP1LRUFwDH3YS; z^CLg3$6TQ9c9%=xpG9Nv=cNVNKA;&%eFoDCbW{DDPi4=St?-&Qo<3VVpO2Sfa&;(# z%c|sEoD>n}tbjy&MnGyA$spvLlCuM^odGTCKzR?pqMEb&`H*~Rc#f?y22tplKzhyg z41Na4bhr&?@?DXi4d4fk-J63OQ}`8bB4PcV^E~6!u;`bxwU&129;syYESff(Uvc{m zkUNn@%MqpOPCUe9?Eup8IzdPU=WHbPe2T2Uo%QrSzZ$QB+4u@~@_atr`B1~j@-nyl Eb>U_Yu>b%7 literal 0 HcmV?d00001 diff --git a/dmidecode.changes b/dmidecode.changes index ab187bf..0a85f0c 100644 --- a/dmidecode.changes +++ b/dmidecode.changes @@ -1,3 +1,36 @@ +------------------------------------------------------------------- +Sun May 19 15:19:23 UTC 2024 - Jean Delvare + +Update for HPE servers from upstream: +- dmioem-update-hpe-oem-type-238.patch: Decode PCI bus segment in + HPE type 238 records. + +- Drop legacy Provides: and Obsoletes: tags. The split from the + pmtools package happened 15 years ago so they are no longer + relevant. + +------------------------------------------------------------------- +Thu Apr 25 12:41:17 UTC 2024 - Jean Delvare + +- Update to upstream version 3.6: + * Support for SMBIOS 3.6.0. This includes new memory device types, new + processor upgrades, and Loongarch support. + * Support for SMBIOS 3.7.0. This includes new port types, new processor + upgrades, new slot characteristics and new fields for memory modules. + * Add bash completion. + * Decode HPE OEM records 197, 239 and 245. + * Implement options --list-strings and --list-types. + * Update HPE OEM records 203, 212, 216, 221, 233, 236, 238 and 242. + * Update Redfish support. + * Bug fixes: + Fix enabled slot characteristics not being printed + * Minor improvements: + Print slot width on its own line + Use standard strings for slot width + * Obsoletes arm-use-alignment-workaround.patch, + dmioem-hpe-oem-record-237-firmware-change.patch and + use-read_file-to-read-from-dump.patch. + ------------------------------------------------------------------- Mon Feb 26 07:51:57 UTC 2024 - Dominique Leuenberger diff --git a/dmidecode.spec b/dmidecode.spec index 7c46386..c6aba2a 100644 --- a/dmidecode.spec +++ b/dmidecode.spec @@ -1,7 +1,7 @@ # # spec file for package dmidecode # -# Copyright (c) 2023 SUSE LLC +# Copyright (c) 2024 SUSE LLC # # All modifications and additions to the file contributed by third parties # remain the property of their copyright owners, unless otherwise agreed @@ -17,7 +17,7 @@ Name: dmidecode -Version: 3.5 +Version: 3.6 Release: 0 Summary: DMI table decoder License: GPL-2.0-or-later @@ -27,11 +27,7 @@ Source0: http://download.savannah.gnu.org/releases/%{name}/%{name}-%{vers Source1: http://download.savannah.gnu.org/releases/%{name}/%{name}-%{version}.tar.xz.sig # https://savannah.nongnu.org/project/memberlist-gpgkeys.php?group=dmidecode Source2: %{name}.keyring -Patch1: arm-use-alignment-workaround.patch -Patch2: dmioem-hpe-oem-record-237-firmware-change.patch -Patch3: use-read_file-to-read-from-dump.patch -Provides: pmtools:%{_sbindir}/dmidecode -Obsoletes: pmtools < 20071117 +Patch1: dmioem-update-hpe-oem-type-238.patch BuildRoot: %{_tmppath}/%{name}-%{version}-build BuildRequires: xz ExclusiveArch: %ix86 ia64 x86_64 %arm aarch64 @@ -60,6 +56,7 @@ CFLAGS="%{optflags}" make %{?_smp_mflags} install -dm 755 %{buildroot}%{_sbindir} install -dm 755 %{buildroot}%{_mandir}/man8 install -dm 755 %{buildroot}%{_docdir}/%{name} +install -dm 755 %{buildroot}%{_datadir}/bash-completion/completions/ %ifarch ia64 %arm aarch64 for i in dmidecode ; do %else @@ -67,6 +64,7 @@ for i in dmidecode vpddecode ownership biosdecode ; do %endif install -m 755 $i %{buildroot}%{_sbindir}/ install -m 644 man/$i.8 %{buildroot}%{_mandir}/man8/ +install -m 644 completion/$i.bash %{buildroot}%{_datadir}/bash-completion/completions/$i done %files @@ -75,6 +73,7 @@ done %dir %{_docdir}/%{name} %doc AUTHORS NEWS README %{_mandir}/man8/* +%{_datadir}/bash-completion/completions/* %license LICENSE %changelog diff --git a/dmioem-hpe-oem-record-237-firmware-change.patch b/dmioem-hpe-oem-record-237-firmware-change.patch deleted file mode 100644 index 53b28f1..0000000 --- a/dmioem-hpe-oem-record-237-firmware-change.patch +++ /dev/null @@ -1,39 +0,0 @@ -From: Jerry Hoemann -Date: Mon, 3 Apr 2023 10:15:12 +0200 -Subject: dmioem: HPE OEM Record 237 Firmware change -Git-ommit: 80de376231e903d2cbea95e51ffea31860502159 - -HPE OEM record type 237 offset 0x09 field was changed from a single -byte STRING to a two byte WORD representing date. - -Fixes: cdab638dabb7 ("dmioem: Decode HPE OEM Record 237") -Signed-off-by: Jerry Hoemann -Signed-off-by: Jean Delvare ---- - dmioem.c | 8 +++++--- - 1 file changed, 5 insertions(+), 3 deletions(-) - ---- dmidecode-3.5.orig/dmioem.c -+++ dmidecode-3.5/dmioem.c -@@ -1094,7 +1094,8 @@ static int dmi_decode_hp(const struct dm - * 0x06 | Manufacture|STRING | DIMM Manufacturer - * 0x07 | Part Number|STRING | DIMM Manufacturer's Part Number - * 0x08 | Serial Num |STRING | DIMM Vendor Serial Number -- * 0x09 | Spare Part |STRING | DIMM Spare Part Number -+ * 0x09 | Man Date | BYTE | DIMM Manufacture Date (YEAR) in BCD -+ * 0x0A | Man Date | BYTE | DIMM Manufacture Date (WEEK) in BCD - */ - if (gen < G9) return 0; - pr_handle_name("%s DIMM Vendor Information", company); -@@ -1105,8 +1106,9 @@ static int dmi_decode_hp(const struct dm - pr_attr("DIMM Manufacturer Part Number", "%s", dmi_string(h, data[0x07])); - if (h->length < 0x09) break; - pr_attr("DIMM Vendor Serial Number", "%s", dmi_string(h, data[0x08])); -- if (h->length < 0x0A) break; -- pr_attr("DIMM Spare Part Number", "%s", dmi_string(h, data[0x09])); -+ if (h->length < 0x0B) break; -+ if (WORD(data + 0x09)) -+ pr_attr("DIMM Manufacture Date", "20%02x-W%02x", data[0x09], data[0x0A]); - break; - - case 238: diff --git a/dmioem-update-hpe-oem-type-238.patch b/dmioem-update-hpe-oem-type-238.patch new file mode 100644 index 0000000..1c0a7e0 --- /dev/null +++ b/dmioem-update-hpe-oem-type-238.patch @@ -0,0 +1,39 @@ +From: Jerry Hoemann +Date: Thu, 16 May 2024 13:12:43 +0200 +Subject: dmioem: Update HPE OEM Type 238 +Git-commit: 190a23ecfd6d743cb6efbc04bb4d95f0584fd68d +Patch-mainline: yes + +New field: PCI Segment Number. + +Signed-off-by: Jerry Hoemann +Signed-off-by: Jean Delvare +--- + dmioem.c | 10 ++++++++-- + 1 file changed, 8 insertions(+), 2 deletions(-) + +--- dmidecode-3.6.orig/dmioem.c ++++ dmidecode-3.6/dmioem.c +@@ -1346,14 +1346,20 @@ static int dmi_decode_hp(const struct dm + * 0x0C | Parent Hub | BYTE | Instance number of internal Hub + * 0x0D | Port Speed | BYTE | Enumerated value of speed configured by BIOS + * 0x0E | Device Path| STRING| UEFI Device Path of USB endpoint ++ * 0x0F | PCI Seg | WORD | PCI Segment number of the USB controller + */ + if (gen < G9) return 0; + pr_handle_name("%s Proliant USB Port Connector Correlation Record", company); + if (h->length < 0x0F) break; + if (!(opt.flags & FLAG_QUIET)) + pr_attr("Associated Handle", "0x%04X", WORD(data + 0x4)); +- pr_attr("PCI Device", "%02x:%02x.%x", data[0x6], +- data[0x7] >> 3, data[0x7] & 0x7); ++ if (h->length < 0x11) ++ pr_attr("PCI Device", "%02x:%02x.%x", data[0x6], ++ data[0x7] >> 3, data[0x7] & 0x7); ++ else ++ pr_attr("PCI Device", "%04x:%02x:%02x.%x", ++ WORD(data + 0xF), data[0x6], ++ data[0x7] >> 3, data[0x7] & 0x7); + dmi_hp_238_loc("Location", data[0x8]); + dmi_hp_238_flags("Management Port", WORD(data + 0x9)); + pr_attr("Port Instance", "%d", data[0xB]); diff --git a/use-read_file-to-read-from-dump.patch b/use-read_file-to-read-from-dump.patch deleted file mode 100644 index cd1cb93..0000000 --- a/use-read_file-to-read-from-dump.patch +++ /dev/null @@ -1,58 +0,0 @@ -From c76ddda0ba0aa99a55945e3290095c2ec493c892 Mon Sep 17 00:00:00 2001 -From: Jean Delvare -Date: Wed, 26 Apr 2023 15:44:27 +0200 -Subject: [PATCH] Consistently use read_file() when reading from a dump file - -Use read_file() instead of mem_chunk() to read the entry point from a -dump file. This is faster, and consistent with how we then read the -actual DMI table from that dump file. - -This made no functional difference so far, which is why it went -unnoticed for years. But now that a file type check was added to the -mem_chunk() function, we must stop using it to read from regular -files. - -This will again allow root to use the --from-dump option. - -Signed-off-by: Jean Delvare -Tested-by: Jerry Hoemann - -diff --git a/dmidecode.c b/dmidecode.c -index 54f59c163daf..52ddbf1a51bd 100644 ---- a/dmidecode.c -+++ b/dmidecode.c -@@ -6025,17 +6025,25 @@ int main(int argc, char * const argv[]) - pr_comment("dmidecode %s", VERSION); - - /* Read from dump if so instructed */ -+ size = 0x20; - if (opt.flags & FLAG_FROM_DUMP) - { - if (!(opt.flags & FLAG_QUIET)) - pr_info("Reading SMBIOS/DMI data from file %s.", - opt.dumpfile); -- if ((buf = mem_chunk(0, 0x20, opt.dumpfile)) == NULL) -+ if ((buf = read_file(0, &size, opt.dumpfile)) == NULL) - { - ret = 1; - goto exit_free; - } - -+ /* Truncated entry point can't be processed */ -+ if (size < 0x20) -+ { -+ ret = 1; -+ goto done; -+ } -+ - if (memcmp(buf, "_SM3_", 5) == 0) - { - if (smbios3_decode(buf, opt.dumpfile, 0)) -@@ -6059,7 +6067,6 @@ int main(int argc, char * const argv[]) - * contain one of several types of entry points, so read enough for - * the largest one, then determine what type it contains. - */ -- size = 0x20; - if (!(opt.flags & FLAG_NO_SYSFS) - && (buf = read_file(0, &size, SYS_ENTRY_FILE)) != NULL) - {