blob: 6916f1a24441159ade93f196e2b6a7f162ba4ccd [file] [log] [blame]
Andy Yanb5e16302019-11-14 11:21:12 +08001// SPDX-License-Identifier: GPL-2.0+
2/*
3 *Copyright (c) 2018 Rockchip Electronics Co., Ltd
4 */
Simon Glass97589732020-05-10 11:40:02 -06005#include <init.h>
Jonas Karlman178cb272024-11-02 20:45:13 +00006#include <asm/armv8/mmu.h>
John Keeping1cfd0802022-07-14 15:18:37 +01007#include <asm/arch-rockchip/bootrom.h>
Jonas Karlman0333e3b2024-04-08 18:14:11 +00008#include <asm/arch-rockchip/grf_rk3308.h>
Andy Yanb5e16302019-11-14 11:21:12 +08009#include <asm/arch-rockchip/hardware.h>
Simon Glass4dcacfc2020-05-10 11:40:13 -060010#include <linux/bitops.h>
Andy Yanb5e16302019-11-14 11:21:12 +080011
Andy Yanb5e16302019-11-14 11:21:12 +080012static struct mm_region rk3308_mem_map[] = {
13 {
14 .virt = 0x0UL,
15 .phys = 0x0UL,
16 .size = 0xff000000UL,
17 .attrs = PTE_BLOCK_MEMTYPE(MT_NORMAL) |
18 PTE_BLOCK_INNER_SHARE
19 }, {
20 .virt = 0xff000000UL,
21 .phys = 0xff000000UL,
22 .size = 0x01000000UL,
23 .attrs = PTE_BLOCK_MEMTYPE(MT_DEVICE_NGNRNE) |
24 PTE_BLOCK_NON_SHARE |
25 PTE_BLOCK_PXN | PTE_BLOCK_UXN
26 }, {
27 /* List terminator */
28 0,
29 }
30};
31
32struct mm_region *mem_map = rk3308_mem_map;
33
34#define GRF_BASE 0xff000000
35#define SGRF_BASE 0xff2b0000
36
37enum {
Andy Yanb5e16302019-11-14 11:21:12 +080038 GPIO4D3_SHIFT = 6,
39 GPIO4D3_MASK = GENMASK(7, 6),
40 GPIO4D3_GPIO = 0,
41 GPIO4D3_SDMMC_D3,
42 GPIO4D3_UART2_TX_M1,
43
44 GPIO4D2_SHIFT = 4,
45 GPIO4D2_MASK = GENMASK(5, 4),
46 GPIO4D2_GPIO = 0,
47 GPIO4D2_SDMMC_D2,
48 GPIO4D2_UART2_RX_M1,
49
50 UART2_IO_SEL_SHIFT = 2,
51 UART2_IO_SEL_MASK = GENMASK(3, 2),
52 UART2_IO_SEL_M0 = 0,
53 UART2_IO_SEL_M1,
54 UART2_IO_SEL_USB,
55
David Wu770258b2019-12-03 19:02:50 +080056 GPIO2C0_SEL_SRC_CTRL_SHIFT = 11,
57 GPIO2C0_SEL_SRC_CTRL_MASK = BIT(11),
58 GPIO2C0_SEL_SRC_CTRL_IOMUX = 0,
59 GPIO2C0_SEL_SRC_CTRL_SEL_PLUS,
60
Andy Yanb5e16302019-11-14 11:21:12 +080061 GPIO3B3_SEL_SRC_CTRL_SHIFT = 7,
62 GPIO3B3_SEL_SRC_CTRL_MASK = BIT(7),
63 GPIO3B3_SEL_SRC_CTRL_IOMUX = 0,
64 GPIO3B3_SEL_SRC_CTRL_SEL_PLUS,
65
66 GPIO3B3_SEL_PLUS_SHIFT = 4,
67 GPIO3B3_SEL_PLUS_MASK = GENMASK(6, 4),
68 GPIO3B3_SEL_PLUS_GPIO3_B3 = 0,
69 GPIO3B3_SEL_PLUS_FLASH_ALE,
70 GPIO3B3_SEL_PLUS_EMMC_PWREN,
71 GPIO3B3_SEL_PLUS_SPI1_CLK,
72 GPIO3B3_SEL_PLUS_LCDC_D23_M1,
73
74 GPIO3B2_SEL_SRC_CTRL_SHIFT = 3,
75 GPIO3B2_SEL_SRC_CTRL_MASK = BIT(3),
76 GPIO3B2_SEL_SRC_CTRL_IOMUX = 0,
77 GPIO3B2_SEL_SRC_CTRL_SEL_PLUS,
78
79 GPIO3B2_SEL_PLUS_SHIFT = 0,
80 GPIO3B2_SEL_PLUS_MASK = GENMASK(2, 0),
81 GPIO3B2_SEL_PLUS_GPIO3_B2 = 0,
82 GPIO3B2_SEL_PLUS_FLASH_RDN,
83 GPIO3B2_SEL_PLUS_EMMC_RSTN,
84 GPIO3B2_SEL_PLUS_SPI1_MISO,
85 GPIO3B2_SEL_PLUS_LCDC_D22_M1,
David Wu770258b2019-12-03 19:02:50 +080086
87 I2C3_IOFUNC_SRC_CTRL_SHIFT = 10,
88 I2C3_IOFUNC_SRC_CTRL_MASK = BIT(10),
89 I2C3_IOFUNC_SRC_CTRL_SEL_PLUS = 1,
90
91 GPIO2A3_SEL_SRC_CTRL_SHIFT = 7,
92 GPIO2A3_SEL_SRC_CTRL_MASK = BIT(7),
93 GPIO2A3_SEL_SRC_CTRL_SEL_PLUS = 1,
94
95 GPIO2A2_SEL_SRC_CTRL_SHIFT = 3,
96 GPIO2A2_SEL_SRC_CTRL_MASK = BIT(3),
97 GPIO2A2_SEL_SRC_CTRL_SEL_PLUS = 1,
Andy Yanb5e16302019-11-14 11:21:12 +080098};
99
John Keeping1cfd0802022-07-14 15:18:37 +0100100const char * const boot_devices[BROM_LAST_BOOTSOURCE + 1] = {
101 [BROM_BOOTSOURCE_EMMC] = "/mmc@ff490000",
Jonas Karlman746a77e2024-03-22 20:50:22 +0000102 [BROM_BOOTSOURCE_SPINOR] = "/spi@ff4c0000/flash@0",
John Keeping1cfd0802022-07-14 15:18:37 +0100103 [BROM_BOOTSOURCE_SD] = "/mmc@ff480000",
104};
105
Pegorer Massimoe54d4fa2023-07-15 10:19:28 +0000106#ifdef CONFIG_DEBUG_UART_BOARD_INIT
Andy Yanb5e16302019-11-14 11:21:12 +0800107__weak void board_debug_uart_init(void)
108{
109 static struct rk3308_grf * const grf = (void *)GRF_BASE;
110
111 /* Enable early UART2 channel m1 on the rk3308 */
112 rk_clrsetreg(&grf->soc_con5, UART2_IO_SEL_MASK,
113 UART2_IO_SEL_M1 << UART2_IO_SEL_SHIFT);
114 rk_clrsetreg(&grf->gpio4d_iomux,
115 GPIO4D3_MASK | GPIO4D2_MASK,
116 GPIO4D2_UART2_RX_M1 << GPIO4D2_SHIFT |
117 GPIO4D3_UART2_TX_M1 << GPIO4D3_SHIFT);
118}
119#endif
120
Simon Glass85ed77d2024-09-29 19:49:46 -0600121#if defined(CONFIG_XPL_BUILD)
Andy Yanb5e16302019-11-14 11:21:12 +0800122int arch_cpu_init(void)
123{
124 static struct rk3308_sgrf * const sgrf = (void *)SGRF_BASE;
David Wu770258b2019-12-03 19:02:50 +0800125 static struct rk3308_grf * const grf = (void *)GRF_BASE;
Andy Yanb5e16302019-11-14 11:21:12 +0800126
127 /* Set CRYPTO SDMMC EMMC NAND SFC USB master bus to be secure access */
128 rk_clrreg(&sgrf->con_secure0, 0x2b83);
129
David Wu770258b2019-12-03 19:02:50 +0800130 /*
131 * Enable plus options to use more pinctrl functions, including
132 * GPIO2A2_PLUS, GPIO2A3_PLUS and I2C3_MULTI_SRC_PLUS.
133 */
134 rk_clrsetreg(&grf->soc_con13,
135 I2C3_IOFUNC_SRC_CTRL_MASK | GPIO2A3_SEL_SRC_CTRL_MASK |
136 GPIO2A2_SEL_SRC_CTRL_MASK,
137 I2C3_IOFUNC_SRC_CTRL_SEL_PLUS << I2C3_IOFUNC_SRC_CTRL_SHIFT |
138 GPIO2A3_SEL_SRC_CTRL_SEL_PLUS << GPIO2A3_SEL_SRC_CTRL_SHIFT |
139 GPIO2A2_SEL_SRC_CTRL_SEL_PLUS << GPIO2A2_SEL_SRC_CTRL_SHIFT);
140
141 /* Plus options about GPIO3B2_PLUS, GPIO3B3_PLUS and GPIO2C0_PLUS. */
142 rk_clrsetreg(&grf->soc_con15,
143 GPIO2C0_SEL_SRC_CTRL_MASK | GPIO3B3_SEL_SRC_CTRL_MASK |
144 GPIO3B2_SEL_SRC_CTRL_MASK,
145 GPIO2C0_SEL_SRC_CTRL_SEL_PLUS << GPIO2C0_SEL_SRC_CTRL_SHIFT |
146 GPIO3B3_SEL_SRC_CTRL_SEL_PLUS << GPIO3B3_SEL_SRC_CTRL_SHIFT |
147 GPIO3B2_SEL_SRC_CTRL_SEL_PLUS << GPIO3B2_SEL_SRC_CTRL_SHIFT);
148
Andy Yanb5e16302019-11-14 11:21:12 +0800149 return 0;
150}
151#endif
Jonas Karlman1eabc112024-11-10 00:56:17 +0000152
153#define RK3308_GRF_CHIP_ID 0xFF000800
154
155int checkboard(void)
156{
157 u32 chip_id = readl(RK3308_GRF_CHIP_ID);
158
159 if (chip_id == 0x3308)
160 printf("SoC: RK3308B\n");
161 else if (chip_id == 0x3308c)
162 printf("SoC: RK3308B-S\n");
163 else
164 printf("SoC: RK3308\n");
165
166 return 0;
167}