summaryrefslogtreecommitdiffstats
path: root/src/soc/mediatek/common/memory.c
diff options
context:
space:
mode:
authorXi Chen <xixi.chen@mediatek.corp-partner.google.com>2022-01-21 11:43:53 +0800
committerHung-Te Lin <hungte@chromium.org>2022-03-23 11:54:21 +0000
commit555c2aeb674567e641930dba014c3219c92f6e9e (patch)
tree9f46888030fceb89a38859c25be5e5c3c62d24b9 /src/soc/mediatek/common/memory.c
parent8a47a14a2fe876fcad4c2b2cc530bc5503f43c5c (diff)
downloadcoreboot-555c2aeb674567e641930dba014c3219c92f6e9e.tar.gz
coreboot-555c2aeb674567e641930dba014c3219c92f6e9e.tar.bz2
coreboot-555c2aeb674567e641930dba014c3219c92f6e9e.zip
soc/mediatek: Save dram info to cbmem
Store dram info in cbmem for ramstage or payloads to use. BUG=b:206014043 TEST=Build pass on Kingler Signed-off-by: Xi Chen <xixi.chen@mediatek.corp-partner.google.com> Change-Id: I195187c0c757a43bb6d2c57c8f303249f2a7995a Reviewed-on: https://review.coreboot.org/c/coreboot/+/61334 Tested-by: build bot (Jenkins) <no-reply@coreboot.org> Reviewed-by: Yu-Ping Wu <yupingso@google.com>
Diffstat (limited to 'src/soc/mediatek/common/memory.c')
-rw-r--r--src/soc/mediatek/common/memory.c48
1 files changed, 48 insertions, 0 deletions
diff --git a/src/soc/mediatek/common/memory.c b/src/soc/mediatek/common/memory.c
index 3ca36117e9ee..2e460ae1bb17 100644
--- a/src/soc/mediatek/common/memory.c
+++ b/src/soc/mediatek/common/memory.c
@@ -3,6 +3,8 @@
#include <assert.h>
#include <bootmode.h>
#include <cbfs.h>
+#include <cbmem.h>
+#include <commonlib/bsd/mem_chip_info.h>
#include <console/console.h>
#include <soc/dramc_common.h>
#include <ip_checksum.h>
@@ -23,6 +25,8 @@ _Static_assert(sizeof(struct dramc_param) <= CALIBRATION_REGION_SIZE,
const char *get_dram_geometry_str(u32 ddr_geometry);
const char *get_dram_type_str(u32 ddr_type);
+static const struct ddr_base_info *curr_ddr_info;
+
static int mt_mem_test(const struct dramc_data *dparam)
{
if (CONFIG(MEMORY_TEST)) {
@@ -96,6 +100,49 @@ const char *get_dram_type_str(u32 ddr_type)
return s;
}
+size_t mtk_dram_size(void)
+{
+ size_t size = 0;
+
+ if (!curr_ddr_info)
+ return 0;
+ for (unsigned int i = 0; i < RANK_MAX; ++i)
+ size += curr_ddr_info->mrr_info.mr8_density[i];
+ return size;
+}
+
+static void fill_dram_info(struct mem_chip_info *mc, const struct ddr_base_info *ddr)
+{
+ unsigned int i;
+ size_t size;
+
+ mc->type = MEM_CHIP_LPDDR4X;
+ mc->num_channels = CHANNEL_MAX;
+ size = mtk_dram_size();
+ assert(size);
+
+ for (i = 0; i < mc->num_channels; ++i) {
+ mc->channel[i].density = size / mc->num_channels;
+ mc->channel[i].io_width = DQ_DATA_WIDTH_LP4;
+ mc->channel[i].manufacturer_id = ddr->mrr_info.mr5_vendor_id;
+ mc->channel[i].revision_id[0] = ddr->mrr_info.mr6_revision_id;
+ mc->channel[i].revision_id[1] = ddr->mrr_info.mr7_revision_id;
+ }
+}
+
+static void add_mem_chip_info(int unused)
+{
+ struct mem_chip_info *mc;
+ size_t size;
+
+ size = sizeof(*mc) + sizeof(struct mem_chip_channel) * CHANNEL_MAX;
+ mc = cbmem_add(CBMEM_ID_MEM_CHIP_INFO, size);
+ assert(mc);
+
+ fill_dram_info(mc, curr_ddr_info);
+}
+ROMSTAGE_CBMEM_INIT_HOOK(add_mem_chip_info);
+
static int run_dram_blob(struct dramc_param *dparam)
{
/* Load and run the provided blob for full-calibration if available */
@@ -261,5 +308,6 @@ void mtk_dram_init(void)
/* dramc_param is too large to fit in stack. */
static struct dramc_param dramc_parameter;
mt_mem_init(&dramc_parameter);
+ curr_ddr_info = &dramc_parameter.dramc_datas.ddr_info;
mtk_mmu_after_dram();
}