1 /* SPDX-License-Identifier: GPL-2.0-only */
5 #include <commonlib/helpers.h>
6 #include <device/dram/ddr3.h>
7 #include <dimm_info_util.h>
9 #define EXTENSION_BUS_WIDTH_8BITS 8
11 /* Fill the SMBIOS memory information from FSP MEM_INFO_DATA_HOB in CBMEM.*/
12 void dimm_info_fill(struct dimm_info
*dimm
, u32 dimm_capacity
, u8 ddr_type
,
13 u32 frequency
, u8 rank_per_dimm
, u8 channel_id
, u8 dimm_id
,
14 const char *module_part_num
, size_t module_part_number_size
,
15 const u8
*module_serial_num
, u16 data_width
, u32 vdd_voltage
,
16 bool ecc_support
, u16 mod_id
, u8 mod_type
, u8 ctrlr_id
,
19 dimm
->mod_id
= mod_id
;
20 dimm
->mod_type
= mod_type
;
21 dimm
->dimm_size
= dimm_capacity
;
22 dimm
->ddr_type
= ddr_type
;
23 /* keep ddr_frequency for backward compatible */
24 dimm
->ddr_frequency
= frequency
;
25 dimm
->configured_speed_mts
= frequency
;
26 dimm
->max_speed_mts
= max_frequency
;
27 dimm
->rank_per_dimm
= rank_per_dimm
;
28 dimm
->channel_num
= channel_id
;
29 dimm
->dimm_num
= dimm_id
;
30 dimm
->ctrlr_num
= ctrlr_id
;
32 if (vdd_voltage
> 0xFFFF) {
33 dimm
->vdd_voltage
= 0xFFFF;
35 dimm
->vdd_voltage
= vdd_voltage
;
38 strncpy((char *)dimm
->module_part_number
,
40 MIN(sizeof(dimm
->module_part_number
),
41 module_part_number_size
));
42 if (module_serial_num
)
43 memcpy(dimm
->serial
, module_serial_num
,
44 DIMM_INFO_SERIAL_SIZE
);
46 uint16_t total_width
= data_width
;
49 total_width
+= EXTENSION_BUS_WIDTH_8BITS
;
51 dimm
->bus_width
= smbios_bus_width_to_spd_width(ddr_type
, total_width
, data_width
);