1 1.1 jmcneill /* $NetBSD: imx8mm-clock.h,v 1.1.1.3 2021/11/07 16:49:59 jmcneill Exp $ */ 2 1.1 jmcneill 3 1.1 jmcneill /* SPDX-License-Identifier: GPL-2.0 */ 4 1.1 jmcneill /* 5 1.1 jmcneill * Copyright 2017-2018 NXP 6 1.1 jmcneill */ 7 1.1 jmcneill 8 1.1 jmcneill #ifndef __DT_BINDINGS_CLOCK_IMX8MM_H 9 1.1 jmcneill #define __DT_BINDINGS_CLOCK_IMX8MM_H 10 1.1 jmcneill 11 1.1 jmcneill #define IMX8MM_CLK_DUMMY 0 12 1.1 jmcneill #define IMX8MM_CLK_32K 1 13 1.1 jmcneill #define IMX8MM_CLK_24M 2 14 1.1 jmcneill #define IMX8MM_OSC_HDMI_CLK 3 15 1.1 jmcneill #define IMX8MM_CLK_EXT1 4 16 1.1 jmcneill #define IMX8MM_CLK_EXT2 5 17 1.1 jmcneill #define IMX8MM_CLK_EXT3 6 18 1.1 jmcneill #define IMX8MM_CLK_EXT4 7 19 1.1 jmcneill #define IMX8MM_AUDIO_PLL1_REF_SEL 8 20 1.1 jmcneill #define IMX8MM_AUDIO_PLL2_REF_SEL 9 21 1.1 jmcneill #define IMX8MM_VIDEO_PLL1_REF_SEL 10 22 1.1 jmcneill #define IMX8MM_DRAM_PLL_REF_SEL 11 23 1.1 jmcneill #define IMX8MM_GPU_PLL_REF_SEL 12 24 1.1 jmcneill #define IMX8MM_VPU_PLL_REF_SEL 13 25 1.1 jmcneill #define IMX8MM_ARM_PLL_REF_SEL 14 26 1.1 jmcneill #define IMX8MM_SYS_PLL1_REF_SEL 15 27 1.1 jmcneill #define IMX8MM_SYS_PLL2_REF_SEL 16 28 1.1 jmcneill #define IMX8MM_SYS_PLL3_REF_SEL 17 29 1.1 jmcneill #define IMX8MM_AUDIO_PLL1 18 30 1.1 jmcneill #define IMX8MM_AUDIO_PLL2 19 31 1.1 jmcneill #define IMX8MM_VIDEO_PLL1 20 32 1.1 jmcneill #define IMX8MM_DRAM_PLL 21 33 1.1 jmcneill #define IMX8MM_GPU_PLL 22 34 1.1 jmcneill #define IMX8MM_VPU_PLL 23 35 1.1 jmcneill #define IMX8MM_ARM_PLL 24 36 1.1 jmcneill #define IMX8MM_SYS_PLL1 25 37 1.1 jmcneill #define IMX8MM_SYS_PLL2 26 38 1.1 jmcneill #define IMX8MM_SYS_PLL3 27 39 1.1 jmcneill #define IMX8MM_AUDIO_PLL1_BYPASS 28 40 1.1 jmcneill #define IMX8MM_AUDIO_PLL2_BYPASS 29 41 1.1 jmcneill #define IMX8MM_VIDEO_PLL1_BYPASS 30 42 1.1 jmcneill #define IMX8MM_DRAM_PLL_BYPASS 31 43 1.1 jmcneill #define IMX8MM_GPU_PLL_BYPASS 32 44 1.1 jmcneill #define IMX8MM_VPU_PLL_BYPASS 33 45 1.1 jmcneill #define IMX8MM_ARM_PLL_BYPASS 34 46 1.1 jmcneill #define IMX8MM_SYS_PLL1_BYPASS 35 47 1.1 jmcneill #define IMX8MM_SYS_PLL2_BYPASS 36 48 1.1 jmcneill #define IMX8MM_SYS_PLL3_BYPASS 37 49 1.1 jmcneill #define IMX8MM_AUDIO_PLL1_OUT 38 50 1.1 jmcneill #define IMX8MM_AUDIO_PLL2_OUT 39 51 1.1 jmcneill #define IMX8MM_VIDEO_PLL1_OUT 40 52 1.1 jmcneill #define IMX8MM_DRAM_PLL_OUT 41 53 1.1 jmcneill #define IMX8MM_GPU_PLL_OUT 42 54 1.1 jmcneill #define IMX8MM_VPU_PLL_OUT 43 55 1.1 jmcneill #define IMX8MM_ARM_PLL_OUT 44 56 1.1 jmcneill #define IMX8MM_SYS_PLL1_OUT 45 57 1.1 jmcneill #define IMX8MM_SYS_PLL2_OUT 46 58 1.1 jmcneill #define IMX8MM_SYS_PLL3_OUT 47 59 1.1 jmcneill #define IMX8MM_SYS_PLL1_40M 48 60 1.1 jmcneill #define IMX8MM_SYS_PLL1_80M 49 61 1.1 jmcneill #define IMX8MM_SYS_PLL1_100M 50 62 1.1 jmcneill #define IMX8MM_SYS_PLL1_133M 51 63 1.1 jmcneill #define IMX8MM_SYS_PLL1_160M 52 64 1.1 jmcneill #define IMX8MM_SYS_PLL1_200M 53 65 1.1 jmcneill #define IMX8MM_SYS_PLL1_266M 54 66 1.1 jmcneill #define IMX8MM_SYS_PLL1_400M 55 67 1.1 jmcneill #define IMX8MM_SYS_PLL1_800M 56 68 1.1 jmcneill #define IMX8MM_SYS_PLL2_50M 57 69 1.1 jmcneill #define IMX8MM_SYS_PLL2_100M 58 70 1.1 jmcneill #define IMX8MM_SYS_PLL2_125M 59 71 1.1 jmcneill #define IMX8MM_SYS_PLL2_166M 60 72 1.1 jmcneill #define IMX8MM_SYS_PLL2_200M 61 73 1.1 jmcneill #define IMX8MM_SYS_PLL2_250M 62 74 1.1 jmcneill #define IMX8MM_SYS_PLL2_333M 63 75 1.1 jmcneill #define IMX8MM_SYS_PLL2_500M 64 76 1.1 jmcneill #define IMX8MM_SYS_PLL2_1000M 65 77 1.1 jmcneill 78 1.1 jmcneill /* core */ 79 1.1 jmcneill #define IMX8MM_CLK_A53_SRC 66 80 1.1 jmcneill #define IMX8MM_CLK_M4_SRC 67 81 1.1 jmcneill #define IMX8MM_CLK_VPU_SRC 68 82 1.1 jmcneill #define IMX8MM_CLK_GPU3D_SRC 69 83 1.1 jmcneill #define IMX8MM_CLK_GPU2D_SRC 70 84 1.1 jmcneill #define IMX8MM_CLK_A53_CG 71 85 1.1 jmcneill #define IMX8MM_CLK_M4_CG 72 86 1.1 jmcneill #define IMX8MM_CLK_VPU_CG 73 87 1.1 jmcneill #define IMX8MM_CLK_GPU3D_CG 74 88 1.1 jmcneill #define IMX8MM_CLK_GPU2D_CG 75 89 1.1 jmcneill #define IMX8MM_CLK_A53_DIV 76 90 1.1 jmcneill #define IMX8MM_CLK_M4_DIV 77 91 1.1 jmcneill #define IMX8MM_CLK_VPU_DIV 78 92 1.1 jmcneill #define IMX8MM_CLK_GPU3D_DIV 79 93 1.1 jmcneill #define IMX8MM_CLK_GPU2D_DIV 80 94 1.1 jmcneill 95 1.1 jmcneill /* bus */ 96 1.1 jmcneill #define IMX8MM_CLK_MAIN_AXI 81 97 1.1 jmcneill #define IMX8MM_CLK_ENET_AXI 82 98 1.1 jmcneill #define IMX8MM_CLK_NAND_USDHC_BUS 83 99 1.1 jmcneill #define IMX8MM_CLK_VPU_BUS 84 100 1.1 jmcneill #define IMX8MM_CLK_DISP_AXI 85 101 1.1 jmcneill #define IMX8MM_CLK_DISP_APB 86 102 1.1 jmcneill #define IMX8MM_CLK_DISP_RTRM 87 103 1.1 jmcneill #define IMX8MM_CLK_USB_BUS 88 104 1.1 jmcneill #define IMX8MM_CLK_GPU_AXI 89 105 1.1 jmcneill #define IMX8MM_CLK_GPU_AHB 90 106 1.1 jmcneill #define IMX8MM_CLK_NOC 91 107 1.1 jmcneill #define IMX8MM_CLK_NOC_APB 92 108 1.1 jmcneill 109 1.1 jmcneill #define IMX8MM_CLK_AHB 93 110 1.1 jmcneill #define IMX8MM_CLK_AUDIO_AHB 94 111 1.1 jmcneill #define IMX8MM_CLK_IPG_ROOT 95 112 1.1 jmcneill #define IMX8MM_CLK_IPG_AUDIO_ROOT 96 113 1.1 jmcneill 114 1.1 jmcneill #define IMX8MM_CLK_DRAM_ALT 97 115 1.1 jmcneill #define IMX8MM_CLK_DRAM_APB 98 116 1.1 jmcneill #define IMX8MM_CLK_VPU_G1 99 117 1.1 jmcneill #define IMX8MM_CLK_VPU_G2 100 118 1.1 jmcneill #define IMX8MM_CLK_DISP_DTRC 101 119 1.1 jmcneill #define IMX8MM_CLK_DISP_DC8000 102 120 1.1 jmcneill #define IMX8MM_CLK_PCIE1_CTRL 103 121 1.1 jmcneill #define IMX8MM_CLK_PCIE1_PHY 104 122 1.1 jmcneill #define IMX8MM_CLK_PCIE1_AUX 105 123 1.1 jmcneill #define IMX8MM_CLK_DC_PIXEL 106 124 1.1 jmcneill #define IMX8MM_CLK_LCDIF_PIXEL 107 125 1.1 jmcneill #define IMX8MM_CLK_SAI1 108 126 1.1 jmcneill #define IMX8MM_CLK_SAI2 109 127 1.1 jmcneill #define IMX8MM_CLK_SAI3 110 128 1.1 jmcneill #define IMX8MM_CLK_SAI4 111 129 1.1 jmcneill #define IMX8MM_CLK_SAI5 112 130 1.1 jmcneill #define IMX8MM_CLK_SAI6 113 131 1.1 jmcneill #define IMX8MM_CLK_SPDIF1 114 132 1.1 jmcneill #define IMX8MM_CLK_SPDIF2 115 133 1.1 jmcneill #define IMX8MM_CLK_ENET_REF 116 134 1.1 jmcneill #define IMX8MM_CLK_ENET_TIMER 117 135 1.1 jmcneill #define IMX8MM_CLK_ENET_PHY_REF 118 136 1.1 jmcneill #define IMX8MM_CLK_NAND 119 137 1.1 jmcneill #define IMX8MM_CLK_QSPI 120 138 1.1 jmcneill #define IMX8MM_CLK_USDHC1 121 139 1.1 jmcneill #define IMX8MM_CLK_USDHC2 122 140 1.1 jmcneill #define IMX8MM_CLK_I2C1 123 141 1.1 jmcneill #define IMX8MM_CLK_I2C2 124 142 1.1 jmcneill #define IMX8MM_CLK_I2C3 125 143 1.1 jmcneill #define IMX8MM_CLK_I2C4 126 144 1.1 jmcneill #define IMX8MM_CLK_UART1 127 145 1.1 jmcneill #define IMX8MM_CLK_UART2 128 146 1.1 jmcneill #define IMX8MM_CLK_UART3 129 147 1.1 jmcneill #define IMX8MM_CLK_UART4 130 148 1.1 jmcneill #define IMX8MM_CLK_USB_CORE_REF 131 149 1.1 jmcneill #define IMX8MM_CLK_USB_PHY_REF 132 150 1.1 jmcneill #define IMX8MM_CLK_ECSPI1 133 151 1.1 jmcneill #define IMX8MM_CLK_ECSPI2 134 152 1.1 jmcneill #define IMX8MM_CLK_PWM1 135 153 1.1 jmcneill #define IMX8MM_CLK_PWM2 136 154 1.1 jmcneill #define IMX8MM_CLK_PWM3 137 155 1.1 jmcneill #define IMX8MM_CLK_PWM4 138 156 1.1 jmcneill #define IMX8MM_CLK_GPT1 139 157 1.1 jmcneill #define IMX8MM_CLK_WDOG 140 158 1.1 jmcneill #define IMX8MM_CLK_WRCLK 141 159 1.1 jmcneill #define IMX8MM_CLK_DSI_CORE 142 160 1.1 jmcneill #define IMX8MM_CLK_DSI_PHY_REF 143 161 1.1 jmcneill #define IMX8MM_CLK_DSI_DBI 144 162 1.1 jmcneill #define IMX8MM_CLK_USDHC3 145 163 1.1 jmcneill #define IMX8MM_CLK_CSI1_CORE 146 164 1.1 jmcneill #define IMX8MM_CLK_CSI1_PHY_REF 147 165 1.1 jmcneill #define IMX8MM_CLK_CSI1_ESC 148 166 1.1 jmcneill #define IMX8MM_CLK_CSI2_CORE 149 167 1.1 jmcneill #define IMX8MM_CLK_CSI2_PHY_REF 150 168 1.1 jmcneill #define IMX8MM_CLK_CSI2_ESC 151 169 1.1 jmcneill #define IMX8MM_CLK_PCIE2_CTRL 152 170 1.1 jmcneill #define IMX8MM_CLK_PCIE2_PHY 153 171 1.1 jmcneill #define IMX8MM_CLK_PCIE2_AUX 154 172 1.1 jmcneill #define IMX8MM_CLK_ECSPI3 155 173 1.1 jmcneill #define IMX8MM_CLK_PDM 156 174 1.1 jmcneill #define IMX8MM_CLK_VPU_H1 157 175 1.1 jmcneill #define IMX8MM_CLK_CLKO1 158 176 1.1 jmcneill 177 1.1 jmcneill #define IMX8MM_CLK_ECSPI1_ROOT 159 178 1.1 jmcneill #define IMX8MM_CLK_ECSPI2_ROOT 160 179 1.1 jmcneill #define IMX8MM_CLK_ECSPI3_ROOT 161 180 1.1 jmcneill #define IMX8MM_CLK_ENET1_ROOT 162 181 1.1 jmcneill #define IMX8MM_CLK_GPT1_ROOT 163 182 1.1 jmcneill #define IMX8MM_CLK_I2C1_ROOT 164 183 1.1 jmcneill #define IMX8MM_CLK_I2C2_ROOT 165 184 1.1 jmcneill #define IMX8MM_CLK_I2C3_ROOT 166 185 1.1 jmcneill #define IMX8MM_CLK_I2C4_ROOT 167 186 1.1 jmcneill #define IMX8MM_CLK_OCOTP_ROOT 168 187 1.1 jmcneill #define IMX8MM_CLK_PCIE1_ROOT 169 188 1.1 jmcneill #define IMX8MM_CLK_PWM1_ROOT 170 189 1.1 jmcneill #define IMX8MM_CLK_PWM2_ROOT 171 190 1.1 jmcneill #define IMX8MM_CLK_PWM3_ROOT 172 191 1.1 jmcneill #define IMX8MM_CLK_PWM4_ROOT 173 192 1.1 jmcneill #define IMX8MM_CLK_QSPI_ROOT 174 193 1.1 jmcneill #define IMX8MM_CLK_NAND_ROOT 175 194 1.1 jmcneill #define IMX8MM_CLK_SAI1_ROOT 176 195 1.1 jmcneill #define IMX8MM_CLK_SAI1_IPG 177 196 1.1 jmcneill #define IMX8MM_CLK_SAI2_ROOT 178 197 1.1 jmcneill #define IMX8MM_CLK_SAI2_IPG 179 198 1.1 jmcneill #define IMX8MM_CLK_SAI3_ROOT 180 199 1.1 jmcneill #define IMX8MM_CLK_SAI3_IPG 181 200 1.1 jmcneill #define IMX8MM_CLK_SAI4_ROOT 182 201 1.1 jmcneill #define IMX8MM_CLK_SAI4_IPG 183 202 1.1 jmcneill #define IMX8MM_CLK_SAI5_ROOT 184 203 1.1 jmcneill #define IMX8MM_CLK_SAI5_IPG 185 204 1.1 jmcneill #define IMX8MM_CLK_SAI6_ROOT 186 205 1.1 jmcneill #define IMX8MM_CLK_SAI6_IPG 187 206 1.1 jmcneill #define IMX8MM_CLK_UART1_ROOT 188 207 1.1 jmcneill #define IMX8MM_CLK_UART2_ROOT 189 208 1.1 jmcneill #define IMX8MM_CLK_UART3_ROOT 190 209 1.1 jmcneill #define IMX8MM_CLK_UART4_ROOT 191 210 1.1 jmcneill #define IMX8MM_CLK_USB1_CTRL_ROOT 192 211 1.1 jmcneill #define IMX8MM_CLK_GPU3D_ROOT 193 212 1.1 jmcneill #define IMX8MM_CLK_USDHC1_ROOT 194 213 1.1 jmcneill #define IMX8MM_CLK_USDHC2_ROOT 195 214 1.1 jmcneill #define IMX8MM_CLK_WDOG1_ROOT 196 215 1.1 jmcneill #define IMX8MM_CLK_WDOG2_ROOT 197 216 1.1 jmcneill #define IMX8MM_CLK_WDOG3_ROOT 198 217 1.1 jmcneill #define IMX8MM_CLK_VPU_G1_ROOT 199 218 1.1 jmcneill #define IMX8MM_CLK_GPU_BUS_ROOT 200 219 1.1 jmcneill #define IMX8MM_CLK_VPU_H1_ROOT 201 220 1.1 jmcneill #define IMX8MM_CLK_VPU_G2_ROOT 202 221 1.1 jmcneill #define IMX8MM_CLK_PDM_ROOT 203 222 1.1 jmcneill #define IMX8MM_CLK_DISP_ROOT 204 223 1.1 jmcneill #define IMX8MM_CLK_DISP_AXI_ROOT 205 224 1.1 jmcneill #define IMX8MM_CLK_DISP_APB_ROOT 206 225 1.1 jmcneill #define IMX8MM_CLK_DISP_RTRM_ROOT 207 226 1.1 jmcneill #define IMX8MM_CLK_USDHC3_ROOT 208 227 1.1 jmcneill #define IMX8MM_CLK_TMU_ROOT 209 228 1.1 jmcneill #define IMX8MM_CLK_VPU_DEC_ROOT 210 229 1.1 jmcneill #define IMX8MM_CLK_SDMA1_ROOT 211 230 1.1 jmcneill #define IMX8MM_CLK_SDMA2_ROOT 212 231 1.1 jmcneill #define IMX8MM_CLK_SDMA3_ROOT 213 232 1.1 jmcneill #define IMX8MM_CLK_GPT_3M 214 233 1.1 jmcneill #define IMX8MM_CLK_ARM 215 234 1.1 jmcneill #define IMX8MM_CLK_PDM_IPG 216 235 1.1 jmcneill #define IMX8MM_CLK_GPU2D_ROOT 217 236 1.1 jmcneill #define IMX8MM_CLK_MU_ROOT 218 237 1.1 jmcneill #define IMX8MM_CLK_CSI1_ROOT 219 238 1.1 jmcneill 239 1.1 jmcneill #define IMX8MM_CLK_DRAM_CORE 220 240 1.1 jmcneill #define IMX8MM_CLK_DRAM_ALT_ROOT 221 241 1.1 jmcneill 242 1.1 jmcneill #define IMX8MM_CLK_NAND_USDHC_BUS_RAWNAND_CLK 222 243 1.1 jmcneill 244 1.1.1.2 skrll #define IMX8MM_CLK_GPIO1_ROOT 223 245 1.1.1.2 skrll #define IMX8MM_CLK_GPIO2_ROOT 224 246 1.1.1.2 skrll #define IMX8MM_CLK_GPIO3_ROOT 225 247 1.1.1.2 skrll #define IMX8MM_CLK_GPIO4_ROOT 226 248 1.1.1.2 skrll #define IMX8MM_CLK_GPIO5_ROOT 227 249 1.1.1.2 skrll 250 1.1.1.2 skrll #define IMX8MM_CLK_SNVS_ROOT 228 251 1.1.1.2 skrll #define IMX8MM_CLK_GIC 229 252 1.1.1.2 skrll 253 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_40M_CG 230 254 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_80M_CG 231 255 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_100M_CG 232 256 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_133M_CG 233 257 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_160M_CG 234 258 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_200M_CG 235 259 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_266M_CG 236 260 1.1.1.2 skrll #define IMX8MM_SYS_PLL1_400M_CG 237 261 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_50M_CG 238 262 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_100M_CG 239 263 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_125M_CG 240 264 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_166M_CG 241 265 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_200M_CG 242 266 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_250M_CG 243 267 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_333M_CG 244 268 1.1.1.2 skrll #define IMX8MM_SYS_PLL2_500M_CG 245 269 1.1.1.2 skrll 270 1.1.1.3 jmcneill #define IMX8MM_CLK_M4_CORE 246 271 1.1.1.3 jmcneill #define IMX8MM_CLK_VPU_CORE 247 272 1.1.1.3 jmcneill #define IMX8MM_CLK_GPU3D_CORE 248 273 1.1.1.3 jmcneill #define IMX8MM_CLK_GPU2D_CORE 249 274 1.1.1.3 jmcneill 275 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKO2 250 276 1.1.1.3 jmcneill 277 1.1.1.3 jmcneill #define IMX8MM_CLK_A53_CORE 251 278 1.1.1.3 jmcneill 279 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT1_SEL 252 280 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT1_DIV 253 281 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT1 254 282 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT2_SEL 255 283 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT2_DIV 256 284 1.1.1.3 jmcneill #define IMX8MM_CLK_CLKOUT2 257 285 1.1.1.3 jmcneill 286 1.1.1.3 jmcneill 287 1.1.1.3 jmcneill #define IMX8MM_CLK_END 258 288 1.1 jmcneill 289 1.1 jmcneill #endif 290