1*54fd6939SJiyong Park /* SPDX-License-Identifier: GPL-2.0+ OR BSD-3-Clause */ 2*54fd6939SJiyong Park /* 3*54fd6939SJiyong Park * Copyright (C) 2017, STMicroelectronics - All Rights Reserved 4*54fd6939SJiyong Park */ 5*54fd6939SJiyong Park 6*54fd6939SJiyong Park #ifndef _DT_BINDINGS_CLOCK_STM32MP1_CLKSRC_H_ 7*54fd6939SJiyong Park #define _DT_BINDINGS_CLOCK_STM32MP1_CLKSRC_H_ 8*54fd6939SJiyong Park 9*54fd6939SJiyong Park /* PLL output is enable when x=1, with x=p,q or r */ 10*54fd6939SJiyong Park #define PQR(p, q, r) (((p) & 1) | (((q) & 1) << 1) | (((r) & 1) << 2)) 11*54fd6939SJiyong Park 12*54fd6939SJiyong Park /* st,clksrc: mandatory clock source */ 13*54fd6939SJiyong Park 14*54fd6939SJiyong Park #define CLK_MPU_HSI 0x00000200 15*54fd6939SJiyong Park #define CLK_MPU_HSE 0x00000201 16*54fd6939SJiyong Park #define CLK_MPU_PLL1P 0x00000202 17*54fd6939SJiyong Park #define CLK_MPU_PLL1P_DIV 0x00000203 18*54fd6939SJiyong Park 19*54fd6939SJiyong Park #define CLK_AXI_HSI 0x00000240 20*54fd6939SJiyong Park #define CLK_AXI_HSE 0x00000241 21*54fd6939SJiyong Park #define CLK_AXI_PLL2P 0x00000242 22*54fd6939SJiyong Park 23*54fd6939SJiyong Park #define CLK_MCU_HSI 0x00000480 24*54fd6939SJiyong Park #define CLK_MCU_HSE 0x00000481 25*54fd6939SJiyong Park #define CLK_MCU_CSI 0x00000482 26*54fd6939SJiyong Park #define CLK_MCU_PLL3P 0x00000483 27*54fd6939SJiyong Park 28*54fd6939SJiyong Park #define CLK_PLL12_HSI 0x00000280 29*54fd6939SJiyong Park #define CLK_PLL12_HSE 0x00000281 30*54fd6939SJiyong Park 31*54fd6939SJiyong Park #define CLK_PLL3_HSI 0x00008200 32*54fd6939SJiyong Park #define CLK_PLL3_HSE 0x00008201 33*54fd6939SJiyong Park #define CLK_PLL3_CSI 0x00008202 34*54fd6939SJiyong Park 35*54fd6939SJiyong Park #define CLK_PLL4_HSI 0x00008240 36*54fd6939SJiyong Park #define CLK_PLL4_HSE 0x00008241 37*54fd6939SJiyong Park #define CLK_PLL4_CSI 0x00008242 38*54fd6939SJiyong Park #define CLK_PLL4_I2SCKIN 0x00008243 39*54fd6939SJiyong Park 40*54fd6939SJiyong Park #define CLK_RTC_DISABLED 0x00001400 41*54fd6939SJiyong Park #define CLK_RTC_LSE 0x00001401 42*54fd6939SJiyong Park #define CLK_RTC_LSI 0x00001402 43*54fd6939SJiyong Park #define CLK_RTC_HSE 0x00001403 44*54fd6939SJiyong Park 45*54fd6939SJiyong Park #define CLK_MCO1_HSI 0x00008000 46*54fd6939SJiyong Park #define CLK_MCO1_HSE 0x00008001 47*54fd6939SJiyong Park #define CLK_MCO1_CSI 0x00008002 48*54fd6939SJiyong Park #define CLK_MCO1_LSI 0x00008003 49*54fd6939SJiyong Park #define CLK_MCO1_LSE 0x00008004 50*54fd6939SJiyong Park #define CLK_MCO1_DISABLED 0x0000800F 51*54fd6939SJiyong Park 52*54fd6939SJiyong Park #define CLK_MCO2_MPU 0x00008040 53*54fd6939SJiyong Park #define CLK_MCO2_AXI 0x00008041 54*54fd6939SJiyong Park #define CLK_MCO2_MCU 0x00008042 55*54fd6939SJiyong Park #define CLK_MCO2_PLL4P 0x00008043 56*54fd6939SJiyong Park #define CLK_MCO2_HSE 0x00008044 57*54fd6939SJiyong Park #define CLK_MCO2_HSI 0x00008045 58*54fd6939SJiyong Park #define CLK_MCO2_DISABLED 0x0000804F 59*54fd6939SJiyong Park 60*54fd6939SJiyong Park /* st,pkcs: peripheral kernel clock source */ 61*54fd6939SJiyong Park 62*54fd6939SJiyong Park #define CLK_I2C12_PCLK1 0x00008C00 63*54fd6939SJiyong Park #define CLK_I2C12_PLL4R 0x00008C01 64*54fd6939SJiyong Park #define CLK_I2C12_HSI 0x00008C02 65*54fd6939SJiyong Park #define CLK_I2C12_CSI 0x00008C03 66*54fd6939SJiyong Park #define CLK_I2C12_DISABLED 0x00008C07 67*54fd6939SJiyong Park 68*54fd6939SJiyong Park #define CLK_I2C35_PCLK1 0x00008C40 69*54fd6939SJiyong Park #define CLK_I2C35_PLL4R 0x00008C41 70*54fd6939SJiyong Park #define CLK_I2C35_HSI 0x00008C42 71*54fd6939SJiyong Park #define CLK_I2C35_CSI 0x00008C43 72*54fd6939SJiyong Park #define CLK_I2C35_DISABLED 0x00008C47 73*54fd6939SJiyong Park 74*54fd6939SJiyong Park #define CLK_I2C46_PCLK5 0x00000C00 75*54fd6939SJiyong Park #define CLK_I2C46_PLL3Q 0x00000C01 76*54fd6939SJiyong Park #define CLK_I2C46_HSI 0x00000C02 77*54fd6939SJiyong Park #define CLK_I2C46_CSI 0x00000C03 78*54fd6939SJiyong Park #define CLK_I2C46_DISABLED 0x00000C07 79*54fd6939SJiyong Park 80*54fd6939SJiyong Park #define CLK_SAI1_PLL4Q 0x00008C80 81*54fd6939SJiyong Park #define CLK_SAI1_PLL3Q 0x00008C81 82*54fd6939SJiyong Park #define CLK_SAI1_I2SCKIN 0x00008C82 83*54fd6939SJiyong Park #define CLK_SAI1_CKPER 0x00008C83 84*54fd6939SJiyong Park #define CLK_SAI1_PLL3R 0x00008C84 85*54fd6939SJiyong Park #define CLK_SAI1_DISABLED 0x00008C87 86*54fd6939SJiyong Park 87*54fd6939SJiyong Park #define CLK_SAI2_PLL4Q 0x00008CC0 88*54fd6939SJiyong Park #define CLK_SAI2_PLL3Q 0x00008CC1 89*54fd6939SJiyong Park #define CLK_SAI2_I2SCKIN 0x00008CC2 90*54fd6939SJiyong Park #define CLK_SAI2_CKPER 0x00008CC3 91*54fd6939SJiyong Park #define CLK_SAI2_SPDIF 0x00008CC4 92*54fd6939SJiyong Park #define CLK_SAI2_PLL3R 0x00008CC5 93*54fd6939SJiyong Park #define CLK_SAI2_DISABLED 0x00008CC7 94*54fd6939SJiyong Park 95*54fd6939SJiyong Park #define CLK_SAI3_PLL4Q 0x00008D00 96*54fd6939SJiyong Park #define CLK_SAI3_PLL3Q 0x00008D01 97*54fd6939SJiyong Park #define CLK_SAI3_I2SCKIN 0x00008D02 98*54fd6939SJiyong Park #define CLK_SAI3_CKPER 0x00008D03 99*54fd6939SJiyong Park #define CLK_SAI3_PLL3R 0x00008D04 100*54fd6939SJiyong Park #define CLK_SAI3_DISABLED 0x00008D07 101*54fd6939SJiyong Park 102*54fd6939SJiyong Park #define CLK_SAI4_PLL4Q 0x00008D40 103*54fd6939SJiyong Park #define CLK_SAI4_PLL3Q 0x00008D41 104*54fd6939SJiyong Park #define CLK_SAI4_I2SCKIN 0x00008D42 105*54fd6939SJiyong Park #define CLK_SAI4_CKPER 0x00008D43 106*54fd6939SJiyong Park #define CLK_SAI4_PLL3R 0x00008D44 107*54fd6939SJiyong Park #define CLK_SAI4_DISABLED 0x00008D47 108*54fd6939SJiyong Park 109*54fd6939SJiyong Park #define CLK_SPI2S1_PLL4P 0x00008D80 110*54fd6939SJiyong Park #define CLK_SPI2S1_PLL3Q 0x00008D81 111*54fd6939SJiyong Park #define CLK_SPI2S1_I2SCKIN 0x00008D82 112*54fd6939SJiyong Park #define CLK_SPI2S1_CKPER 0x00008D83 113*54fd6939SJiyong Park #define CLK_SPI2S1_PLL3R 0x00008D84 114*54fd6939SJiyong Park #define CLK_SPI2S1_DISABLED 0x00008D87 115*54fd6939SJiyong Park 116*54fd6939SJiyong Park #define CLK_SPI2S23_PLL4P 0x00008DC0 117*54fd6939SJiyong Park #define CLK_SPI2S23_PLL3Q 0x00008DC1 118*54fd6939SJiyong Park #define CLK_SPI2S23_I2SCKIN 0x00008DC2 119*54fd6939SJiyong Park #define CLK_SPI2S23_CKPER 0x00008DC3 120*54fd6939SJiyong Park #define CLK_SPI2S23_PLL3R 0x00008DC4 121*54fd6939SJiyong Park #define CLK_SPI2S23_DISABLED 0x00008DC7 122*54fd6939SJiyong Park 123*54fd6939SJiyong Park #define CLK_SPI45_PCLK2 0x00008E00 124*54fd6939SJiyong Park #define CLK_SPI45_PLL4Q 0x00008E01 125*54fd6939SJiyong Park #define CLK_SPI45_HSI 0x00008E02 126*54fd6939SJiyong Park #define CLK_SPI45_CSI 0x00008E03 127*54fd6939SJiyong Park #define CLK_SPI45_HSE 0x00008E04 128*54fd6939SJiyong Park #define CLK_SPI45_DISABLED 0x00008E07 129*54fd6939SJiyong Park 130*54fd6939SJiyong Park #define CLK_SPI6_PCLK5 0x00000C40 131*54fd6939SJiyong Park #define CLK_SPI6_PLL4Q 0x00000C41 132*54fd6939SJiyong Park #define CLK_SPI6_HSI 0x00000C42 133*54fd6939SJiyong Park #define CLK_SPI6_CSI 0x00000C43 134*54fd6939SJiyong Park #define CLK_SPI6_HSE 0x00000C44 135*54fd6939SJiyong Park #define CLK_SPI6_PLL3Q 0x00000C45 136*54fd6939SJiyong Park #define CLK_SPI6_DISABLED 0x00000C47 137*54fd6939SJiyong Park 138*54fd6939SJiyong Park #define CLK_UART6_PCLK2 0x00008E40 139*54fd6939SJiyong Park #define CLK_UART6_PLL4Q 0x00008E41 140*54fd6939SJiyong Park #define CLK_UART6_HSI 0x00008E42 141*54fd6939SJiyong Park #define CLK_UART6_CSI 0x00008E43 142*54fd6939SJiyong Park #define CLK_UART6_HSE 0x00008E44 143*54fd6939SJiyong Park #define CLK_UART6_DISABLED 0x00008E47 144*54fd6939SJiyong Park 145*54fd6939SJiyong Park #define CLK_UART24_PCLK1 0x00008E80 146*54fd6939SJiyong Park #define CLK_UART24_PLL4Q 0x00008E81 147*54fd6939SJiyong Park #define CLK_UART24_HSI 0x00008E82 148*54fd6939SJiyong Park #define CLK_UART24_CSI 0x00008E83 149*54fd6939SJiyong Park #define CLK_UART24_HSE 0x00008E84 150*54fd6939SJiyong Park #define CLK_UART24_DISABLED 0x00008E87 151*54fd6939SJiyong Park 152*54fd6939SJiyong Park #define CLK_UART35_PCLK1 0x00008EC0 153*54fd6939SJiyong Park #define CLK_UART35_PLL4Q 0x00008EC1 154*54fd6939SJiyong Park #define CLK_UART35_HSI 0x00008EC2 155*54fd6939SJiyong Park #define CLK_UART35_CSI 0x00008EC3 156*54fd6939SJiyong Park #define CLK_UART35_HSE 0x00008EC4 157*54fd6939SJiyong Park #define CLK_UART35_DISABLED 0x00008EC7 158*54fd6939SJiyong Park 159*54fd6939SJiyong Park #define CLK_UART78_PCLK1 0x00008F00 160*54fd6939SJiyong Park #define CLK_UART78_PLL4Q 0x00008F01 161*54fd6939SJiyong Park #define CLK_UART78_HSI 0x00008F02 162*54fd6939SJiyong Park #define CLK_UART78_CSI 0x00008F03 163*54fd6939SJiyong Park #define CLK_UART78_HSE 0x00008F04 164*54fd6939SJiyong Park #define CLK_UART78_DISABLED 0x00008F07 165*54fd6939SJiyong Park 166*54fd6939SJiyong Park #define CLK_UART1_PCLK5 0x00000C80 167*54fd6939SJiyong Park #define CLK_UART1_PLL3Q 0x00000C81 168*54fd6939SJiyong Park #define CLK_UART1_HSI 0x00000C82 169*54fd6939SJiyong Park #define CLK_UART1_CSI 0x00000C83 170*54fd6939SJiyong Park #define CLK_UART1_PLL4Q 0x00000C84 171*54fd6939SJiyong Park #define CLK_UART1_HSE 0x00000C85 172*54fd6939SJiyong Park #define CLK_UART1_DISABLED 0x00000C87 173*54fd6939SJiyong Park 174*54fd6939SJiyong Park #define CLK_SDMMC12_HCLK6 0x00008F40 175*54fd6939SJiyong Park #define CLK_SDMMC12_PLL3R 0x00008F41 176*54fd6939SJiyong Park #define CLK_SDMMC12_PLL4P 0x00008F42 177*54fd6939SJiyong Park #define CLK_SDMMC12_HSI 0x00008F43 178*54fd6939SJiyong Park #define CLK_SDMMC12_DISABLED 0x00008F47 179*54fd6939SJiyong Park 180*54fd6939SJiyong Park #define CLK_SDMMC3_HCLK2 0x00008F80 181*54fd6939SJiyong Park #define CLK_SDMMC3_PLL3R 0x00008F81 182*54fd6939SJiyong Park #define CLK_SDMMC3_PLL4P 0x00008F82 183*54fd6939SJiyong Park #define CLK_SDMMC3_HSI 0x00008F83 184*54fd6939SJiyong Park #define CLK_SDMMC3_DISABLED 0x00008F87 185*54fd6939SJiyong Park 186*54fd6939SJiyong Park #define CLK_ETH_PLL4P 0x00008FC0 187*54fd6939SJiyong Park #define CLK_ETH_PLL3Q 0x00008FC1 188*54fd6939SJiyong Park #define CLK_ETH_DISABLED 0x00008FC3 189*54fd6939SJiyong Park 190*54fd6939SJiyong Park #define CLK_QSPI_ACLK 0x00009000 191*54fd6939SJiyong Park #define CLK_QSPI_PLL3R 0x00009001 192*54fd6939SJiyong Park #define CLK_QSPI_PLL4P 0x00009002 193*54fd6939SJiyong Park #define CLK_QSPI_CKPER 0x00009003 194*54fd6939SJiyong Park 195*54fd6939SJiyong Park #define CLK_FMC_ACLK 0x00009040 196*54fd6939SJiyong Park #define CLK_FMC_PLL3R 0x00009041 197*54fd6939SJiyong Park #define CLK_FMC_PLL4P 0x00009042 198*54fd6939SJiyong Park #define CLK_FMC_CKPER 0x00009043 199*54fd6939SJiyong Park 200*54fd6939SJiyong Park #define CLK_FDCAN_HSE 0x000090C0 201*54fd6939SJiyong Park #define CLK_FDCAN_PLL3Q 0x000090C1 202*54fd6939SJiyong Park #define CLK_FDCAN_PLL4Q 0x000090C2 203*54fd6939SJiyong Park #define CLK_FDCAN_PLL4R 0x000090C3 204*54fd6939SJiyong Park 205*54fd6939SJiyong Park #define CLK_SPDIF_PLL4P 0x00009140 206*54fd6939SJiyong Park #define CLK_SPDIF_PLL3Q 0x00009141 207*54fd6939SJiyong Park #define CLK_SPDIF_HSI 0x00009142 208*54fd6939SJiyong Park #define CLK_SPDIF_DISABLED 0x00009143 209*54fd6939SJiyong Park 210*54fd6939SJiyong Park #define CLK_CEC_LSE 0x00009180 211*54fd6939SJiyong Park #define CLK_CEC_LSI 0x00009181 212*54fd6939SJiyong Park #define CLK_CEC_CSI_DIV122 0x00009182 213*54fd6939SJiyong Park #define CLK_CEC_DISABLED 0x00009183 214*54fd6939SJiyong Park 215*54fd6939SJiyong Park #define CLK_USBPHY_HSE 0x000091C0 216*54fd6939SJiyong Park #define CLK_USBPHY_PLL4R 0x000091C1 217*54fd6939SJiyong Park #define CLK_USBPHY_HSE_DIV2 0x000091C2 218*54fd6939SJiyong Park #define CLK_USBPHY_DISABLED 0x000091C3 219*54fd6939SJiyong Park 220*54fd6939SJiyong Park #define CLK_USBO_PLL4R 0x800091C0 221*54fd6939SJiyong Park #define CLK_USBO_USBPHY 0x800091C1 222*54fd6939SJiyong Park 223*54fd6939SJiyong Park #define CLK_RNG1_CSI 0x00000CC0 224*54fd6939SJiyong Park #define CLK_RNG1_PLL4R 0x00000CC1 225*54fd6939SJiyong Park #define CLK_RNG1_LSE 0x00000CC2 226*54fd6939SJiyong Park #define CLK_RNG1_LSI 0x00000CC3 227*54fd6939SJiyong Park 228*54fd6939SJiyong Park #define CLK_RNG2_CSI 0x00009200 229*54fd6939SJiyong Park #define CLK_RNG2_PLL4R 0x00009201 230*54fd6939SJiyong Park #define CLK_RNG2_LSE 0x00009202 231*54fd6939SJiyong Park #define CLK_RNG2_LSI 0x00009203 232*54fd6939SJiyong Park 233*54fd6939SJiyong Park #define CLK_CKPER_HSI 0x00000D00 234*54fd6939SJiyong Park #define CLK_CKPER_CSI 0x00000D01 235*54fd6939SJiyong Park #define CLK_CKPER_HSE 0x00000D02 236*54fd6939SJiyong Park #define CLK_CKPER_DISABLED 0x00000D03 237*54fd6939SJiyong Park 238*54fd6939SJiyong Park #define CLK_STGEN_HSI 0x00000D40 239*54fd6939SJiyong Park #define CLK_STGEN_HSE 0x00000D41 240*54fd6939SJiyong Park #define CLK_STGEN_DISABLED 0x00000D43 241*54fd6939SJiyong Park 242*54fd6939SJiyong Park #define CLK_DSI_DSIPLL 0x00009240 243*54fd6939SJiyong Park #define CLK_DSI_PLL4P 0x00009241 244*54fd6939SJiyong Park 245*54fd6939SJiyong Park #define CLK_ADC_PLL4R 0x00009280 246*54fd6939SJiyong Park #define CLK_ADC_CKPER 0x00009281 247*54fd6939SJiyong Park #define CLK_ADC_PLL3Q 0x00009282 248*54fd6939SJiyong Park #define CLK_ADC_DISABLED 0x00009283 249*54fd6939SJiyong Park 250*54fd6939SJiyong Park #define CLK_LPTIM45_PCLK3 0x000092C0 251*54fd6939SJiyong Park #define CLK_LPTIM45_PLL4P 0x000092C1 252*54fd6939SJiyong Park #define CLK_LPTIM45_PLL3Q 0x000092C2 253*54fd6939SJiyong Park #define CLK_LPTIM45_LSE 0x000092C3 254*54fd6939SJiyong Park #define CLK_LPTIM45_LSI 0x000092C4 255*54fd6939SJiyong Park #define CLK_LPTIM45_CKPER 0x000092C5 256*54fd6939SJiyong Park #define CLK_LPTIM45_DISABLED 0x000092C7 257*54fd6939SJiyong Park 258*54fd6939SJiyong Park #define CLK_LPTIM23_PCLK3 0x00009300 259*54fd6939SJiyong Park #define CLK_LPTIM23_PLL4Q 0x00009301 260*54fd6939SJiyong Park #define CLK_LPTIM23_CKPER 0x00009302 261*54fd6939SJiyong Park #define CLK_LPTIM23_LSE 0x00009303 262*54fd6939SJiyong Park #define CLK_LPTIM23_LSI 0x00009304 263*54fd6939SJiyong Park #define CLK_LPTIM23_DISABLED 0x00009307 264*54fd6939SJiyong Park 265*54fd6939SJiyong Park #define CLK_LPTIM1_PCLK1 0x00009340 266*54fd6939SJiyong Park #define CLK_LPTIM1_PLL4P 0x00009341 267*54fd6939SJiyong Park #define CLK_LPTIM1_PLL3Q 0x00009342 268*54fd6939SJiyong Park #define CLK_LPTIM1_LSE 0x00009343 269*54fd6939SJiyong Park #define CLK_LPTIM1_LSI 0x00009344 270*54fd6939SJiyong Park #define CLK_LPTIM1_CKPER 0x00009345 271*54fd6939SJiyong Park #define CLK_LPTIM1_DISABLED 0x00009347 272*54fd6939SJiyong Park 273*54fd6939SJiyong Park /* define for st,pll /csg */ 274*54fd6939SJiyong Park #define SSCG_MODE_CENTER_SPREAD 0 275*54fd6939SJiyong Park #define SSCG_MODE_DOWN_SPREAD 1 276*54fd6939SJiyong Park 277*54fd6939SJiyong Park /* define for st,drive */ 278*54fd6939SJiyong Park #define LSEDRV_LOWEST 0 279*54fd6939SJiyong Park #define LSEDRV_MEDIUM_LOW 1 280*54fd6939SJiyong Park #define LSEDRV_MEDIUM_HIGH 2 281*54fd6939SJiyong Park #define LSEDRV_HIGHEST 3 282*54fd6939SJiyong Park 283*54fd6939SJiyong Park #endif 284