nanxiongchao / rpms / dmidecode

Forked from rpms/dmidecode 4 years ago
Clone

Blame SOURCES/0001-dmidecode-Add-enumerated-values-from-SMBIOS-3.3.0.patch

65c10b
From 3fa833fd78ff5eb74f9459e061e26e063ed648d5 Mon Sep 17 00:00:00 2001
65c10b
From: Jean Delvare <jdelvare@suse.de>
65c10b
Date: Wed, 23 Oct 2019 12:44:13 +0200
65c10b
Subject: [PATCH 1/2] dmidecode: Add enumerated values from SMBIOS 3.3.0
65c10b
65c10b
Add all the enumerated values from the SMBIOS 3.3.0 specification
65c10b
update that was released last month.
65c10b
65c10b
Signed-off-by: Jean Delvare <jdelvare@suse.de>
65c10b
Reviewed-by: Jerry Hoemann <jerry.hoemann@hpe.com>
65c10b
Signed-off-by: Lianbo Jiang <lijiang@redhat.com>
65c10b
---
65c10b
 dmidecode.c | 44 +++++++++++++++++++++++++++++++++++---------
65c10b
 1 file changed, 35 insertions(+), 9 deletions(-)
65c10b
65c10b
diff --git a/dmidecode.c b/dmidecode.c
65c10b
index bdf1185dabe9..8e535356de71 100644
65c10b
--- a/dmidecode.c
65c10b
+++ b/dmidecode.c
65c10b
@@ -936,6 +936,10 @@ static const char *dmi_processor_family(const struct dmi_header *h, u16 ver)
65c10b
 		{ 0x140, "WinChip" },
65c10b
 		{ 0x15E, "DSP" },
65c10b
 		{ 0x1F4, "Video Processor" },
65c10b
+
65c10b
+		{ 0x200, "RV32" },
65c10b
+		{ 0x201, "RV64" },
65c10b
+		{ 0x202, "RV128" },
65c10b
 	};
65c10b
 	/*
65c10b
 	 * Note to developers: when adding entries to this list, check if
65c10b
@@ -1821,6 +1825,9 @@ static const char *dmi_slot_type(u8 code)
65c10b
 		"PCI Express Mini 52-pin without bottom-side keep-outs",
65c10b
 		"PCI Express Mini 76-pin" /* 0x23 */
65c10b
 	};
65c10b
+	static const char *type_0x30[] = {
65c10b
+		"CXL FLexbus 1.0" /* 0x30 */
65c10b
+	};
65c10b
 	static const char *type_0xA0[] = {
65c10b
 		"PC-98/C20", /* 0xA0 */
65c10b
 		"PC-98/C24",
65c10b
@@ -1844,7 +1851,14 @@ static const char *dmi_slot_type(u8 code)
65c10b
 		"PCI Express 3 x2",
65c10b
 		"PCI Express 3 x4",
65c10b
 		"PCI Express 3 x8",
65c10b
-		"PCI Express 3 x16" /* 0xB6 */
65c10b
+		"PCI Express 3 x16",
65c10b
+		out_of_spec, /* 0xB7 */
65c10b
+		"PCI Express 4",
65c10b
+		"PCI Express 4 x1",
65c10b
+		"PCI Express 4 x2",
65c10b
+		"PCI Express 4 x4",
65c10b
+		"PCI Express 4 x8",
65c10b
+		"PCI Express 4 x16" /* 0xBD */
65c10b
 	};
65c10b
 	/*
65c10b
 	 * Note to developers: when adding entries to these lists, check if
65c10b
@@ -1853,7 +1867,9 @@ static const char *dmi_slot_type(u8 code)
65c10b
 
65c10b
 	if (code >= 0x01 && code <= 0x23)
65c10b
 		return type[code - 0x01];
65c10b
-	if (code >= 0xA0 && code <= 0xB6)
65c10b
+	if (code == 0x30)
65c10b
+		return type_0x30[code - 0x30];
65c10b
+	if (code >= 0xA0 && code <= 0xBD)
65c10b
 		return type_0xA0[code - 0xA0];
65c10b
 	return out_of_spec;
65c10b
 }
65c10b
@@ -1957,6 +1973,12 @@ static void dmi_slot_id(u8 code1, u8 code2, u8 type, const char *prefix)
65c10b
 		case 0xB4: /* PCI Express 3 */
