Angel Pons | 11ba353 | 2020-04-05 13:21:58 +0200 | [diff] [blame] | 1 | /* SPDX-License-Identifier: GPL-2.0-only */ |
Junzhi Zhao | 66ee65f | 2018-06-13 16:20:00 +0800 | [diff] [blame] | 2 | |
| 3 | #include <boardid.h> |
| 4 | #include <cbfs.h> |
| 5 | #include <console/console.h> |
| 6 | #include <soc/emi.h> |
| 7 | |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 8 | /* |
| 9 | * The RAM_CODE ADC on Kukui can support only 12 different levels. Each model |
| 10 | * can create its own mapping if needed, with an offset (0x10, 0x20, ..., |
| 11 | * defined as CONFIG_BOARD_SDRAM_TABLE_OFFSET) applied in ram_code(). |
| 12 | */ |
Junzhi Zhao | 66ee65f | 2018-06-13 16:20:00 +0800 | [diff] [blame] | 13 | static const char *const sdram_configs[] = { |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 14 | /* Standard table. */ |
Kevin Chiu | 2ee5dcb | 2020-09-04 11:07:39 +0800 | [diff] [blame] | 15 | [0x00] = "sdram-lpddr4x-K4UBE3D4AA-MGCR-4GB", |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 16 | [0x01] = "sdram-lpddr4x-H9HCNNNCPMALHR-4GB", |
| 17 | [0x02] = "sdram-lpddr4x-MT53E1G32D4NQ-4GB", |
| 18 | [0x03] = "sdram-lpddr4x-KMDH6001DA-B422-4GB", |
| 19 | [0x04] = "sdram-lpddr4x-KMDP6001DA-B425-4GB", |
| 20 | [0x05] = "sdram-lpddr4x-MT29VZZZAD8DQKSL-4GB", |
| 21 | [0x06] = "sdram-lpddr4x-KMDV6001DA-B620-4GB", |
| 22 | [0x07] = "sdram-lpddr4x-SDADA4CR-128G-4GB", |
| 23 | [0x08] = "sdram-lpddr4x-K4UBE3D4AA-MGCL-4GB", |
| 24 | [0x09] = "sdram-lpddr4x-MT53E2G32D4NQ-046-8GB", |
| 25 | [0x0a] = "sdram-lpddr4x-H9HCNNNCPMMLXR-NEE-4GB", |
| 26 | |
| 27 | /* Table shared by Burnet and its variants, offset = 0x10 */ |
Kevin Chiu | 144c5ae | 2020-08-26 18:10:33 +0800 | [diff] [blame] | 28 | [0x10] = "sdram-lpddr4x-K4UBE3D4AA-MGCR-4GB", |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 29 | [0x11] = "sdram-lpddr4x-H9HCNNNCPMALHR-4GB", |
| 30 | [0x12] = "sdram-lpddr4x-MT53E1G32D4NQ-4GB", |
| 31 | [0x13] = "sdram-lpddr4x-K4UBE3D4AA-MGCL-4GB", |
| 32 | [0x14] = "sdram-lpddr4x-H9HCNNNCPMMLXR-NEE-4GB", |
Kevin Chiu | dda2de8 | 2020-08-17 18:04:16 +0800 | [diff] [blame] | 33 | [0x16] = "sdram-lpddr4x-MT53E2G32D4NQ-046-8GB", |
Junzhi Zhao | 66ee65f | 2018-06-13 16:20:00 +0800 | [diff] [blame] | 34 | }; |
| 35 | |
| 36 | static struct sdram_params params; |
| 37 | |
| 38 | const struct sdram_params *get_sdram_config(void) |
| 39 | { |
| 40 | uint32_t ramcode = ram_code(); |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 41 | const char *name = NULL; |
Junzhi Zhao | 66ee65f | 2018-06-13 16:20:00 +0800 | [diff] [blame] | 42 | |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 43 | if (ramcode < ARRAY_SIZE(sdram_configs)) |
| 44 | name = sdram_configs[ramcode]; |
| 45 | |
Julius Werner | 834b3ec | 2020-03-04 16:52:08 -0800 | [diff] [blame^] | 46 | if (!name || cbfs_load(name, ¶ms, sizeof(params)) != sizeof(params)) |
Hung-Te Lin | 45701fd | 2020-07-28 10:59:00 +0800 | [diff] [blame] | 47 | die("Cannot load SDRAM parameter file for RAM code %#02x: %s!", |
| 48 | ramcode, name ? name : "unknown"); |
Junzhi Zhao | 66ee65f | 2018-06-13 16:20:00 +0800 | [diff] [blame] | 49 | |
| 50 | return ¶ms; |
| 51 | } |