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>
This commit is contained in:
parent
8a47a14a2f
commit
555c2aeb67
2 changed files with 49 additions and 0 deletions
|
@ -6,6 +6,7 @@
|
|||
#include <soc/dramc_param.h>
|
||||
|
||||
size_t sdram_size(void);
|
||||
size_t mtk_dram_size(void);
|
||||
void mt_set_emi(struct dramc_param *dparam);
|
||||
void mt_mem_init(struct dramc_param *dparam);
|
||||
void mtk_dram_init(void);
|
||||
|
|
|
@ -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();
|
||||
}
|
||||
|
|
Loading…
Reference in a new issue