mb/google/hatch: Use MEM_CH_SEL to indicate single_channel sku
MEM_CH_SEL is used to indicate whether we are on a single or dual channel device, where MEM_CH_SEL = 1 for single channel skus and MEM_CH_SEL = 0 for dual channel skus. Initialize single_channel field (from GPP_F2), which will in turn initialize MemorySpdPtr pointers in cannonlake soc code. In the first build, we did not use GPP_F2, so we need to add an internal pulldown as those early devices were all dual channel devices. BUG=b:123062346, b:122959294 BRANCH=None TEST=Boot into current boards and ensure that we have 2 channels as expected Also, verify that GPP_F2 is set to 0. Change-Id: I89d022793580be603a93d0b177d73ce968529b5c Signed-off-by: Shelley Chen <shchen@google.com> Reviewed-on: https://review.coreboot.org/c/coreboot/+/31358 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
parent
fa861eea30
commit
2ee720ca45
4 changed files with 27 additions and 6 deletions
|
@ -23,13 +23,16 @@
|
||||||
|
|
||||||
void mainboard_memory_init_params(FSPM_UPD *memupd)
|
void mainboard_memory_init_params(FSPM_UPD *memupd)
|
||||||
{
|
{
|
||||||
|
struct cnl_mb_cfg memcfg;
|
||||||
|
|
||||||
const struct spd_info spd = {
|
const struct spd_info spd = {
|
||||||
.spd_by_index = true,
|
.spd_by_index = true,
|
||||||
.spd_spec.spd_index = variant_memory_sku(),
|
.spd_spec.spd_index = variant_memory_sku(),
|
||||||
};
|
};
|
||||||
|
|
||||||
|
variant_memory_params(&memcfg);
|
||||||
cannonlake_memcfg_init(&memupd->FspmConfig,
|
cannonlake_memcfg_init(&memupd->FspmConfig,
|
||||||
variant_memory_params(), &spd);
|
&memcfg, &spd);
|
||||||
}
|
}
|
||||||
|
|
||||||
void mainboard_get_dram_part_num(const char **part_num, size_t *len)
|
void mainboard_get_dram_part_num(const char **part_num, size_t *len)
|
||||||
|
|
|
@ -281,7 +281,7 @@ static const struct pad_config gpio_table[] = {
|
||||||
/* F1 : WWAN_RESET_1V8_ODL */
|
/* F1 : WWAN_RESET_1V8_ODL */
|
||||||
PAD_CFG_GPO(GPP_F1, 1, DEEP),
|
PAD_CFG_GPO(GPP_F1, 1, DEEP),
|
||||||
/* F2 : MEM_CH_SEL */
|
/* F2 : MEM_CH_SEL */
|
||||||
PAD_CFG_GPI(GPP_F2, NONE, PLTRST),
|
PAD_CFG_GPI(GPP_F2, DN_20K, PLTRST),
|
||||||
/* F3 : GPP_F3 ==> NC */
|
/* F3 : GPP_F3 ==> NC */
|
||||||
PAD_NC(GPP_F3, NONE),
|
PAD_NC(GPP_F3, NONE),
|
||||||
/* F4 : CNV_BRI_DT */
|
/* F4 : CNV_BRI_DT */
|
||||||
|
@ -429,7 +429,7 @@ static const struct pad_config early_gpio_table[] = {
|
||||||
/* C23 : WLAN_PE_RST# */
|
/* C23 : WLAN_PE_RST# */
|
||||||
PAD_CFG_GPO(GPP_C23, 1, DEEP),
|
PAD_CFG_GPO(GPP_C23, 1, DEEP),
|
||||||
/* F2 : MEM_CH_SEL */
|
/* F2 : MEM_CH_SEL */
|
||||||
PAD_CFG_GPI(GPP_F2, NONE, PLTRST),
|
PAD_CFG_GPI(GPP_F2, DN_20K, PLTRST),
|
||||||
/* F11 : PCH_MEM_STRAP2 */
|
/* F11 : PCH_MEM_STRAP2 */
|
||||||
PAD_CFG_GPI(GPP_F11, NONE, PLTRST),
|
PAD_CFG_GPI(GPP_F11, NONE, PLTRST),
|
||||||
/* F20 : PCH_MEM_STRAP0 */
|
/* F20 : PCH_MEM_STRAP0 */
|
||||||
|
|
|
@ -16,6 +16,7 @@
|
||||||
#ifndef BASEBOARD_VARIANTS_H
|
#ifndef BASEBOARD_VARIANTS_H
|
||||||
#define BASEBOARD_VARIANTS_H
|
#define BASEBOARD_VARIANTS_H
|
||||||
|
|
||||||
|
#include <soc/cnl_memcfg_init.h>
|
||||||
#include <soc/gpio.h>
|
#include <soc/gpio.h>
|
||||||
#include <stdint.h>
|
#include <stdint.h>
|
||||||
#include <vendorcode/google/chromeos/chromeos.h>
|
#include <vendorcode/google/chromeos/chromeos.h>
|
||||||
|
@ -29,7 +30,7 @@ const struct pad_config *variant_early_gpio_table(size_t *num);
|
||||||
int variant_memory_sku(void);
|
int variant_memory_sku(void);
|
||||||
|
|
||||||
/* Return board specific memory configuration */
|
/* Return board specific memory configuration */
|
||||||
const struct cnl_mb_cfg *variant_memory_params(void);
|
void variant_memory_params(struct cnl_mb_cfg *bcfg);
|
||||||
|
|
||||||
/* Return ChromeOS gpio table and fill in number of entries. */
|
/* Return ChromeOS gpio table and fill in number of entries. */
|
||||||
const struct cros_gpio *variant_cros_gpios(size_t *num);
|
const struct cros_gpio *variant_cros_gpios(size_t *num);
|
||||||
|
|
|
@ -17,6 +17,7 @@
|
||||||
#include <baseboard/gpio.h>
|
#include <baseboard/gpio.h>
|
||||||
#include <gpio.h>
|
#include <gpio.h>
|
||||||
#include <soc/cnl_memcfg_init.h>
|
#include <soc/cnl_memcfg_init.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
static const struct cnl_mb_cfg baseboard_memcfg = {
|
static const struct cnl_mb_cfg baseboard_memcfg = {
|
||||||
/*
|
/*
|
||||||
|
@ -42,9 +43,25 @@ static const struct cnl_mb_cfg baseboard_memcfg = {
|
||||||
.ect = 1,
|
.ect = 1,
|
||||||
};
|
};
|
||||||
|
|
||||||
const struct cnl_mb_cfg *__weak variant_memory_params(void)
|
void __weak variant_memory_params(struct cnl_mb_cfg *bcfg)
|
||||||
{
|
{
|
||||||
return &baseboard_memcfg;
|
memcpy(bcfg, &baseboard_memcfg, sizeof(baseboard_memcfg));
|
||||||
|
/*
|
||||||
|
* GPP_F2 is the MEM_CH_SEL gpio, which is set to 1 for single
|
||||||
|
* channel skus and 0 for dual channel skus.
|
||||||
|
*/
|
||||||
|
if (gpio_get(GPP_F2) == 1) {
|
||||||
|
/*
|
||||||
|
* Single channel config: for Hatch, Channel 0 is
|
||||||
|
* always populated.
|
||||||
|
*/
|
||||||
|
bcfg->channel_empty[0] = 0;
|
||||||
|
bcfg->channel_empty[1] = 1;
|
||||||
|
} else {
|
||||||
|
/* Dual channel config: both channels populated. */
|
||||||
|
bcfg->channel_empty[0] = 0;
|
||||||
|
bcfg->channel_empty[1] = 0;
|
||||||
|
}
|
||||||
}
|
}
|
||||||
|
|
||||||
int __weak variant_memory_sku(void)
|
int __weak variant_memory_sku(void)
|
||||||
|
|
Loading…
Reference in a new issue