summaryrefslogtreecommitdiffstats
path: root/src/mainboard/intel/jasperlake_rvp/romstage_fsp_params.c
blob: 65161310fd25445ce757d5a466039c263bc18ced (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
/* SPDX-License-Identifier: GPL-2.0-only */

#include <baseboard/variants.h>
#include <console/console.h>
#include <soc/meminit.h>
#include <soc/romstage.h>
#include "board_id.h"

void mainboard_memory_init_params(FSPM_UPD *memupd)
{
	static struct spd_info jslrvp_spd_info;
	uint8_t board_id = get_board_id();
	const struct mb_cfg *board_cfg = variant_memcfg_config(board_id);

	/* TODO: Read the resistor strap to get number of memory segments */
	bool half_populated = false;

	/* Check board id and fill correct parameters to upd */
	if (board_id == jsl_ddr4) {
		/* Initialize spd information for DDR4 board */
		jslrvp_spd_info.read_type = READ_SMBUS;
		jslrvp_spd_info.spd_spec.spd_smbus_address[0] = 0xA0;
		jslrvp_spd_info.spd_spec.spd_smbus_address[1] = 0xA2;
		jslrvp_spd_info.spd_spec.spd_smbus_address[2] = 0xA4;
		jslrvp_spd_info.spd_spec.spd_smbus_address[3] = 0xA6;

	} else if (board_id == jsl_lpddr4) {
		/* Initialize spd information for LPDDR4 board */
		jslrvp_spd_info.read_type = READ_SPD_CBFS;
		jslrvp_spd_info.spd_spec.spd_index = 0x00;
	}

	/* Initialize variant specific configurations */
	memcfg_init(&memupd->FspmConfig, board_cfg, &jslrvp_spd_info, half_populated);
}