mb/google/drallion: Add memory init setup for drallion
This implementation adds below support 1. Add support to read memory strap 2. Add support to configure below memory parameters -> rcomp resistor configuration -> dqs mapping -> ect and ca vref config Signed-off-by: Thejaswani Putta <thejaswani.putta@intel.com> Change-Id: I9993ad175e6f52711d5a05733aeab1bbed1e0b80 Reviewed-on: https://review.coreboot.org/c/coreboot/+/35141 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: EricR Lai <ericr_lai@compal.corp-partner.google.com>
This commit is contained in:
parent
ecea91679f
commit
7140db4751
3 changed files with 58 additions and 1 deletions
|
@ -58,11 +58,18 @@ static const struct cnl_mb_cfg memcfg = {
|
||||||
.vref_ca_config = 2,
|
.vref_ca_config = 2,
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const struct cnl_mb_cfg * __weak get_variant_memory_cfg(struct cnl_mb_cfg *mem_cfg)
|
||||||
|
{
|
||||||
|
return &memcfg;
|
||||||
|
}
|
||||||
|
|
||||||
void mainboard_memory_init_params(FSPM_UPD *memupd)
|
void mainboard_memory_init_params(FSPM_UPD *memupd)
|
||||||
{
|
{
|
||||||
|
struct cnl_mb_cfg board_memcfg;
|
||||||
|
|
||||||
variant_mainboard_post_init_params(memupd);
|
variant_mainboard_post_init_params(memupd);
|
||||||
|
|
||||||
wilco_ec_romstage_init();
|
wilco_ec_romstage_init();
|
||||||
|
|
||||||
cannonlake_memcfg_init(&memupd->FspmConfig, &memcfg);
|
cannonlake_memcfg_init(&memupd->FspmConfig, get_variant_memory_cfg(&board_memcfg));
|
||||||
}
|
}
|
||||||
|
|
|
@ -17,7 +17,11 @@
|
||||||
#define BASEBOARD_VARIANTS_H
|
#define BASEBOARD_VARIANTS_H
|
||||||
|
|
||||||
#include <fsp/api.h>
|
#include <fsp/api.h>
|
||||||
|
#include <soc/cnl_memcfg_init.h>
|
||||||
|
|
||||||
void variant_mainboard_post_init_params(FSPM_UPD *mupd);
|
void variant_mainboard_post_init_params(FSPM_UPD *mupd);
|
||||||
|
|
||||||
|
/* Return board specific memory configuration */
|
||||||
|
const struct cnl_mb_cfg *get_variant_memory_cfg(struct cnl_mb_cfg *mem_cfg);
|
||||||
|
|
||||||
#endif /* BASEBOARD_VARIANTS_H */
|
#endif /* BASEBOARD_VARIANTS_H */
|
||||||
|
|
|
@ -16,6 +16,8 @@
|
||||||
#include <variant/variant.h>
|
#include <variant/variant.h>
|
||||||
#include <gpio.h>
|
#include <gpio.h>
|
||||||
#include <variant/gpio.h>
|
#include <variant/gpio.h>
|
||||||
|
#include <baseboard/variants.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
/* Use spd_index array to save mem_id */
|
/* Use spd_index array to save mem_id */
|
||||||
static const int spd_index[32] = {
|
static const int spd_index[32] = {
|
||||||
|
@ -25,6 +27,50 @@ static const int spd_index[32] = {
|
||||||
5, 0, 7, 2, 0, 0, 0, 0
|
5, 0, 7, 2, 0, 0, 0, 0
|
||||||
};
|
};
|
||||||
|
|
||||||
|
const struct cnl_mb_cfg *get_variant_memory_cfg(struct cnl_mb_cfg *mem_cfg)
|
||||||
|
{
|
||||||
|
int mem_sku;
|
||||||
|
struct cnl_mb_cfg baseboard_memcfg = {
|
||||||
|
/*
|
||||||
|
* The dqs_map arrays map the ddr4 pins to the SoC pins
|
||||||
|
* for both channels.
|
||||||
|
*
|
||||||
|
* the index = pin number on ddr4 part
|
||||||
|
* the value = pin number on SoC
|
||||||
|
*/
|
||||||
|
.dqs_map[DDR_CH0] = { 0, 1, 4, 5, 2, 3, 6, 7 },
|
||||||
|
.dqs_map[DDR_CH1] = { 0, 1, 4, 5, 2, 3, 6, 7 },
|
||||||
|
|
||||||
|
/* Baseboard uses 120, 81 and 100 rcomp resistors */
|
||||||
|
.rcomp_resistor = { 120, 81, 100 },
|
||||||
|
|
||||||
|
/* Baseboard Rcomp target values */
|
||||||
|
.rcomp_targets = { 100, 40, 20, 20, 26 },
|
||||||
|
|
||||||
|
/* Set CaVref config to 2 */
|
||||||
|
.vref_ca_config = 2,
|
||||||
|
|
||||||
|
/* Enable Early Command Training */
|
||||||
|
.ect = 1,
|
||||||
|
};
|
||||||
|
|
||||||
|
mem_sku = variant_memory_sku();
|
||||||
|
|
||||||
|
memcpy(mem_cfg, &baseboard_memcfg, sizeof(baseboard_memcfg));
|
||||||
|
|
||||||
|
/* In Drallion dual channel is enabled by default.
|
||||||
|
* spd[0]-spd[3] map to CH0D0, CH0D1, CH1D0, Ch1D1 respectively.
|
||||||
|
* Dual-DIMM memory is not used in drallion family, so we only
|
||||||
|
* fill in spd info for CH0D0 and CH1D0 here.
|
||||||
|
*/
|
||||||
|
for (int i = 0; i < 3; i = i+2) {
|
||||||
|
mem_cfg->spd[i].read_type = READ_SPD_CBFS;
|
||||||
|
mem_cfg->spd[i].spd_spec.spd_index = mem_sku;
|
||||||
|
}
|
||||||
|
|
||||||
|
return mem_cfg;
|
||||||
|
}
|
||||||
|
|
||||||
int variant_memory_sku(void)
|
int variant_memory_sku(void)
|
||||||
{
|
{
|
||||||
gpio_t spd_gpios[] = {
|
gpio_t spd_gpios[] = {
|
||||||
|
|
Loading…
Reference in a new issue