xref: /rk3399_ARM-atf/plat/marvell/armada/a8k/a80x0/board/dram_port.c (revision 8909fa9bbf159f12cec0a06a3e57bc32a65953b8)
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 #include <drivers/mentor/mi2cv.h>
11a2847172SGrzegorz Jaszczyk #include <lib/mmio.h>
12a2847172SGrzegorz Jaszczyk 
13a2847172SGrzegorz Jaszczyk #include <mv_ddr_if.h>
14a2847172SGrzegorz Jaszczyk #include <mvebu_def.h>
15a2847172SGrzegorz Jaszczyk #include <plat_marvell.h>
16a2847172SGrzegorz Jaszczyk 
17a2847172SGrzegorz Jaszczyk #define MVEBU_AP_MPP_CTRL0_7_REG		MVEBU_AP_MPP_REGS(0)
18a2847172SGrzegorz Jaszczyk #define MVEBU_AP_MPP_CTRL4_OFFS			16
19a2847172SGrzegorz Jaszczyk #define MVEBU_AP_MPP_CTRL5_OFFS			20
20a2847172SGrzegorz Jaszczyk #define MVEBU_AP_MPP_CTRL4_I2C0_SDA_ENA		0x3
21a2847172SGrzegorz Jaszczyk #define MVEBU_AP_MPP_CTRL5_I2C0_SCK_ENA		0x3
22a2847172SGrzegorz Jaszczyk 
23a2847172SGrzegorz Jaszczyk #define MVEBU_CP_MPP_CTRL37_OFFS		20
24a2847172SGrzegorz Jaszczyk #define MVEBU_CP_MPP_CTRL38_OFFS		24
25a2847172SGrzegorz Jaszczyk #define MVEBU_CP_MPP_CTRL37_I2C0_SCK_ENA	0x2
26a2847172SGrzegorz Jaszczyk #define MVEBU_CP_MPP_CTRL38_I2C0_SDA_ENA	0x2
27a2847172SGrzegorz Jaszczyk 
28a2847172SGrzegorz Jaszczyk #define MVEBU_MPP_CTRL_MASK			0xf
29a2847172SGrzegorz Jaszczyk 
30a2847172SGrzegorz Jaszczyk /*
31a2847172SGrzegorz Jaszczyk  * This struct provides the DRAM training code with
32a2847172SGrzegorz Jaszczyk  * the appropriate board DRAM configuration
33a2847172SGrzegorz Jaszczyk  */
34a2847172SGrzegorz Jaszczyk static struct mv_ddr_topology_map board_topology_map = {
35a2847172SGrzegorz Jaszczyk 	/* MISL board with 1CS 8Gb x4 devices of Micron 2400T */
36a2847172SGrzegorz Jaszczyk 	DEBUG_LEVEL_ERROR,
37a2847172SGrzegorz Jaszczyk 	0x1, /* active interfaces */
38a2847172SGrzegorz Jaszczyk 	/* cs_mask, mirror, dqs_swap, ck_swap X subphys */
39a2847172SGrzegorz Jaszczyk 	{ { { {0x1, 0x0, 0, 0},	/* FIXME: change the cs mask for all 64 bit */
40a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
41a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
42a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
43a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
44a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
45a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
46a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0},
47a2847172SGrzegorz Jaszczyk 	      {0x1, 0x0, 0, 0} },
48a2847172SGrzegorz Jaszczyk 	   /* TODO: double check if the speed bin is 2400T */
49a2847172SGrzegorz Jaszczyk 	   SPEED_BIN_DDR_2400T,		/* speed_bin */
50a2847172SGrzegorz Jaszczyk 	   MV_DDR_DEV_WIDTH_8BIT,	/* sdram device width */
51a2847172SGrzegorz Jaszczyk 	   MV_DDR_DIE_CAP_8GBIT,	/* die capacity */
52a2847172SGrzegorz Jaszczyk 	   MV_DDR_FREQ_SAR,		/* frequency */
53a2847172SGrzegorz Jaszczyk 	   0, 0,			/* cas_l, cas_wl */
54a2847172SGrzegorz Jaszczyk 	   MV_DDR_TEMP_LOW} },		/* temperature */
5557adbf37SAlex Leibovich #if DDR32
5657adbf37SAlex Leibovich 	MV_DDR_32BIT_ECC_PUP8_BUS_MASK, /* subphys mask */
5757adbf37SAlex Leibovich #else
58a2847172SGrzegorz Jaszczyk 	MV_DDR_64BIT_ECC_PUP8_BUS_MASK, /* subphys mask */
5957adbf37SAlex Leibovich #endif
6032b3b999SAlex Leibovich 	MV_DDR_CFG_SPD,			/* ddr configuration data source */
6148270689SMoti Buskila 	NOT_COMBINED,			/* ddr twin-die combined*/
62a2847172SGrzegorz Jaszczyk 	{ {0} },			/* raw spd data */
63a2847172SGrzegorz Jaszczyk 	{0},				/* timing parameters */
64a2847172SGrzegorz Jaszczyk 	{				/* electrical configuration */
65a2847172SGrzegorz Jaszczyk 		{			/* memory electrical configuration */
66a2847172SGrzegorz Jaszczyk 			MV_DDR_RTT_NOM_PARK_RZQ_DISABLE,	/* rtt_nom */
67a2847172SGrzegorz Jaszczyk 			{
68a2847172SGrzegorz Jaszczyk 				MV_DDR_RTT_NOM_PARK_RZQ_DIV4, /* rtt_park 1cs */
69a2847172SGrzegorz Jaszczyk 				MV_DDR_RTT_NOM_PARK_RZQ_DIV1  /* rtt_park 2cs */
70a2847172SGrzegorz Jaszczyk 			},
71a2847172SGrzegorz Jaszczyk 			{
72a2847172SGrzegorz Jaszczyk 				MV_DDR_RTT_WR_DYN_ODT_OFF,	/* rtt_wr 1cs */
73a2847172SGrzegorz Jaszczyk 				MV_DDR_RTT_WR_RZQ_DIV2		/* rtt_wr 2cs */
74a2847172SGrzegorz Jaszczyk 			},
75a2847172SGrzegorz Jaszczyk 			MV_DDR_DIC_RZQ_DIV7	/* dic */
76a2847172SGrzegorz Jaszczyk 		},
77a2847172SGrzegorz Jaszczyk 		{			/* phy electrical configuration */
78a2847172SGrzegorz Jaszczyk 			MV_DDR_OHM_30,	/* data_drv_p */
79a2847172SGrzegorz Jaszczyk 			MV_DDR_OHM_30,	/* data_drv_n */
80a2847172SGrzegorz Jaszczyk 			MV_DDR_OHM_30,	/* ctrl_drv_p */
81a2847172SGrzegorz Jaszczyk 			MV_DDR_OHM_30,	/* ctrl_drv_n */
82a2847172SGrzegorz Jaszczyk 			{
83a2847172SGrzegorz Jaszczyk 				MV_DDR_OHM_60,	/* odt_p 1cs */
84a2847172SGrzegorz Jaszczyk 				MV_DDR_OHM_120	/* odt_p 2cs */
85a2847172SGrzegorz Jaszczyk 			},
86a2847172SGrzegorz Jaszczyk 			{
87a2847172SGrzegorz Jaszczyk 				MV_DDR_OHM_60,	/* odt_n 1cs */
88a2847172SGrzegorz Jaszczyk 				MV_DDR_OHM_120	/* odt_n 2cs */
89a2847172SGrzegorz Jaszczyk 			},
90a2847172SGrzegorz Jaszczyk 		},
91a2847172SGrzegorz Jaszczyk 		{			/* mac electrical configuration */
92a2847172SGrzegorz Jaszczyk 			MV_DDR_ODT_CFG_NORMAL,		/* odtcfg_pattern */
93a2847172SGrzegorz Jaszczyk 			MV_DDR_ODT_CFG_ALWAYS_ON,	/* odtcfg_write */
94a2847172SGrzegorz Jaszczyk 			MV_DDR_ODT_CFG_NORMAL,		/* odtcfg_read */
95a2847172SGrzegorz Jaszczyk 		},
96a2847172SGrzegorz Jaszczyk 	}
97a2847172SGrzegorz Jaszczyk };
98a2847172SGrzegorz Jaszczyk 
mv_ddr_topology_map_get(void)99a2847172SGrzegorz Jaszczyk struct mv_ddr_topology_map *mv_ddr_topology_map_get(void)
100a2847172SGrzegorz Jaszczyk {
101a2847172SGrzegorz Jaszczyk 	/* Return the board topology as defined in the board code */
102a2847172SGrzegorz Jaszczyk 	return &board_topology_map;
103a2847172SGrzegorz Jaszczyk }
104a2847172SGrzegorz Jaszczyk 
mpp_config(void)105a2847172SGrzegorz Jaszczyk static void mpp_config(void)
106a2847172SGrzegorz Jaszczyk {
107a2847172SGrzegorz Jaszczyk 	uintptr_t reg;
108a2847172SGrzegorz Jaszczyk 	uint32_t val;
109a2847172SGrzegorz Jaszczyk 
110a2847172SGrzegorz Jaszczyk 	reg = MVEBU_CP_MPP_REGS(0, 4);
111a2847172SGrzegorz Jaszczyk 	/* configure CP0 MPP 37 and 38 to i2c */
112a2847172SGrzegorz Jaszczyk 	val = mmio_read_32(reg);
113a2847172SGrzegorz Jaszczyk 	val &= ~((MVEBU_MPP_CTRL_MASK << MVEBU_CP_MPP_CTRL37_OFFS) |
114a2847172SGrzegorz Jaszczyk 		(MVEBU_MPP_CTRL_MASK << MVEBU_CP_MPP_CTRL38_OFFS));
115a2847172SGrzegorz Jaszczyk 	val |= (MVEBU_CP_MPP_CTRL37_I2C0_SCK_ENA <<
116a2847172SGrzegorz Jaszczyk 			MVEBU_CP_MPP_CTRL37_OFFS) |
117a2847172SGrzegorz Jaszczyk 		(MVEBU_CP_MPP_CTRL38_I2C0_SDA_ENA <<
118a2847172SGrzegorz Jaszczyk 			MVEBU_CP_MPP_CTRL38_OFFS);
119a2847172SGrzegorz Jaszczyk 	mmio_write_32(reg, val);
120a2847172SGrzegorz Jaszczyk }
121a2847172SGrzegorz Jaszczyk 
122a2847172SGrzegorz Jaszczyk /*
123a2847172SGrzegorz Jaszczyk  * This function may modify the default DRAM parameters
124a2847172SGrzegorz Jaszczyk  * based on information received from SPD or bootloader
125a2847172SGrzegorz Jaszczyk  * configuration located on non volatile storage
126a2847172SGrzegorz Jaszczyk  */
plat_marvell_dram_update_topology(void)127a2847172SGrzegorz Jaszczyk void plat_marvell_dram_update_topology(void)
128a2847172SGrzegorz Jaszczyk {
129a2847172SGrzegorz Jaszczyk 	struct mv_ddr_topology_map *tm = mv_ddr_topology_map_get();
130a2847172SGrzegorz Jaszczyk 
131a2847172SGrzegorz Jaszczyk 	INFO("Gathering DRAM information\n");
132a2847172SGrzegorz Jaszczyk 
133a2847172SGrzegorz Jaszczyk 	if (tm->cfg_src == MV_DDR_CFG_SPD) {
134a2847172SGrzegorz Jaszczyk 		/* configure MPPs to enable i2c */
135a2847172SGrzegorz Jaszczyk 		mpp_config();
136a2847172SGrzegorz Jaszczyk 
137a2847172SGrzegorz Jaszczyk 		/* initialize i2c */
138a2847172SGrzegorz Jaszczyk 		i2c_init((void *)MVEBU_CP0_I2C_BASE);
139a2847172SGrzegorz Jaszczyk 
140a2847172SGrzegorz Jaszczyk 		/* select SPD memory page 0 to access DRAM configuration */
141*1e179c79SKonstantin Porotchkin 		i2c_write(I2C_SPD_P0_ADDR, 0x0, 1, tm->spd_data.all_bytes, 0);
142a2847172SGrzegorz Jaszczyk 
143a2847172SGrzegorz Jaszczyk 		/* read data from spd */
144a2847172SGrzegorz Jaszczyk 		i2c_read(I2C_SPD_ADDR, 0x0, 1, tm->spd_data.all_bytes,
145a2847172SGrzegorz Jaszczyk 			 sizeof(tm->spd_data.all_bytes));
146a2847172SGrzegorz Jaszczyk 	}
147a2847172SGrzegorz Jaszczyk }
148