coreboot-kgpe-d16/tests/lib
Subrata Banik 6de8b42482 arch/x86: Refactor the SMBIOS type 17 write function
List of changes:
1. Create Module Type macros as per Memory Type
(i.e. DDR2/DDR3/DDR4/DDR5/LPDDR4/LPDDR5) and fix compilation
issue due to renaming of existing macros due to scoping the Memory
Type.
2. Use dedicated Memory Type and Module type for `Form Factor`
and `TypeDetail` conversion using `get_spd_info()` function.
3. Create a new API (convert_form_factor_to_module_type()) for
`Form Factor` to 'Module type' conversion as per `Memory Type`.
4. Add new argument as `Memory Type` to
smbios_form_factor_to_spd_mod_type() so that it can internally
call convert_form_factor_to_module_type() for `Module Type`
conversion.
5. Update `test_smbios_form_factor_to_spd_mod_type()` to
accommodate different memory types.
6. Skip fixed module type to form factor conversion using DDR2 SPD4
specification (inside dimm_info_fill()).

Refer to datasheet SPD4.1.2.M-1 for LPDDRx and SPD4.1.2.L-3 for DDRx.

BUG=b:194659789
TEST=Refer to dmidecode -t 17 output as below:
Without this code change:

Handle 0x0012, DMI type 17, 40 bytes
Memory Device
        Array Handle: 0x000A
        Error Information Handle: Not Provided
        Total Width: 16 bits
        Data Width: 16 bits
        Size: 2048 MB
        Form Factor: Unknown
        ....

With this code change:

Handle 0x0012, DMI type 17, 40 bytes
Memory Device
        Array Handle: 0x000A
        Error Information Handle: Not Provided
        Total Width: 16 bits
        Data Width: 16 bits
        Size: 2048 MB
        Form Factor: Row Of Chips
        ....

Change-Id: Ia337ac8f50b61ae78d86a07c7a86aa9c248bad50
Signed-off-by: Subrata Banik <subrata.banik@intel.com>
Reviewed-on: https://review.coreboot.org/c/coreboot/+/56628
Tested-by: build bot (Jenkins) <no-reply@coreboot.org>
Reviewed-by: Jakub Czapiga <jacz@semihalf.com>
Reviewed-by: Tim Wawrzynczak <twawrzynczak@chromium.org>
2021-11-11 09:10:10 +00:00
..
Makefile.inc arch/x86: Refactor the SMBIOS type 17 write function 2021-11-11 09:10:10 +00:00
b64_decode-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
bootmem-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
cbfs-lookup-test.c tests: Add lib/cbfs-lookup-test test case 2021-09-14 23:35:38 +00:00
cbfs-verification-test.c tests: Add lib/cbfs-verification-test test case 2021-09-02 00:31:02 +00:00
cbmem_console-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
cbmem_stage_cache-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
compute_ip_checksum-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
coreboot_table-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
crc_byte-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
dimm_info_util-test.c arch/x86: Refactor the SMBIOS type 17 write function 2021-11-11 09:10:10 +00:00
edid-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
fmap-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
hexstrtobin-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
imd-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
imd_cbmem-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
libgcc-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
list-test.c lib/list: Add list_append 2021-11-03 08:29:16 +00:00
lzma-test.c tests: Add lib/lzma-test test case 2021-10-14 13:13:07 +00:00
malloc-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memchr-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memcmp-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memcpy-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memmove-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memrange-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
memset-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
region_file-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
rtc-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
spd_cache-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
stack-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
string-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
timestamp-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00
uuid-test.c tests: Improve test output readability 2021-09-01 19:38:09 +00:00