1 /* $NetBSD: rk3328-cru.h,v 1.1.1.1.4.2 2017/07/18 16:08:56 snj Exp $ */ 2 3 /* 4 * Copyright (c) 2016 Rockchip Electronics Co. Ltd. 5 * Author: Elaine <zhangqing (at) rock-chips.com> 6 * 7 * This program is free software; you can redistribute it and/or modify 8 * it under the terms of the GNU General Public License as published by 9 * the Free Software Foundation; either version 2 of the License, or 10 * (at your option) any later version. 11 * 12 * This program is distributed in the hope that it will be useful, 13 * but WITHOUT ANY WARRANTY; without even the implied warranty of 14 * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the 15 * GNU General Public License for more details. 16 */ 17 18 #ifndef _DT_BINDINGS_CLK_ROCKCHIP_RK3328_H 19 #define _DT_BINDINGS_CLK_ROCKCHIP_RK3328_H 20 21 /* core clocks */ 22 #define PLL_APLL 1 23 #define PLL_DPLL 2 24 #define PLL_CPLL 3 25 #define PLL_GPLL 4 26 #define PLL_NPLL 5 27 #define ARMCLK 6 28 29 /* sclk gates (special clocks) */ 30 #define SCLK_RTC32K 30 31 #define SCLK_SDMMC_EXT 31 32 #define SCLK_SPI 32 33 #define SCLK_SDMMC 33 34 #define SCLK_SDIO 34 35 #define SCLK_EMMC 35 36 #define SCLK_TSADC 36 37 #define SCLK_SARADC 37 38 #define SCLK_UART0 38 39 #define SCLK_UART1 39 40 #define SCLK_UART2 40 41 #define SCLK_I2S0 41 42 #define SCLK_I2S1 42 43 #define SCLK_I2S2 43 44 #define SCLK_I2S1_OUT 44 45 #define SCLK_I2S2_OUT 45 46 #define SCLK_SPDIF 46 47 #define SCLK_TIMER0 47 48 #define SCLK_TIMER1 48 49 #define SCLK_TIMER2 49 50 #define SCLK_TIMER3 50 51 #define SCLK_TIMER4 51 52 #define SCLK_TIMER5 52 53 #define SCLK_WIFI 53 54 #define SCLK_CIF_OUT 54 55 #define SCLK_I2C0 55 56 #define SCLK_I2C1 56 57 #define SCLK_I2C2 57 58 #define SCLK_I2C3 58 59 #define SCLK_CRYPTO 59 60 #define SCLK_PWM 60 61 #define SCLK_PDM 61 62 #define SCLK_EFUSE 62 63 #define SCLK_OTP 63 64 #define SCLK_DDRCLK 64 65 #define SCLK_VDEC_CABAC 65 66 #define SCLK_VDEC_CORE 66 67 #define SCLK_VENC_DSP 67 68 #define SCLK_VENC_CORE 68 69 #define SCLK_RGA 69 70 #define SCLK_HDMI_SFC 70 71 #define SCLK_HDMI_CEC 71 72 #define SCLK_USB3_REF 72 73 #define SCLK_USB3_SUSPEND 73 74 #define SCLK_SDMMC_DRV 74 75 #define SCLK_SDIO_DRV 75 76 #define SCLK_EMMC_DRV 76 77 #define SCLK_SDMMC_EXT_DRV 77 78 #define SCLK_SDMMC_SAMPLE 78 79 #define SCLK_SDIO_SAMPLE 79 80 #define SCLK_EMMC_SAMPLE 80 81 #define SCLK_SDMMC_EXT_SAMPLE 81 82 #define SCLK_VOP 82 83 #define SCLK_MAC2PHY_RXTX 83 84 #define SCLK_MAC2PHY_SRC 84 85 #define SCLK_MAC2PHY_REF 85 86 #define SCLK_MAC2PHY_OUT 86 87 #define SCLK_MAC2IO_RX 87 88 #define SCLK_MAC2IO_TX 88 89 #define SCLK_MAC2IO_REFOUT 89 90 #define SCLK_MAC2IO_REF 90 91 #define SCLK_MAC2IO_OUT 91 92 #define SCLK_TSP 92 93 #define SCLK_HSADC_TSP 93 94 #define SCLK_USB3PHY_REF 94 95 #define SCLK_REF_USB3OTG 95 96 #define SCLK_USB3OTG_REF 96 97 #define SCLK_USB3OTG_SUSPEND 97 98 #define SCLK_REF_USB3OTG_SRC 98 99 #define SCLK_MAC2IO_SRC 99 100 #define SCLK_MAC2IO 100 101 #define SCLK_MAC2PHY 101 102 103 /* dclk gates */ 104 #define DCLK_LCDC 120 105 #define DCLK_HDMIPHY 121 106 #define HDMIPHY 122 107 #define USB480M 123 108 #define DCLK_LCDC_SRC 124 109 110 /* aclk gates */ 111 #define ACLK_AXISRAM 130 112 #define ACLK_VOP_PRE 131 113 #define ACLK_USB3OTG 132 114 #define ACLK_RGA_PRE 133 115 #define ACLK_DMAC 134 116 #define ACLK_GPU 135 117 #define ACLK_BUS_PRE 136 118 #define ACLK_PERI_PRE 137 119 #define ACLK_RKVDEC_PRE 138 120 #define ACLK_RKVDEC 139 121 #define ACLK_RKVENC 140 122 #define ACLK_VPU_PRE 141 123 #define ACLK_VIO_PRE 142 124 #define ACLK_VPU 143 125 #define ACLK_VIO 144 126 #define ACLK_VOP 145 127 #define ACLK_GMAC 146 128 #define ACLK_H265 147 129 #define ACLK_H264 148 130 #define ACLK_MAC2PHY 149 131 #define ACLK_MAC2IO 150 132 #define ACLK_DCF 151 133 #define ACLK_TSP 152 134 #define ACLK_PERI 153 135 #define ACLK_RGA 154 136 #define ACLK_IEP 155 137 #define ACLK_CIF 156 138 #define ACLK_HDCP 157 139 140 /* pclk gates */ 141 #define PCLK_GPIO0 200 142 #define PCLK_GPIO1 201 143 #define PCLK_GPIO2 202 144 #define PCLK_GPIO3 203 145 #define PCLK_GRF 204 146 #define PCLK_I2C0 205 147 #define PCLK_I2C1 206 148 #define PCLK_I2C2 207 149 #define PCLK_I2C3 208 150 #define PCLK_SPI 209 151 #define PCLK_UART0 210 152 #define PCLK_UART1 211 153 #define PCLK_UART2 212 154 #define PCLK_TSADC 213 155 #define PCLK_PWM 214 156 #define PCLK_TIMER 215 157 #define PCLK_BUS_PRE 216 158 #define PCLK_PERI_PRE 217 159 #define PCLK_HDMI_CTRL 218 160 #define PCLK_HDMI_PHY 219 161 #define PCLK_GMAC 220 162 #define PCLK_H265 221 163 #define PCLK_MAC2PHY 222 164 #define PCLK_MAC2IO 223 165 #define PCLK_USB3PHY_OTG 224 166 #define PCLK_USB3PHY_PIPE 225 167 #define PCLK_USB3_GRF 226 168 #define PCLK_USB2_GRF 227 169 #define PCLK_HDMIPHY 228 170 #define PCLK_DDR 229 171 #define PCLK_PERI 230 172 #define PCLK_HDMI 231 173 #define PCLK_HDCP 232 174 #define PCLK_DCF 233 175 #define PCLK_SARADC 234 176 177 /* hclk gates */ 178 #define HCLK_PERI 308 179 #define HCLK_TSP 309 180 #define HCLK_GMAC 310 181 #define HCLK_I2S0_8CH 311 182 #define HCLK_I2S1_8CH 313 183 #define HCLK_I2S2_2CH 313 184 #define HCLK_SPDIF_8CH 314 185 #define HCLK_VOP 315 186 #define HCLK_NANDC 316 187 #define HCLK_SDMMC 317 188 #define HCLK_SDIO 318 189 #define HCLK_EMMC 319 190 #define HCLK_SDMMC_EXT 320 191 #define HCLK_RKVDEC_PRE 321 192 #define HCLK_RKVDEC 322 193 #define HCLK_RKVENC 323 194 #define HCLK_VPU_PRE 324 195 #define HCLK_VIO_PRE 325 196 #define HCLK_VPU 326 197 #define HCLK_VIO 327 198 #define HCLK_BUS_PRE 328 199 #define HCLK_PERI_PRE 329 200 #define HCLK_H264 330 201 #define HCLK_CIF 331 202 #define HCLK_OTG_PMU 332 203 #define HCLK_OTG 333 204 #define HCLK_HOST0 334 205 #define HCLK_HOST0_ARB 335 206 #define HCLK_CRYPTO_MST 336 207 #define HCLK_CRYPTO_SLV 337 208 #define HCLK_PDM 338 209 #define HCLK_IEP 339 210 #define HCLK_RGA 340 211 #define HCLK_HDCP 341 212 213 #define CLK_NR_CLKS (HCLK_HDCP + 1) 214 215 /* soft-reset indices */ 216 #define SRST_CORE0_PO 0 217 #define SRST_CORE1_PO 1 218 #define SRST_CORE2_PO 2 219 #define SRST_CORE3_PO 3 220 #define SRST_CORE0 4 221 #define SRST_CORE1 5 222 #define SRST_CORE2 6 223 #define SRST_CORE3 7 224 #define SRST_CORE0_DBG 8 225 #define SRST_CORE1_DBG 9 226 #define SRST_CORE2_DBG 10 227 #define SRST_CORE3_DBG 11 228 #define SRST_TOPDBG 12 229 #define SRST_CORE_NIU 13 230 #define SRST_STRC_A 14 231 #define SRST_L2C 15 232 233 #define SRST_A53_GIC 18 234 #define SRST_DAP 19 235 #define SRST_PMU_P 21 236 #define SRST_EFUSE 22 237 #define SRST_BUSSYS_H 23 238 #define SRST_BUSSYS_P 24 239 #define SRST_SPDIF 25 240 #define SRST_INTMEM 26 241 #define SRST_ROM 27 242 #define SRST_GPIO0 28 243 #define SRST_GPIO1 29 244 #define SRST_GPIO2 30 245 #define SRST_GPIO3 31 246 247 #define SRST_I2S0 32 248 #define SRST_I2S1 33 249 #define SRST_I2S2 34 250 #define SRST_I2S0_H 35 251 #define SRST_I2S1_H 36 252 #define SRST_I2S2_H 37 253 #define SRST_UART0 38 254 #define SRST_UART1 39 255 #define SRST_UART2 40 256 #define SRST_UART0_P 41 257 #define SRST_UART1_P 42 258 #define SRST_UART2_P 43 259 #define SRST_I2C0 44 260 #define SRST_I2C1 45 261 #define SRST_I2C2 46 262 #define SRST_I2C3 47 263 264 #define SRST_I2C0_P 48 265 #define SRST_I2C1_P 49 266 #define SRST_I2C2_P 50 267 #define SRST_I2C3_P 51 268 #define SRST_EFUSE_SE_P 52 269 #define SRST_EFUSE_NS_P 53 270 #define SRST_PWM0 54 271 #define SRST_PWM0_P 55 272 #define SRST_DMA 56 273 #define SRST_TSP_A 57 274 #define SRST_TSP_H 58 275 #define SRST_TSP 59 276 #define SRST_TSP_HSADC 60 277 #define SRST_DCF_A 61 278 #define SRST_DCF_P 62 279 280 #define SRST_SCR 64 281 #define SRST_SPI 65 282 #define SRST_TSADC 66 283 #define SRST_TSADC_P 67 284 #define SRST_CRYPTO 68 285 #define SRST_SGRF 69 286 #define SRST_GRF 70 287 #define SRST_USB_GRF 71 288 #define SRST_TIMER_6CH_P 72 289 #define SRST_TIMER0 73 290 #define SRST_TIMER1 74 291 #define SRST_TIMER2 75 292 #define SRST_TIMER3 76 293 #define SRST_TIMER4 77 294 #define SRST_TIMER5 78 295 #define SRST_USB3GRF 79 296 297 #define SRST_PHYNIU 80 298 #define SRST_HDMIPHY 81 299 #define SRST_VDAC 82 300 #define SRST_ACODEC_p 83 301 #define SRST_SARADC 85 302 #define SRST_SARADC_P 86 303 #define SRST_GRF_DDR 87 304 #define SRST_DFIMON 88 305 #define SRST_MSCH 89 306 #define SRST_DDRMSCH 91 307 #define SRST_DDRCTRL 92 308 #define SRST_DDRCTRL_P 93 309 #define SRST_DDRPHY 94 310 #define SRST_DDRPHY_P 95 311 312 #define SRST_GMAC_NIU_A 96 313 #define SRST_GMAC_NIU_P 97 314 #define SRST_GMAC2PHY_A 98 315 #define SRST_GMAC2IO_A 99 316 #define SRST_MACPHY 100 317 #define SRST_OTP_PHY 101 318 #define SRST_GPU_A 102 319 #define SRST_GPU_NIU_A 103 320 #define SRST_SDMMCEXT 104 321 #define SRST_PERIPH_NIU_A 105 322 #define SRST_PERIHP_NIU_H 106 323 #define SRST_PERIHP_P 107 324 #define SRST_PERIPHSYS_H 108 325 #define SRST_MMC0 109 326 #define SRST_SDIO 110 327 #define SRST_EMMC 111 328 329 #define SRST_USB2OTG_H 112 330 #define SRST_USB2OTG 113 331 #define SRST_USB2OTG_ADP 114 332 #define SRST_USB2HOST_H 115 333 #define SRST_USB2HOST_ARB 116 334 #define SRST_USB2HOST_AUX 117 335 #define SRST_USB2HOST_EHCIPHY 118 336 #define SRST_USB2HOST_UTMI 119 337 #define SRST_USB3OTG 120 338 #define SRST_USBPOR 121 339 #define SRST_USB2OTG_UTMI 122 340 #define SRST_USB2HOST_PHY_UTMI 123 341 #define SRST_USB3OTG_UTMI 124 342 #define SRST_USB3PHY_U2 125 343 #define SRST_USB3PHY_U3 126 344 #define SRST_USB3PHY_PIPE 127 345 346 #define SRST_VIO_A 128 347 #define SRST_VIO_BUS_H 129 348 #define SRST_VIO_H2P_H 130 349 #define SRST_VIO_ARBI_H 131 350 #define SRST_VOP_NIU_A 132 351 #define SRST_VOP_A 133 352 #define SRST_VOP_H 134 353 #define SRST_VOP_D 135 354 #define SRST_RGA 136 355 #define SRST_RGA_NIU_A 137 356 #define SRST_RGA_A 138 357 #define SRST_RGA_H 139 358 #define SRST_IEP_A 140 359 #define SRST_IEP_H 141 360 #define SRST_HDMI 142 361 #define SRST_HDMI_P 143 362 363 #define SRST_HDCP_A 144 364 #define SRST_HDCP 145 365 #define SRST_HDCP_H 146 366 #define SRST_CIF_A 147 367 #define SRST_CIF_H 148 368 #define SRST_CIF_P 149 369 #define SRST_OTP_P 150 370 #define SRST_OTP_SBPI 151 371 #define SRST_OTP_USER 152 372 #define SRST_DDRCTRL_A 153 373 #define SRST_DDRSTDY_P 154 374 #define SRST_DDRSTDY 155 375 #define SRST_PDM_H 156 376 #define SRST_PDM 157 377 #define SRST_USB3PHY_OTG_P 158 378 #define SRST_USB3PHY_PIPE_P 159 379 380 #define SRST_VCODEC_A 160 381 #define SRST_VCODEC_NIU_A 161 382 #define SRST_VCODEC_H 162 383 #define SRST_VCODEC_NIU_H 163 384 #define SRST_VDEC_A 164 385 #define SRST_VDEC_NIU_A 165 386 #define SRST_VDEC_H 166 387 #define SRST_VDEC_NIU_H 167 388 #define SRST_VDEC_CORE 168 389 #define SRST_VDEC_CABAC 169 390 #define SRST_DDRPHYDIV 175 391 392 #define SRST_RKVENC_NIU_A 176 393 #define SRST_RKVENC_NIU_H 177 394 #define SRST_RKVENC_H265_A 178 395 #define SRST_RKVENC_H265_P 179 396 #define SRST_RKVENC_H265_CORE 180 397 #define SRST_RKVENC_H265_DSP 181 398 #define SRST_RKVENC_H264_A 182 399 #define SRST_RKVENC_H264_H 183 400 #define SRST_RKVENC_INTMEM 184 401 402 #endif 403