11e80936aSAnson Huang /* SPDX-License-Identifier: GPL-2.0 */
21e80936aSAnson Huang /*
31e80936aSAnson Huang  * Copyright 2018-2019 NXP
41e80936aSAnson Huang  */
51e80936aSAnson Huang 
61e80936aSAnson Huang #ifndef __DT_BINDINGS_CLOCK_IMX8MN_H
71e80936aSAnson Huang #define __DT_BINDINGS_CLOCK_IMX8MN_H
81e80936aSAnson Huang 
91e80936aSAnson Huang #define IMX8MN_CLK_DUMMY			0
101e80936aSAnson Huang #define IMX8MN_CLK_32K				1
111e80936aSAnson Huang #define IMX8MN_CLK_24M				2
121e80936aSAnson Huang #define IMX8MN_OSC_HDMI_CLK			3
131e80936aSAnson Huang #define IMX8MN_CLK_EXT1				4
141e80936aSAnson Huang #define IMX8MN_CLK_EXT2				5
151e80936aSAnson Huang #define IMX8MN_CLK_EXT3				6
161e80936aSAnson Huang #define IMX8MN_CLK_EXT4				7
171e80936aSAnson Huang #define IMX8MN_AUDIO_PLL1_REF_SEL		8
181e80936aSAnson Huang #define IMX8MN_AUDIO_PLL2_REF_SEL		9
191e80936aSAnson Huang #define IMX8MN_VIDEO_PLL1_REF_SEL		10
201e80936aSAnson Huang #define IMX8MN_DRAM_PLL_REF_SEL			11
211e80936aSAnson Huang #define IMX8MN_GPU_PLL_REF_SEL			12
22*a429c60bSDario Binacchi #define IMX8MN_M7_ALT_PLL_REF_SEL		13
23*a429c60bSDario Binacchi #define IMX8MN_VPU_PLL_REF_SEL			IMX8MN_M7_ALT_PLL_REF_SEL
241e80936aSAnson Huang #define IMX8MN_ARM_PLL_REF_SEL			14
251e80936aSAnson Huang #define IMX8MN_SYS_PLL1_REF_SEL			15
261e80936aSAnson Huang #define IMX8MN_SYS_PLL2_REF_SEL			16
271e80936aSAnson Huang #define IMX8MN_SYS_PLL3_REF_SEL			17
281e80936aSAnson Huang #define IMX8MN_AUDIO_PLL1			18
291e80936aSAnson Huang #define IMX8MN_AUDIO_PLL2			19
301e80936aSAnson Huang #define IMX8MN_VIDEO_PLL1			20
311e80936aSAnson Huang #define IMX8MN_DRAM_PLL				21
321e80936aSAnson Huang #define IMX8MN_GPU_PLL				22
33*a429c60bSDario Binacchi #define IMX8MN_M7_ALT_PLL			23
34*a429c60bSDario Binacchi #define IMX8MN_VPU_PLL				IMX8MN_M7_ALT_PLL
351e80936aSAnson Huang #define IMX8MN_ARM_PLL				24
361e80936aSAnson Huang #define IMX8MN_SYS_PLL1				25
371e80936aSAnson Huang #define IMX8MN_SYS_PLL2				26
381e80936aSAnson Huang #define IMX8MN_SYS_PLL3				27
391e80936aSAnson Huang #define IMX8MN_AUDIO_PLL1_BYPASS		28
401e80936aSAnson Huang #define IMX8MN_AUDIO_PLL2_BYPASS		29
411e80936aSAnson Huang #define IMX8MN_VIDEO_PLL1_BYPASS		30
421e80936aSAnson Huang #define IMX8MN_DRAM_PLL_BYPASS			31
431e80936aSAnson Huang #define IMX8MN_GPU_PLL_BYPASS			32
44*a429c60bSDario Binacchi #define IMX8MN_M7_ALT_PLL_BYPASS		33
45*a429c60bSDario Binacchi #define IMX8MN_VPU_PLL_BYPASS			IMX8MN_M7_ALT_PLL_BYPASS
461e80936aSAnson Huang #define IMX8MN_ARM_PLL_BYPASS			34
471e80936aSAnson Huang #define IMX8MN_SYS_PLL1_BYPASS			35
481e80936aSAnson Huang #define IMX8MN_SYS_PLL2_BYPASS			36
491e80936aSAnson Huang #define IMX8MN_SYS_PLL3_BYPASS			37
501e80936aSAnson Huang #define IMX8MN_AUDIO_PLL1_OUT			38
511e80936aSAnson Huang #define IMX8MN_AUDIO_PLL2_OUT			39
521e80936aSAnson Huang #define IMX8MN_VIDEO_PLL1_OUT			40
531e80936aSAnson Huang #define IMX8MN_DRAM_PLL_OUT			41
541e80936aSAnson Huang #define IMX8MN_GPU_PLL_OUT			42
55*a429c60bSDario Binacchi #define IMX8MN_M7_ALT_PLL_OUT			43
56*a429c60bSDario Binacchi #define IMX8MN_VPU_PLL_OUT			IMX8MN_M7_ALT_PLL_OUT
571e80936aSAnson Huang #define IMX8MN_ARM_PLL_OUT			44
581e80936aSAnson Huang #define IMX8MN_SYS_PLL1_OUT			45
591e80936aSAnson Huang #define IMX8MN_SYS_PLL2_OUT			46
601e80936aSAnson Huang #define IMX8MN_SYS_PLL3_OUT			47
611e80936aSAnson Huang #define IMX8MN_SYS_PLL1_40M			48
621e80936aSAnson Huang #define IMX8MN_SYS_PLL1_80M			49
631e80936aSAnson Huang #define IMX8MN_SYS_PLL1_100M			50
641e80936aSAnson Huang #define IMX8MN_SYS_PLL1_133M			51
651e80936aSAnson Huang #define IMX8MN_SYS_PLL1_160M			52
661e80936aSAnson Huang #define IMX8MN_SYS_PLL1_200M			53
671e80936aSAnson Huang #define IMX8MN_SYS_PLL1_266M			54
681e80936aSAnson Huang #define IMX8MN_SYS_PLL1_400M			55
691e80936aSAnson Huang #define IMX8MN_SYS_PLL1_800M			56
701e80936aSAnson Huang #define IMX8MN_SYS_PLL2_50M			57
711e80936aSAnson Huang #define IMX8MN_SYS_PLL2_100M			58
721e80936aSAnson Huang #define IMX8MN_SYS_PLL2_125M			59
731e80936aSAnson Huang #define IMX8MN_SYS_PLL2_166M			60
741e80936aSAnson Huang #define IMX8MN_SYS_PLL2_200M			61
751e80936aSAnson Huang #define IMX8MN_SYS_PLL2_250M			62
761e80936aSAnson Huang #define IMX8MN_SYS_PLL2_333M			63
771e80936aSAnson Huang #define IMX8MN_SYS_PLL2_500M			64
781e80936aSAnson Huang #define IMX8MN_SYS_PLL2_1000M			65
791e80936aSAnson Huang 
801e80936aSAnson Huang /* CORE CLOCK ROOT */
811e80936aSAnson Huang #define IMX8MN_CLK_A53_SRC			66
821e80936aSAnson Huang #define IMX8MN_CLK_GPU_CORE_SRC			67
831e80936aSAnson Huang #define IMX8MN_CLK_GPU_SHADER_SRC		68
841e80936aSAnson Huang #define IMX8MN_CLK_A53_CG			69
851e80936aSAnson Huang #define IMX8MN_CLK_GPU_CORE_CG			70
861e80936aSAnson Huang #define IMX8MN_CLK_GPU_SHADER_CG		71
871e80936aSAnson Huang #define IMX8MN_CLK_A53_DIV			72
881e80936aSAnson Huang #define IMX8MN_CLK_GPU_CORE_DIV			73
891e80936aSAnson Huang #define IMX8MN_CLK_GPU_SHADER_DIV		74
901e80936aSAnson Huang 
911e80936aSAnson Huang /* BUS CLOCK ROOT */
921e80936aSAnson Huang #define IMX8MN_CLK_MAIN_AXI			75
931e80936aSAnson Huang #define IMX8MN_CLK_ENET_AXI			76
941e80936aSAnson Huang #define IMX8MN_CLK_NAND_USDHC_BUS		77
951e80936aSAnson Huang #define IMX8MN_CLK_DISP_AXI			78
961e80936aSAnson Huang #define IMX8MN_CLK_DISP_APB			79
971e80936aSAnson Huang #define IMX8MN_CLK_USB_BUS			80
981e80936aSAnson Huang #define IMX8MN_CLK_GPU_AXI			81
991e80936aSAnson Huang #define IMX8MN_CLK_GPU_AHB			82
1001e80936aSAnson Huang #define IMX8MN_CLK_NOC				83
1011e80936aSAnson Huang #define IMX8MN_CLK_AHB				84
1021e80936aSAnson Huang #define IMX8MN_CLK_AUDIO_AHB			85
1031e80936aSAnson Huang 
1041e80936aSAnson Huang /* IPG CLOCK ROOT */
1051e80936aSAnson Huang #define IMX8MN_CLK_IPG_ROOT			86
1061e80936aSAnson Huang #define IMX8MN_CLK_IPG_AUDIO_ROOT		87
1071e80936aSAnson Huang 
1081e80936aSAnson Huang /* IP */
1091e80936aSAnson Huang #define IMX8MN_CLK_DRAM_CORE			88
1101e80936aSAnson Huang #define IMX8MN_CLK_DRAM_ALT			89
1111e80936aSAnson Huang #define IMX8MN_CLK_DRAM_APB			90
1121e80936aSAnson Huang #define IMX8MN_CLK_DRAM_ALT_ROOT		91
1131e80936aSAnson Huang #define IMX8MN_CLK_DISP_PIXEL			92
1141e80936aSAnson Huang #define IMX8MN_CLK_SAI2				93
1151e80936aSAnson Huang #define IMX8MN_CLK_SAI3				94
1161e80936aSAnson Huang #define IMX8MN_CLK_SAI5				95
1171e80936aSAnson Huang #define IMX8MN_CLK_SAI6				96
1181e80936aSAnson Huang #define IMX8MN_CLK_SPDIF1			97
1191e80936aSAnson Huang #define IMX8MN_CLK_ENET_REF			98
1201e80936aSAnson Huang #define IMX8MN_CLK_ENET_TIMER			99
1211e80936aSAnson Huang #define IMX8MN_CLK_ENET_PHY_REF			100
1221e80936aSAnson Huang #define IMX8MN_CLK_NAND				101
1231e80936aSAnson Huang #define IMX8MN_CLK_QSPI				102
1241e80936aSAnson Huang #define IMX8MN_CLK_USDHC1			103
1251e80936aSAnson Huang #define IMX8MN_CLK_USDHC2			104
1261e80936aSAnson Huang #define IMX8MN_CLK_I2C1				105
1271e80936aSAnson Huang #define IMX8MN_CLK_I2C2				106
1281e80936aSAnson Huang #define IMX8MN_CLK_I2C3				107
1295eb40257SAnson Huang #define IMX8MN_CLK_I2C4				108
1305eb40257SAnson Huang #define IMX8MN_CLK_UART1			109
1311e80936aSAnson Huang #define IMX8MN_CLK_UART2			110
1321e80936aSAnson Huang #define IMX8MN_CLK_UART3			111
1331e80936aSAnson Huang #define IMX8MN_CLK_UART4			112
1341e80936aSAnson Huang #define IMX8MN_CLK_USB_CORE_REF			113
1351e80936aSAnson Huang #define IMX8MN_CLK_USB_PHY_REF			114
1361e80936aSAnson Huang #define IMX8MN_CLK_ECSPI1			115
1371e80936aSAnson Huang #define IMX8MN_CLK_ECSPI2			116
1381e80936aSAnson Huang #define IMX8MN_CLK_PWM1				117
1391e80936aSAnson Huang #define IMX8MN_CLK_PWM2				118
1401e80936aSAnson Huang #define IMX8MN_CLK_PWM3				119
1411e80936aSAnson Huang #define IMX8MN_CLK_PWM4				120
1421e80936aSAnson Huang #define IMX8MN_CLK_WDOG				121
1431e80936aSAnson Huang #define IMX8MN_CLK_WRCLK			122
1441e80936aSAnson Huang #define IMX8MN_CLK_CLKO1			123
1451e80936aSAnson Huang #define IMX8MN_CLK_CLKO2			124
1461e80936aSAnson Huang #define IMX8MN_CLK_DSI_CORE			125
1471e80936aSAnson Huang #define IMX8MN_CLK_DSI_PHY_REF			126
1481e80936aSAnson Huang #define IMX8MN_CLK_DSI_DBI			127
1491e80936aSAnson Huang #define IMX8MN_CLK_USDHC3			128
1501e80936aSAnson Huang #define IMX8MN_CLK_CAMERA_PIXEL			129
1511e80936aSAnson Huang #define IMX8MN_CLK_CSI1_PHY_REF			130
1521e80936aSAnson Huang #define IMX8MN_CLK_CSI2_PHY_REF			131
1531e80936aSAnson Huang #define IMX8MN_CLK_CSI2_ESC			132
1541e80936aSAnson Huang #define IMX8MN_CLK_ECSPI3			133
1551e80936aSAnson Huang #define IMX8MN_CLK_PDM				134
1561e80936aSAnson Huang #define IMX8MN_CLK_SAI7				135
1571e80936aSAnson Huang 
1581e80936aSAnson Huang #define IMX8MN_CLK_ECSPI1_ROOT			136
1591e80936aSAnson Huang #define IMX8MN_CLK_ECSPI2_ROOT			137
1601e80936aSAnson Huang #define IMX8MN_CLK_ECSPI3_ROOT			138
1611e80936aSAnson Huang #define IMX8MN_CLK_ENET1_ROOT			139
1621e80936aSAnson Huang #define IMX8MN_CLK_GPIO1_ROOT			140
1631e80936aSAnson Huang #define IMX8MN_CLK_GPIO2_ROOT			141
1641e80936aSAnson Huang #define IMX8MN_CLK_GPIO3_ROOT			142
1651e80936aSAnson Huang #define IMX8MN_CLK_GPIO4_ROOT			143
1661e80936aSAnson Huang #define IMX8MN_CLK_GPIO5_ROOT			144
1671e80936aSAnson Huang #define IMX8MN_CLK_I2C1_ROOT			145
1681e80936aSAnson Huang #define IMX8MN_CLK_I2C2_ROOT			146
1691e80936aSAnson Huang #define IMX8MN_CLK_I2C3_ROOT			147
1701e80936aSAnson Huang #define IMX8MN_CLK_I2C4_ROOT			148
1711e80936aSAnson Huang #define IMX8MN_CLK_MU_ROOT			149
1721e80936aSAnson Huang #define IMX8MN_CLK_OCOTP_ROOT			150
1731e80936aSAnson Huang #define IMX8MN_CLK_PWM1_ROOT			151
1741e80936aSAnson Huang #define IMX8MN_CLK_PWM2_ROOT			152
1751e80936aSAnson Huang #define IMX8MN_CLK_PWM3_ROOT			153
1761e80936aSAnson Huang #define IMX8MN_CLK_PWM4_ROOT			154
1771e80936aSAnson Huang #define IMX8MN_CLK_QSPI_ROOT			155
1781e80936aSAnson Huang #define IMX8MN_CLK_NAND_ROOT			156
1791e80936aSAnson Huang #define IMX8MN_CLK_SAI2_ROOT			157
1801e80936aSAnson Huang #define IMX8MN_CLK_SAI2_IPG			158
1811e80936aSAnson Huang #define IMX8MN_CLK_SAI3_ROOT			159
1821e80936aSAnson Huang #define IMX8MN_CLK_SAI3_IPG			160
1831e80936aSAnson Huang #define IMX8MN_CLK_SAI5_ROOT			161
1841e80936aSAnson Huang #define IMX8MN_CLK_SAI5_IPG			162
1851e80936aSAnson Huang #define IMX8MN_CLK_SAI6_ROOT			163
1861e80936aSAnson Huang #define IMX8MN_CLK_SAI6_IPG			164
1871e80936aSAnson Huang #define IMX8MN_CLK_SAI7_ROOT			165
1881e80936aSAnson Huang #define IMX8MN_CLK_SAI7_IPG			166
1891e80936aSAnson Huang #define IMX8MN_CLK_SDMA1_ROOT			167
1901e80936aSAnson Huang #define IMX8MN_CLK_SDMA2_ROOT			168
1911e80936aSAnson Huang #define IMX8MN_CLK_UART1_ROOT			169
1921e80936aSAnson Huang #define IMX8MN_CLK_UART2_ROOT			170
1931e80936aSAnson Huang #define IMX8MN_CLK_UART3_ROOT			171
1941e80936aSAnson Huang #define IMX8MN_CLK_UART4_ROOT			172
1951e80936aSAnson Huang #define IMX8MN_CLK_USB1_CTRL_ROOT		173
1961e80936aSAnson Huang #define IMX8MN_CLK_USDHC1_ROOT			174
1971e80936aSAnson Huang #define IMX8MN_CLK_USDHC2_ROOT			175
1981e80936aSAnson Huang #define IMX8MN_CLK_WDOG1_ROOT			176
1991e80936aSAnson Huang #define IMX8MN_CLK_WDOG2_ROOT			177
2001e80936aSAnson Huang #define IMX8MN_CLK_WDOG3_ROOT			178
2011e80936aSAnson Huang #define IMX8MN_CLK_GPU_BUS_ROOT			179
2021e80936aSAnson Huang #define IMX8MN_CLK_ASRC_ROOT			180
2031e80936aSAnson Huang #define IMX8MN_CLK_GPU3D_ROOT			181
2041e80936aSAnson Huang #define IMX8MN_CLK_PDM_ROOT			182
2051e80936aSAnson Huang #define IMX8MN_CLK_PDM_IPG			183
2061e80936aSAnson Huang #define IMX8MN_CLK_DISP_AXI_ROOT		184
2071e80936aSAnson Huang #define IMX8MN_CLK_DISP_APB_ROOT		185
2081e80936aSAnson Huang #define IMX8MN_CLK_DISP_PIXEL_ROOT		186
2091e80936aSAnson Huang #define IMX8MN_CLK_CAMERA_PIXEL_ROOT		187
2101e80936aSAnson Huang #define IMX8MN_CLK_USDHC3_ROOT			188
2111e80936aSAnson Huang #define IMX8MN_CLK_SDMA3_ROOT			189
2121e80936aSAnson Huang #define IMX8MN_CLK_TMU_ROOT			190
2131e80936aSAnson Huang #define IMX8MN_CLK_ARM				191
2141e80936aSAnson Huang #define IMX8MN_CLK_NAND_USDHC_BUS_RAWNAND_CLK	192
2151e80936aSAnson Huang #define IMX8MN_CLK_GPU_CORE_ROOT		193
216be378b60SLeonard Crestez #define IMX8MN_CLK_GIC				194
2171e80936aSAnson Huang 
218e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_40M_CG			195
219e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_80M_CG			196
220e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_100M_CG			197
221e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_133M_CG			198
222e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_160M_CG			199
223e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_200M_CG			200
224e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_266M_CG			201
225e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL1_400M_CG			202
226e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_50M_CG			203
227e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_100M_CG			204
228e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_125M_CG			205
229e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_166M_CG			206
230e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_200M_CG			207
231e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_250M_CG			208
232e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_333M_CG			209
233e8688fe8SLeonard Crestez #define IMX8MN_SYS_PLL2_500M_CG			210
234e8688fe8SLeonard Crestez 
235d2d46dfaSHoria Geantă #define IMX8MN_CLK_SNVS_ROOT			211
23633db2ce7SPeng Fan #define IMX8MN_CLK_GPU_CORE			212
23733db2ce7SPeng Fan #define IMX8MN_CLK_GPU_SHADER			213
238d2d46dfaSHoria Geantă 
239c69def88SPeng Fan #define IMX8MN_CLK_A53_CORE			214
240c69def88SPeng Fan 
2413af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT1_SEL			215
2423af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT1_DIV			216
2433af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT1			217
2443af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT2_SEL			218
2453af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT2_DIV			219
2463af4df65SLucas Stach #define IMX8MN_CLK_CLKOUT2			220
2473af4df65SLucas Stach 
24886842d25SMarek Vasut #define IMX8MN_CLK_M7_CORE			221
24986842d25SMarek Vasut 
2509b305019SAlvin Šipraga #define IMX8MN_CLK_GPT_3M			222
2519b305019SAlvin Šipraga #define IMX8MN_CLK_GPT1				223
2529b305019SAlvin Šipraga #define IMX8MN_CLK_GPT1_ROOT			224
2539b305019SAlvin Šipraga #define IMX8MN_CLK_GPT2				225
2549b305019SAlvin Šipraga #define IMX8MN_CLK_GPT2_ROOT			226
2559b305019SAlvin Šipraga #define IMX8MN_CLK_GPT3				227
2569b305019SAlvin Šipraga #define IMX8MN_CLK_GPT3_ROOT			228
2579b305019SAlvin Šipraga #define IMX8MN_CLK_GPT4				229
2589b305019SAlvin Šipraga #define IMX8MN_CLK_GPT4_ROOT			230
2599b305019SAlvin Šipraga #define IMX8MN_CLK_GPT5				231
2609b305019SAlvin Šipraga #define IMX8MN_CLK_GPT5_ROOT			232
2619b305019SAlvin Šipraga #define IMX8MN_CLK_GPT6				233
2629b305019SAlvin Šipraga #define IMX8MN_CLK_GPT6_ROOT			234
2639b305019SAlvin Šipraga 
2649b305019SAlvin Šipraga #define IMX8MN_CLK_END				235
2651e80936aSAnson Huang 
2661e80936aSAnson Huang #endif
267