1a2847172SGrzegorz Jaszczyk /*
2a2847172SGrzegorz Jaszczyk * Copyright (C) 2018 Marvell International Ltd.
3a2847172SGrzegorz Jaszczyk *
4a2847172SGrzegorz Jaszczyk * SPDX-License-Identifier: BSD-3-Clause
5a2847172SGrzegorz Jaszczyk * https://spdx.org/licenses
6a2847172SGrzegorz Jaszczyk */
7a2847172SGrzegorz Jaszczyk
8a2847172SGrzegorz Jaszczyk #include <arch_helpers.h>
9a2847172SGrzegorz Jaszczyk #include <common/debug.h>
10a2847172SGrzegorz Jaszczyk
11a2847172SGrzegorz Jaszczyk #include <mv_ddr_if.h>
12a2847172SGrzegorz Jaszczyk #include <plat_marvell.h>
13a2847172SGrzegorz Jaszczyk
14a2847172SGrzegorz Jaszczyk /*
15a2847172SGrzegorz Jaszczyk * This function may modify the default DRAM parameters
16a2847172SGrzegorz Jaszczyk * based on information received from SPD or bootloader
17a2847172SGrzegorz Jaszczyk * configuration located on non volatile storage
18a2847172SGrzegorz Jaszczyk */
plat_marvell_dram_update_topology(void)19a2847172SGrzegorz Jaszczyk void plat_marvell_dram_update_topology(void)
20a2847172SGrzegorz Jaszczyk {
21a2847172SGrzegorz Jaszczyk }
22a2847172SGrzegorz Jaszczyk
23a2847172SGrzegorz Jaszczyk /*
24a2847172SGrzegorz Jaszczyk * This struct provides the DRAM training code with
25a2847172SGrzegorz Jaszczyk * the appropriate board DRAM configuration
26a2847172SGrzegorz Jaszczyk */
27a2847172SGrzegorz Jaszczyk static struct mv_ddr_topology_map board_topology_map = {
28a2847172SGrzegorz Jaszczyk /* FIXME: MISL board 2CS 4Gb x8 devices of micron - 2133P */
29a2847172SGrzegorz Jaszczyk DEBUG_LEVEL_ERROR,
30a2847172SGrzegorz Jaszczyk 0x1, /* active interfaces */
31a2847172SGrzegorz Jaszczyk /* cs_mask, mirror, dqs_swap, ck_swap X subphys */
32a2847172SGrzegorz Jaszczyk { { { {0x3, 0x2, 0, 0},
33a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
34a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
35a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
36a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
37a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
38a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
39a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0},
40a2847172SGrzegorz Jaszczyk {0x3, 0x2, 0, 0} },
41a2847172SGrzegorz Jaszczyk SPEED_BIN_DDR_2133P, /* speed_bin */
42a2847172SGrzegorz Jaszczyk MV_DDR_DEV_WIDTH_8BIT, /* sdram device width */
43a2847172SGrzegorz Jaszczyk MV_DDR_DIE_CAP_4GBIT, /* die capacity */
44a2847172SGrzegorz Jaszczyk MV_DDR_FREQ_SAR, /* frequency */
45a2847172SGrzegorz Jaszczyk 0, 0, /* cas_l, cas_wl */
46a2847172SGrzegorz Jaszczyk MV_DDR_TEMP_LOW} }, /* temperature */
47a2847172SGrzegorz Jaszczyk MV_DDR_32BIT_ECC_PUP8_BUS_MASK, /* subphys mask */
48a2847172SGrzegorz Jaszczyk MV_DDR_CFG_DEFAULT, /* ddr configuration data source */
49*48270689SMoti Buskila NOT_COMBINED, /* ddr twin-die combined*/
50a2847172SGrzegorz Jaszczyk { {0} }, /* raw spd data */
51a2847172SGrzegorz Jaszczyk {0}, /* timing parameters */
52a2847172SGrzegorz Jaszczyk { /* electrical configuration */
53a2847172SGrzegorz Jaszczyk { /* memory electrical configuration */
54a2847172SGrzegorz Jaszczyk MV_DDR_RTT_NOM_PARK_RZQ_DISABLE, /* rtt_nom */
55a2847172SGrzegorz Jaszczyk {
56a2847172SGrzegorz Jaszczyk MV_DDR_RTT_NOM_PARK_RZQ_DIV4, /* rtt_park 1cs */
57a2847172SGrzegorz Jaszczyk MV_DDR_RTT_NOM_PARK_RZQ_DIV1 /* rtt_park 2cs */
58a2847172SGrzegorz Jaszczyk },
59a2847172SGrzegorz Jaszczyk {
60a2847172SGrzegorz Jaszczyk MV_DDR_RTT_WR_DYN_ODT_OFF, /* rtt_wr 1cs */
61a2847172SGrzegorz Jaszczyk MV_DDR_RTT_WR_RZQ_DIV2 /* rtt_wr 2cs */
62a2847172SGrzegorz Jaszczyk },
63a2847172SGrzegorz Jaszczyk MV_DDR_DIC_RZQ_DIV7 /* dic */
64a2847172SGrzegorz Jaszczyk },
65a2847172SGrzegorz Jaszczyk { /* phy electrical configuration */
66a2847172SGrzegorz Jaszczyk MV_DDR_OHM_30, /* data_drv_p */
67a2847172SGrzegorz Jaszczyk MV_DDR_OHM_30, /* data_drv_n */
68a2847172SGrzegorz Jaszczyk MV_DDR_OHM_30, /* ctrl_drv_p */
69a2847172SGrzegorz Jaszczyk MV_DDR_OHM_30, /* ctrl_drv_n */
70a2847172SGrzegorz Jaszczyk {
71a2847172SGrzegorz Jaszczyk MV_DDR_OHM_60, /* odt_p 1cs */
72a2847172SGrzegorz Jaszczyk MV_DDR_OHM_120 /* odt_p 2cs */
73a2847172SGrzegorz Jaszczyk },
74a2847172SGrzegorz Jaszczyk {
75a2847172SGrzegorz Jaszczyk MV_DDR_OHM_60, /* odt_n 1cs */
76a2847172SGrzegorz Jaszczyk MV_DDR_OHM_120 /* odt_n 2cs */
77a2847172SGrzegorz Jaszczyk },
78a2847172SGrzegorz Jaszczyk },
79a2847172SGrzegorz Jaszczyk { /* mac electrical configuration */
80a2847172SGrzegorz Jaszczyk MV_DDR_ODT_CFG_NORMAL, /* odtcfg_pattern */
81a2847172SGrzegorz Jaszczyk MV_DDR_ODT_CFG_ALWAYS_ON, /* odtcfg_write */
82a2847172SGrzegorz Jaszczyk MV_DDR_ODT_CFG_NORMAL, /* odtcfg_read */
83a2847172SGrzegorz Jaszczyk },
84a2847172SGrzegorz Jaszczyk }
85a2847172SGrzegorz Jaszczyk };
86a2847172SGrzegorz Jaszczyk
mv_ddr_topology_map_get(void)87a2847172SGrzegorz Jaszczyk struct mv_ddr_topology_map *mv_ddr_topology_map_get(void)
88a2847172SGrzegorz Jaszczyk {
89a2847172SGrzegorz Jaszczyk /* Return the board topology as defined in the board code */
90a2847172SGrzegorz Jaszczyk return &board_topology_map;
91a2847172SGrzegorz Jaszczyk }
92