mb/google/hatch/variants/kohaku: Add support for LPDDR3 configurations
First configuration supported is 8 GB system memory: 4 x 2 GB (K4E6E304ED-EGCG). BRANCH=none BUG=b:129706819 TEST=ensure the firmware builds without error; I don't have hardware available to test this just yet. Signed-off-by: Paul Fagerburg <pfagerburg@chromium.org> Change-Id: Ibd92d585118ff75492e8a7188dcdb2a286836d56 Reviewed-on: https://review.coreboot.org/c/coreboot/+/32364 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Furquan Shaikh <furquan@google.com>
This commit is contained in:
committed by
Furquan Shaikh
parent
cb42f4d467
commit
d3d41b348d
32
src/mainboard/google/hatch/spd/LP_8G_2133.spd.hex
Normal file
32
src/mainboard/google/hatch/spd/LP_8G_2133.spd.hex
Normal file
@@ -0,0 +1,32 @@
|
|||||||
|
21 01 0F 0E 15 19 90 08 00 00 00 0B 0B 03 00 00
|
||||||
|
00 00 08 FF D4 01 00 00 78 00 90 A8 90 90 06 D0
|
||||||
|
02 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 08 7F C2 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
||||||
|
00 00 00 00 00 00 00 00 00 00 00 00 00 00 00 00
|
@@ -12,12 +12,9 @@
|
|||||||
## GNU General Public License for more details.
|
## GNU General Public License for more details.
|
||||||
##
|
##
|
||||||
|
|
||||||
SPD_SOURCES = 4G_2400 # 0b000
|
SPD_SOURCES = LP_8G_2133 # 0b000
|
||||||
SPD_SOURCES += empty_ddr4 # 0b001
|
|
||||||
SPD_SOURCES += 8G_2400 # 0b010
|
romstage-y += memory.c
|
||||||
SPD_SOURCES += 8G_2666 # 0b011
|
|
||||||
SPD_SOURCES += 16G_2400 # 0b100
|
|
||||||
SPD_SOURCES += 16G_2666 # 0b101
|
|
||||||
|
|
||||||
bootblock-y += gpio.c
|
bootblock-y += gpio.c
|
||||||
ramstage-y += gpio.c
|
ramstage-y += gpio.c
|
||||||
|
85
src/mainboard/google/hatch/variants/kohaku/memory.c
Normal file
85
src/mainboard/google/hatch/variants/kohaku/memory.c
Normal file
@@ -0,0 +1,85 @@
|
|||||||
|
/*
|
||||||
|
* This file is part of the coreboot project.
|
||||||
|
*
|
||||||
|
* Copyright (C) 2018 Intel Corporation.
|
||||||
|
*
|
||||||
|
* This program is free software; you can redistribute it and/or modify
|
||||||
|
* it under the terms of the GNU General Public License as published by
|
||||||
|
* the Free Software Foundation; version 2 of the License.
|
||||||
|
*
|
||||||
|
* This program is distributed in the hope that it will be useful,
|
||||||
|
* but WITHOUT ANY WARRANTY; without even the implied warranty of
|
||||||
|
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
||||||
|
* GNU General Public License for more details.
|
||||||
|
*/
|
||||||
|
|
||||||
|
#include <baseboard/variants.h>
|
||||||
|
#include <baseboard/gpio.h>
|
||||||
|
#include <gpio.h>
|
||||||
|
#include <soc/cnl_memcfg_init.h>
|
||||||
|
#include <string.h>
|
||||||
|
|
||||||
|
static const struct cnl_mb_cfg baseboard_memcfg = {
|
||||||
|
/*
|
||||||
|
* The dqs_map arrays map the SoC pins to the lpddr3 pins
|
||||||
|
* for both channels.
|
||||||
|
*
|
||||||
|
* "The index of the array is CPU byte number, the values are DRAM byte
|
||||||
|
* numbers." - doc #573387
|
||||||
|
*
|
||||||
|
* the index = pin number on SoC
|
||||||
|
* the value = pin number on lpddr3 part
|
||||||
|
*/
|
||||||
|
.dqs_map[DDR_CH0] = { 0, 1, 3, 2, 5, 7, 6, 4 },
|
||||||
|
.dqs_map[DDR_CH1] = { 1, 3, 2, 0, 5, 7, 6, 4 },
|
||||||
|
|
||||||
|
.dq_map[DDR_CH0] = {
|
||||||
|
{0xf, 0xf0},
|
||||||
|
{0x0, 0xf0},
|
||||||
|
{0xf, 0xf0},
|
||||||
|
{0xf, 0x0},
|
||||||
|
{0xff, 0x0},
|
||||||
|
{0xff, 0x0}
|
||||||
|
},
|
||||||
|
.dq_map[DDR_CH1] = {
|
||||||
|
{0xf, 0xf0},
|
||||||
|
{0x0, 0xf0},
|
||||||
|
{0xf, 0xf0},
|
||||||
|
{0xf, 0x0},
|
||||||
|
{0xff, 0x0},
|
||||||
|
{0xff, 0x0}
|
||||||
|
},
|
||||||
|
|
||||||
|
/* Kohaku uses 200, 80.6 and 162 rcomp resistors */
|
||||||
|
.rcomp_resistor = { 200, 81, 162 },
|
||||||
|
|
||||||
|
/* Kohaku Rcomp target values */
|
||||||
|
.rcomp_targets = { 100, 40, 40, 23, 40 },
|
||||||
|
|
||||||
|
/* Set CaVref config to 0 for LPDDR3 */
|
||||||
|
.vref_ca_config = 0,
|
||||||
|
|
||||||
|
/* Disable Early Command Training */
|
||||||
|
.ect = 0,
|
||||||
|
};
|
||||||
|
|
||||||
|
void variant_memory_params(struct cnl_mb_cfg *bcfg)
|
||||||
|
{
|
||||||
|
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 kohaku, 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;
|
||||||
|
}
|
||||||
|
}
|
Reference in New Issue
Block a user