|
|
d384d2 |
From 02ff0488f7d7a0f7e69ff7141236cbc1392c3b4c Mon Sep 17 00:00:00 2001
|
|
|
d384d2 |
From: Jean Delvare <jdelvare@suse.de>
|
|
|
d384d2 |
Date: Fri, 30 Oct 2020 15:36:19 +0100
|
|
|
d384d2 |
Subject: [PATCH 2/2] dmidecode: Skip details of uninstalled memory modules
|
|
|
d384d2 |
|
|
|
d384d2 |
If a memory slot is empty then by definition the fields containing
|
|
|
d384d2 |
the memory module details are irrelevant. Best case they are filled
|
|
|
d384d2 |
with "Unused" and "None", but in some cases they are even invalid
|
|
|
d384d2 |
because the manufacturer did not bother setting the fields to
|
|
|
d384d2 |
valid neutral values. So it is better to not print these fields
|
|
|
d384d2 |
at all, so as to not confuse the user.
|
|
|
d384d2 |
|
|
|
d384d2 |
Signed-off-by: Jean Delvare <jdelvare@suse.de>
|
|
|
d384d2 |
Signed-off-by: Lianbo Jiang <lijiang@redhat.com>
|
|
|
d384d2 |
---
|
|
|
d384d2 |
dmidecode.c | 3 +++
|
|
|
d384d2 |
1 file changed, 3 insertions(+)
|
|
|
d384d2 |
|
|
|
d384d2 |
diff --git a/dmidecode.c b/dmidecode.c
|
|
|
d384d2 |
index 0e480d3e337b..657a1341470b 100644
|
|
|
d384d2 |
--- a/dmidecode.c
|
|
|
d384d2 |
+++ b/dmidecode.c
|
|
|
d384d2 |
@@ -4465,6 +4465,9 @@ static void dmi_decode(const struct dmi_header *h, u16 ver)
|
|
|
d384d2 |
dmi_memory_device_type(data[0x12]));
|
|
|
d384d2 |
dmi_memory_device_type_detail(WORD(data + 0x13));
|
|
|
d384d2 |
if (h->length < 0x17) break;
|
|
|
d384d2 |
+ /* If no module is present, the remaining fields are irrelevant */
|
|
|
d384d2 |
+ if (WORD(data + 0x0C) == 0)
|
|
|
d384d2 |
+ break;
|
|
|
d384d2 |
dmi_memory_device_speed("Speed", WORD(data + 0x15));
|
|
|
d384d2 |
if (h->length < 0x1B) break;
|
|
|
d384d2 |
pr_attr("Manufacturer", "%s",
|
|
|
d384d2 |
--
|
|
|
d384d2 |
2.17.1
|
|
|
d384d2 |
|