65c10b
 		case 0xB5: /* PCI Express 3 */
65c10b
 		case 0xB6: /* PCI Express 3 */
65c10b
+		case 0xB8: /* PCI Express 4 */
65c10b
+		case 0xB9: /* PCI Express 4 */
65c10b
+		case 0xBA: /* PCI Express 4 */
65c10b
+		case 0xBB: /* PCI Express 4 */
65c10b
+		case 0xBC: /* PCI Express 4 */
65c10b
+		case 0xBD: /* PCI Express 4 */
65c10b
 			printf("%sID: %u\n", prefix, code1);
65c10b
 			break;
65c10b
 		case 0x07: /* PCMCIA */
65c10b
@@ -2298,12 +2320,13 @@ static const char *dmi_memory_array_location(u8 code)
65c10b
 		"PC-98/C20 Add-on Card", /* 0xA0 */
65c10b
 		"PC-98/C24 Add-on Card",
65c10b
 		"PC-98/E Add-on Card",
65c10b
-		"PC-98/Local Bus Add-on Card" /* 0xA3 */
65c10b
+		"PC-98/Local Bus Add-on Card",
65c10b
+		"CXL Flexbus 1.0" /* 0xA4 */
65c10b
 	};
65c10b
 
65c10b
 	if (code >= 0x01 && code <= 0x0A)
65c10b
 		return location[code - 0x01];
65c10b
-	if (code >= 0xA0 && code <= 0xA3)
65c10b
+	if (code >= 0xA0 && code <= 0xA4)
65c10b
 		return location_0xA0[code - 0xA0];
65c10b
 	return out_of_spec;
65c10b
 }
65c10b
@@ -2426,10 +2449,11 @@ static const char *dmi_memory_device_form_factor(u8 code)
65c10b
 		"RIMM",
65c10b
 		"SODIMM",
65c10b
 		"SRIMM",
65c10b
-		"FB-DIMM" /* 0x0F */
65c10b
+		"FB-DIMM",
65c10b
+		"Die" /* 0x10 */
65c10b
 	};
65c10b
 
65c10b
-	if (code >= 0x01 && code <= 0x0F)
65c10b
+	if (code >= 0x01 && code <= 0x10)
65c10b
 		return form_factor[code - 0x01];
65c10b
 	return out_of_spec;
65c10b
 }
65c10b
@@ -2478,10 +2502,12 @@ static const char *dmi_memory_device_type(u8 code)
65c10b
 		"LPDDR2",
65c10b
 		"LPDDR3",
65c10b
 		"LPDDR4",
65c10b
-		"Logical non-volatile device" /* 0x1F */
65c10b
+		"Logical non-volatile device",
65c10b
+		"HBM",
65c10b
+		"HBM2" /* 0x21 */
65c10b
 	};
65c10b
 
65c10b
-	if (code >= 0x01 && code <= 0x1F)
65c10b
+	if (code >= 0x01 && code <= 0x21)
65c10b
 		return type[code - 0x01];
65c10b
 	return out_of_spec;
65c10b
 }
65c10b
@@ -2537,7 +2563,7 @@ static void dmi_memory_technology(u8 code)
65c10b
 		"NVDIMM-N",
65c10b
 		"NVDIMM-F",
65c10b
 		"NVDIMM-P",
65c10b
-		"Intel persistent memory" /* 0x07 */
65c10b
+		"Intel Optane DC persistent memory" /* 0x07 */
65c10b
 	};
65c10b
 	if (code >= 0x01 && code <= 0x07)
65c10b
 		printf(" %s", technology[code - 0x01]);
65c10b
-- 
65c10b
2.17.1
65c10b