aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorEric Lai <eric_lai@quanta.corp-partner.google.com>2023-06-12 14:27:54 +0800
committerFelix Held <felix-coreboot@felixheld.de>2023-06-20 22:55:13 +0000
commitc1ef4f3356be9440e981e23914bff03a98f1d89e (patch)
tree97e3232e79692f9f14fda9f48bf5065ec0eaba37
parentb26f0f924ab81e578bdbf725960e0d02643f972e (diff)
arch/x86: Introduce DUMP_SMBIOS_TYPE17 config
DDR5 spd is not supported read by coreboot. But FSP can read it, so print the memory information from smbios type17 dimm information. TEST=check the coreboot log. memory Channel-0-DIMM-0 type is DDR5 memory part number is MTC8C1084S1SC56BG1 memory max speed is 5600 MT/s memory speed is 5200 MT/s memory size is 16384 MiB Signed-off-by: Eric Lai <eric_lai@quanta.corp-partner.google.com> Change-Id: I2b5ca1f4a59598531a6cba500672c2717f2a7b00 Reviewed-on: https://review.coreboot.org/c/coreboot/+/75756 Reviewed-by: Kapil Porwal <kapilporwal@google.com> Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
-rw-r--r--src/arch/x86/Kconfig4
-rw-r--r--src/arch/x86/smbios.c62
2 files changed, 66 insertions, 0 deletions
diff --git a/src/arch/x86/Kconfig b/src/arch/x86/Kconfig
index b3cf96bb7a..7b3f34ae72 100644
--- a/src/arch/x86/Kconfig
+++ b/src/arch/x86/Kconfig
@@ -359,4 +359,8 @@ config ECFW_PTR_SIZE
help
Size of reserved space for EC firmware pointer
+config DUMP_SMBIOS_TYPE17
+ bool "Dump part of SMBIOS type17 dimm information."
+ depends on GENERATE_SMBIOS_TABLES
+
endif
diff --git a/src/arch/x86/smbios.c b/src/arch/x86/smbios.c
index 1ec0ad20fe..733d44b2ce 100644
--- a/src/arch/x86/smbios.c
+++ b/src/arch/x86/smbios.c
@@ -219,6 +219,65 @@ static void smbios_fill_dimm_serial_number(const struct dimm_info *dimm,
t->serial_number = smbios_add_string(t->eos, serial);
}
+static const char *memory_device_type(u8 code)
+{
+ /* SMBIOS spec 3.6 7.18.2 */
+ static const char * const type[] = {
+ "Other",
+ "Unknown",
+ "DRAM",
+ "EDRAM",
+ "VRAM",
+ "SRAM",
+ "RAM",
+ "ROM",
+ "Flash",
+ "EEPROM",
+ "FEPROM",
+ "EPROM",
+ "CDRAM",
+ "3DRAM",
+ "SDRAM",
+ "SGRAM",
+ "RDRAM",
+ "DDR",
+ "DDR2",
+ "DDR2 FB-DIMM",
+ "Reserved",
+ "Reserved",
+ "Reserved",
+ "DDR3",
+ "FBD2",
+ "DDR4", /* 0x1A */
+ "LPDDR",
+ "LPDDR2",
+ "LPDDR3",
+ "LPDDR4",
+ "Logical non-volatile device",
+ "HBM",
+ "HBM2",
+ "DDR5",
+ "LPDDR5",
+ "HBM3", /* 0x24 */
+ };
+
+ if (code >= MEMORY_TYPE_OTHER && code <= MEMORY_TYPE_HBM3)
+ return type[code - 1];
+ return "Unsupproted";
+}
+
+static void dump_smbios_type17(struct dimm_info *dimm)
+{
+ printk(BIOS_INFO, "memory at Channel-%d-DIMM-%d", dimm->channel_num, dimm->dimm_num);
+ printk(BIOS_INFO, " type is %s\n", memory_device_type(dimm->ddr_type));
+ printk(BIOS_INFO, "memory part number is %s\n", dimm->module_part_number);
+ if (dimm->max_speed_mts != 0)
+ printk(BIOS_INFO, "memory max speed is %d MT/s\n", dimm->max_speed_mts);
+ printk(BIOS_INFO, "memory speed is %d MT/s\n",
+ dimm->configured_speed_mts ? : dimm->ddr_frequency);
+ printk(BIOS_INFO, "memory size is %d MiB\n", dimm->dimm_size);
+}
+
static int create_smbios_type17_for_dimm(struct dimm_info *dimm,
unsigned long *current, int *handle,
int type16_handle)
@@ -273,6 +332,9 @@ static int create_smbios_type17_for_dimm(struct dimm_info *dimm,
t->phys_memory_array_handle = type16_handle;
*handle += 1;
+ if (CONFIG(DUMP_SMBIOS_TYPE17))
+ dump_smbios_type17(dimm);
+
return smbios_full_table_len(&t->header, t->eos);
}