3476195651
majority of the diff is the normal collection of driver additions for new SoCs and non-critical clk data fixes and updates. The framework must be middle aged. The two biggest directories in the diffstat show that the Qualcomm and Unisoc support added a handful of big drivers for new SoCs but that's not really the whole story because those new drivers tend to add large numbers of lines of clk data. There's a handful of AT91 clk drivers added this time around too and a bunch of improvements to drivers like the i.MX driver. All around lots of updates and fixes in various clk drivers which is good to see. The core framework has only one real major change which has been baking in next for the past couple months. It fixes the framework so that it stops caching a clk's phase when the phase clk_op returns an error. Before this change we would consider some negative errno as a phase and that just doesn't make sense. Core: - Don't show clk phase when it is invalid New Drivers: - Add support for Unisoc SC9863A clks - Qualcomm SM8250 RPMh and MSM8976 RPM clks - Qualcomm SM8250 Global Clock Controller (GCC) support - Qualcomm SC7180 Modem Clock Controller (MSS CC) support - EHRPWM's TimeBase clock(TBCLK) for TI AM654 SoCs - Support PMC clks on at91sam9n12, at91rm9200, sama5d3, and at91sam9g45 SoCs Updates: - GPU GX GDSC support on Qualcomm sc7180 - Fixes and improvements for the Marvell MMP2/MMP3 SoC clk drivers - A series from Anson to convert i.MX8 clock bindings to json-schema - Update i.MX pll14xx driver to include new frequency entries for pll1443x table, and return error for invalid PLL type - Add missing of_node_put() call for a number of i.MX clock drivers - Drop flag CLK_IS_CRITICAL from 'A53_CORE' mux clock, as we already have the flag on its child cpu clock - Fix a53 cpu clock for i.MX8 drivers to get it source from ARM PLL via CORE_SEL slice, and source from A53 CCM clk root when we need to change ARM PLL frequency. Thus, we can support core running above 1GHz safely - Update i.MX pfdv2 driver to check zero rate and use determine_rate for getting the best rate - Add CLKO2 for imx8mm, SNVS clock for imx8mn, and PXP clock for imx7d - Remove PMC clks from Tegra clk driver - Improved clock/reset handling for the Renesas R-Car USB2 Clock Selector - Conversion to json-schema of the Renesas CPG/MSSR DT bindings - Add Crypto clocks on Renesas R-Car M3-W/W+, M3-N, E3, and D3 - Add RPC (QSPI/HyperFLASH) clocks on Renesas R-Car H3, M3-W/W+, and M3-N - Update Amlogic audio clock gate hierarchy for meson8 and gxbb - Update Amlogic g12a spicc clock sources - Support for Ingenic X1000 TCU clks -----BEGIN PGP SIGNATURE----- iQJFBAABCAAvFiEE9L57QeeUxqYDyoaDrQKIl8bklSUFAl6JDxURHHNib3lkQGtl cm5lbC5vcmcACgkQrQKIl8bklSU51A/+OzAA4HyywcSwLWMhUbyWI0hWis8/Gdtv /tIOPY/+J/Wi+2vFXoZEQWr/GViEEC1ylQwtkc/cm1WklEka/+q+GJFawyyIfX2i ovofDWw5lJd4/ACaOqV4ryEppwHnPUvASvoIOUXX6IwauNQzI0dRZWTOLTg2YW7x uvI5OtQ8o71+bM+VL1tuhWvN/4Zx9tALNU9yhaRhHdafR+xQ0d4x5bBQo8MG/2E0 3xIbRqGbhO6XfNiKAjgKcI3jtHn006LK1/1AjyXUETWzu5Zcg2SYb/YAah39RKLZ FTV+xY39C8JBLPt6ZLrBu9mPDcoQOWohmnDLki0qm65cfVs/tbDX3kwp3ixCly7y jSCqNpl7RuWcbjMe8YesakhJc1IFICQts08KsM6dPipL+7iAv++fNQrfrnXf0cDx cPCgDkepos/aRhNXmVFdxf2FRKkIQjYpdAPFdYSvLv6MK0Dk6G7/EhOOXA10Z2BU BojY8tUx/YaC8sRbnZlhitYfpqDVFzdihL2G6W31iUbt1sKYR6t6Szhct2EbRTOQ 69bUy2lw7M8pk1Remp0LqdrVUDYLy0/X3dVaa/teIaZt2Ac1NnWzHw9LMmnlFFEG GxuZy5Q5fCKbAf0tSkD4Gzb9z8f0pzAyfdlpGsY7+eEEWloc4yNFCcFcNyzJTXWV 4kdye0klUPs= =ZoI6 -----END PGP SIGNATURE----- Merge tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux Pull clk updates from Stephen Boyd: "There's not much to see in the core framework this time around. Instead the majority of the diff is the normal collection of driver additions for new SoCs and non-critical clk data fixes and updates. The framework must be middle aged. The two biggest directories in the diffstat show that the Qualcomm and Unisoc support added a handful of big drivers for new SoCs but that's not really the whole story because those new drivers tend to add large numbers of lines of clk data. There's a handful of AT91 clk drivers added this time around too and a bunch of improvements to drivers like the i.MX driver. All around lots of updates and fixes in various clk drivers which is good to see. The core framework has only one real major change which has been baking in next for the past couple months. It fixes the framework so that it stops caching a clk's phase when the phase clk_op returns an error. Before this change we would consider some negative errno as a phase and that just doesn't make sense. Core: - Don't show clk phase when it is invalid New Drivers: - Add support for Unisoc SC9863A clks - Qualcomm SM8250 RPMh and MSM8976 RPM clks - Qualcomm SM8250 Global Clock Controller (GCC) support - Qualcomm SC7180 Modem Clock Controller (MSS CC) support - EHRPWM's TimeBase clock(TBCLK) for TI AM654 SoCs - Support PMC clks on at91sam9n12, at91rm9200, sama5d3, and at91sam9g45 SoCs Updates: - GPU GX GDSC support on Qualcomm sc7180 - Fixes and improvements for the Marvell MMP2/MMP3 SoC clk drivers - A series from Anson to convert i.MX8 clock bindings to json-schema - Update i.MX pll14xx driver to include new frequency entries for pll1443x table, and return error for invalid PLL type - Add missing of_node_put() call for a number of i.MX clock drivers - Drop flag CLK_IS_CRITICAL from 'A53_CORE' mux clock, as we already have the flag on its child cpu clock - Fix a53 cpu clock for i.MX8 drivers to get it source from ARM PLL via CORE_SEL slice, and source from A53 CCM clk root when we need to change ARM PLL frequency. Thus, we can support core running above 1GHz safely - Update i.MX pfdv2 driver to check zero rate and use determine_rate for getting the best rate - Add CLKO2 for imx8mm, SNVS clock for imx8mn, and PXP clock for imx7d - Remove PMC clks from Tegra clk driver - Improved clock/reset handling for the Renesas R-Car USB2 Clock Selector - Conversion to json-schema of the Renesas CPG/MSSR DT bindings - Add Crypto clocks on Renesas R-Car M3-W/W+, M3-N, E3, and D3 - Add RPC (QSPI/HyperFLASH) clocks on Renesas R-Car H3, M3-W/W+, and M3-N - Update Amlogic audio clock gate hierarchy for meson8 and gxbb - Update Amlogic g12a spicc clock sources - Support for Ingenic X1000 TCU clks" * tag 'clk-for-linus' of git://git.kernel.org/pub/scm/linux/kernel/git/clk/linux: (146 commits) clk: sprd: fix to get a correct ibias of pll dt-bindings: imx8mm-clock: Fix the file path dt-bindings: imx8mq-clock: Fix the file path clk: qcom: rpmh: Drop unnecessary semicolons clk: qcom: rpmh: Simplify clk_rpmh_bcm_send_cmd() clk: tegra: Use NULL for pointer initialization clk: sprd: add clocks support for SC9863A clk: sprd: support to get regmap from parent node clk: sprd: Add macros for referencing parents without strings clk: sprd: Add dt-bindings include file for SC9863A dt-bindings: clk: sprd: add bindings for sc9863a clock controller dt-bindings: clk: sprd: rename the common file name sprd.txt to SoC specific clk: sprd: add gate for pll clocks MAINTAINERS: dt: update reference for arm-integrator.txt clk: mmp2: Fix bit masks for LCDC I/O and pixel clocks clk: mmp2: Add clock for fifth SD HCI on MMP3 dt-bindings: marvell,mmp2: Add clock id for the fifth SD HCI on MMP3 clk: mmp2: Add clocks for the thermal sensors dt-bindings: marvell,mmp2: Add clock ids for the thermal sensors clk: mmp2: add the GPU clocks ...
240 lines
7.5 KiB
C
240 lines
7.5 KiB
C
/* SPDX-License-Identifier: GPL-2.0 */
|
|
/*
|
|
* Copyright 2018-2019 NXP
|
|
*/
|
|
|
|
#ifndef __DT_BINDINGS_CLOCK_IMX8MN_H
|
|
#define __DT_BINDINGS_CLOCK_IMX8MN_H
|
|
|
|
#define IMX8MN_CLK_DUMMY 0
|
|
#define IMX8MN_CLK_32K 1
|
|
#define IMX8MN_CLK_24M 2
|
|
#define IMX8MN_OSC_HDMI_CLK 3
|
|
#define IMX8MN_CLK_EXT1 4
|
|
#define IMX8MN_CLK_EXT2 5
|
|
#define IMX8MN_CLK_EXT3 6
|
|
#define IMX8MN_CLK_EXT4 7
|
|
#define IMX8MN_AUDIO_PLL1_REF_SEL 8
|
|
#define IMX8MN_AUDIO_PLL2_REF_SEL 9
|
|
#define IMX8MN_VIDEO_PLL1_REF_SEL 10
|
|
#define IMX8MN_DRAM_PLL_REF_SEL 11
|
|
#define IMX8MN_GPU_PLL_REF_SEL 12
|
|
#define IMX8MN_VPU_PLL_REF_SEL 13
|
|
#define IMX8MN_ARM_PLL_REF_SEL 14
|
|
#define IMX8MN_SYS_PLL1_REF_SEL 15
|
|
#define IMX8MN_SYS_PLL2_REF_SEL 16
|
|
#define IMX8MN_SYS_PLL3_REF_SEL 17
|
|
#define IMX8MN_AUDIO_PLL1 18
|
|
#define IMX8MN_AUDIO_PLL2 19
|
|
#define IMX8MN_VIDEO_PLL1 20
|
|
#define IMX8MN_DRAM_PLL 21
|
|
#define IMX8MN_GPU_PLL 22
|
|
#define IMX8MN_VPU_PLL 23
|
|
#define IMX8MN_ARM_PLL 24
|
|
#define IMX8MN_SYS_PLL1 25
|
|
#define IMX8MN_SYS_PLL2 26
|
|
#define IMX8MN_SYS_PLL3 27
|
|
#define IMX8MN_AUDIO_PLL1_BYPASS 28
|
|
#define IMX8MN_AUDIO_PLL2_BYPASS 29
|
|
#define IMX8MN_VIDEO_PLL1_BYPASS 30
|
|
#define IMX8MN_DRAM_PLL_BYPASS 31
|
|
#define IMX8MN_GPU_PLL_BYPASS 32
|
|
#define IMX8MN_VPU_PLL_BYPASS 33
|
|
#define IMX8MN_ARM_PLL_BYPASS 34
|
|
#define IMX8MN_SYS_PLL1_BYPASS 35
|
|
#define IMX8MN_SYS_PLL2_BYPASS 36
|
|
#define IMX8MN_SYS_PLL3_BYPASS 37
|
|
#define IMX8MN_AUDIO_PLL1_OUT 38
|
|
#define IMX8MN_AUDIO_PLL2_OUT 39
|
|
#define IMX8MN_VIDEO_PLL1_OUT 40
|
|
#define IMX8MN_DRAM_PLL_OUT 41
|
|
#define IMX8MN_GPU_PLL_OUT 42
|
|
#define IMX8MN_VPU_PLL_OUT 43
|
|
#define IMX8MN_ARM_PLL_OUT 44
|
|
#define IMX8MN_SYS_PLL1_OUT 45
|
|
#define IMX8MN_SYS_PLL2_OUT 46
|
|
#define IMX8MN_SYS_PLL3_OUT 47
|
|
#define IMX8MN_SYS_PLL1_40M 48
|
|
#define IMX8MN_SYS_PLL1_80M 49
|
|
#define IMX8MN_SYS_PLL1_100M 50
|
|
#define IMX8MN_SYS_PLL1_133M 51
|
|
#define IMX8MN_SYS_PLL1_160M 52
|
|
#define IMX8MN_SYS_PLL1_200M 53
|
|
#define IMX8MN_SYS_PLL1_266M 54
|
|
#define IMX8MN_SYS_PLL1_400M 55
|
|
#define IMX8MN_SYS_PLL1_800M 56
|
|
#define IMX8MN_SYS_PLL2_50M 57
|
|
#define IMX8MN_SYS_PLL2_100M 58
|
|
#define IMX8MN_SYS_PLL2_125M 59
|
|
#define IMX8MN_SYS_PLL2_166M 60
|
|
#define IMX8MN_SYS_PLL2_200M 61
|
|
#define IMX8MN_SYS_PLL2_250M 62
|
|
#define IMX8MN_SYS_PLL2_333M 63
|
|
#define IMX8MN_SYS_PLL2_500M 64
|
|
#define IMX8MN_SYS_PLL2_1000M 65
|
|
|
|
/* CORE CLOCK ROOT */
|
|
#define IMX8MN_CLK_A53_SRC 66
|
|
#define IMX8MN_CLK_GPU_CORE_SRC 67
|
|
#define IMX8MN_CLK_GPU_SHADER_SRC 68
|
|
#define IMX8MN_CLK_A53_CG 69
|
|
#define IMX8MN_CLK_GPU_CORE_CG 70
|
|
#define IMX8MN_CLK_GPU_SHADER_CG 71
|
|
#define IMX8MN_CLK_A53_DIV 72
|
|
#define IMX8MN_CLK_GPU_CORE_DIV 73
|
|
#define IMX8MN_CLK_GPU_SHADER_DIV 74
|
|
|
|
/* BUS CLOCK ROOT */
|
|
#define IMX8MN_CLK_MAIN_AXI 75
|
|
#define IMX8MN_CLK_ENET_AXI 76
|
|
#define IMX8MN_CLK_NAND_USDHC_BUS 77
|
|
#define IMX8MN_CLK_DISP_AXI 78
|
|
#define IMX8MN_CLK_DISP_APB 79
|
|
#define IMX8MN_CLK_USB_BUS 80
|
|
#define IMX8MN_CLK_GPU_AXI 81
|
|
#define IMX8MN_CLK_GPU_AHB 82
|
|
#define IMX8MN_CLK_NOC 83
|
|
#define IMX8MN_CLK_AHB 84
|
|
#define IMX8MN_CLK_AUDIO_AHB 85
|
|
|
|
/* IPG CLOCK ROOT */
|
|
#define IMX8MN_CLK_IPG_ROOT 86
|
|
#define IMX8MN_CLK_IPG_AUDIO_ROOT 87
|
|
|
|
/* IP */
|
|
#define IMX8MN_CLK_DRAM_CORE 88
|
|
#define IMX8MN_CLK_DRAM_ALT 89
|
|
#define IMX8MN_CLK_DRAM_APB 90
|
|
#define IMX8MN_CLK_DRAM_ALT_ROOT 91
|
|
#define IMX8MN_CLK_DISP_PIXEL 92
|
|
#define IMX8MN_CLK_SAI2 93
|
|
#define IMX8MN_CLK_SAI3 94
|
|
#define IMX8MN_CLK_SAI5 95
|
|
#define IMX8MN_CLK_SAI6 96
|
|
#define IMX8MN_CLK_SPDIF1 97
|
|
#define IMX8MN_CLK_ENET_REF 98
|
|
#define IMX8MN_CLK_ENET_TIMER 99
|
|
#define IMX8MN_CLK_ENET_PHY_REF 100
|
|
#define IMX8MN_CLK_NAND 101
|
|
#define IMX8MN_CLK_QSPI 102
|
|
#define IMX8MN_CLK_USDHC1 103
|
|
#define IMX8MN_CLK_USDHC2 104
|
|
#define IMX8MN_CLK_I2C1 105
|
|
#define IMX8MN_CLK_I2C2 106
|
|
#define IMX8MN_CLK_I2C3 107
|
|
#define IMX8MN_CLK_I2C4 108
|
|
#define IMX8MN_CLK_UART1 109
|
|
#define IMX8MN_CLK_UART2 110
|
|
#define IMX8MN_CLK_UART3 111
|
|
#define IMX8MN_CLK_UART4 112
|
|
#define IMX8MN_CLK_USB_CORE_REF 113
|
|
#define IMX8MN_CLK_USB_PHY_REF 114
|
|
#define IMX8MN_CLK_ECSPI1 115
|
|
#define IMX8MN_CLK_ECSPI2 116
|
|
#define IMX8MN_CLK_PWM1 117
|
|
#define IMX8MN_CLK_PWM2 118
|
|
#define IMX8MN_CLK_PWM3 119
|
|
#define IMX8MN_CLK_PWM4 120
|
|
#define IMX8MN_CLK_WDOG 121
|
|
#define IMX8MN_CLK_WRCLK 122
|
|
#define IMX8MN_CLK_CLKO1 123
|
|
#define IMX8MN_CLK_CLKO2 124
|
|
#define IMX8MN_CLK_DSI_CORE 125
|
|
#define IMX8MN_CLK_DSI_PHY_REF 126
|
|
#define IMX8MN_CLK_DSI_DBI 127
|
|
#define IMX8MN_CLK_USDHC3 128
|
|
#define IMX8MN_CLK_CAMERA_PIXEL 129
|
|
#define IMX8MN_CLK_CSI1_PHY_REF 130
|
|
#define IMX8MN_CLK_CSI2_PHY_REF 131
|
|
#define IMX8MN_CLK_CSI2_ESC 132
|
|
#define IMX8MN_CLK_ECSPI3 133
|
|
#define IMX8MN_CLK_PDM 134
|
|
#define IMX8MN_CLK_SAI7 135
|
|
|
|
#define IMX8MN_CLK_ECSPI1_ROOT 136
|
|
#define IMX8MN_CLK_ECSPI2_ROOT 137
|
|
#define IMX8MN_CLK_ECSPI3_ROOT 138
|
|
#define IMX8MN_CLK_ENET1_ROOT 139
|
|
#define IMX8MN_CLK_GPIO1_ROOT 140
|
|
#define IMX8MN_CLK_GPIO2_ROOT 141
|
|
#define IMX8MN_CLK_GPIO3_ROOT 142
|
|
#define IMX8MN_CLK_GPIO4_ROOT 143
|
|
#define IMX8MN_CLK_GPIO5_ROOT 144
|
|
#define IMX8MN_CLK_I2C1_ROOT 145
|
|
#define IMX8MN_CLK_I2C2_ROOT 146
|
|
#define IMX8MN_CLK_I2C3_ROOT 147
|
|
#define IMX8MN_CLK_I2C4_ROOT 148
|
|
#define IMX8MN_CLK_MU_ROOT 149
|
|
#define IMX8MN_CLK_OCOTP_ROOT 150
|
|
#define IMX8MN_CLK_PWM1_ROOT 151
|
|
#define IMX8MN_CLK_PWM2_ROOT 152
|
|
#define IMX8MN_CLK_PWM3_ROOT 153
|
|
#define IMX8MN_CLK_PWM4_ROOT 154
|
|
#define IMX8MN_CLK_QSPI_ROOT 155
|
|
#define IMX8MN_CLK_NAND_ROOT 156
|
|
#define IMX8MN_CLK_SAI2_ROOT 157
|
|
#define IMX8MN_CLK_SAI2_IPG 158
|
|
#define IMX8MN_CLK_SAI3_ROOT 159
|
|
#define IMX8MN_CLK_SAI3_IPG 160
|
|
#define IMX8MN_CLK_SAI5_ROOT 161
|
|
#define IMX8MN_CLK_SAI5_IPG 162
|
|
#define IMX8MN_CLK_SAI6_ROOT 163
|
|
#define IMX8MN_CLK_SAI6_IPG 164
|
|
#define IMX8MN_CLK_SAI7_ROOT 165
|
|
#define IMX8MN_CLK_SAI7_IPG 166
|
|
#define IMX8MN_CLK_SDMA1_ROOT 167
|
|
#define IMX8MN_CLK_SDMA2_ROOT 168
|
|
#define IMX8MN_CLK_UART1_ROOT 169
|
|
#define IMX8MN_CLK_UART2_ROOT 170
|
|
#define IMX8MN_CLK_UART3_ROOT 171
|
|
#define IMX8MN_CLK_UART4_ROOT 172
|
|
#define IMX8MN_CLK_USB1_CTRL_ROOT 173
|
|
#define IMX8MN_CLK_USDHC1_ROOT 174
|
|
#define IMX8MN_CLK_USDHC2_ROOT 175
|
|
#define IMX8MN_CLK_WDOG1_ROOT 176
|
|
#define IMX8MN_CLK_WDOG2_ROOT 177
|
|
#define IMX8MN_CLK_WDOG3_ROOT 178
|
|
#define IMX8MN_CLK_GPU_BUS_ROOT 179
|
|
#define IMX8MN_CLK_ASRC_ROOT 180
|
|
#define IMX8MN_CLK_GPU3D_ROOT 181
|
|
#define IMX8MN_CLK_PDM_ROOT 182
|
|
#define IMX8MN_CLK_PDM_IPG 183
|
|
#define IMX8MN_CLK_DISP_AXI_ROOT 184
|
|
#define IMX8MN_CLK_DISP_APB_ROOT 185
|
|
#define IMX8MN_CLK_DISP_PIXEL_ROOT 186
|
|
#define IMX8MN_CLK_CAMERA_PIXEL_ROOT 187
|
|
#define IMX8MN_CLK_USDHC3_ROOT 188
|
|
#define IMX8MN_CLK_SDMA3_ROOT 189
|
|
#define IMX8MN_CLK_TMU_ROOT 190
|
|
#define IMX8MN_CLK_ARM 191
|
|
#define IMX8MN_CLK_NAND_USDHC_BUS_RAWNAND_CLK 192
|
|
#define IMX8MN_CLK_GPU_CORE_ROOT 193
|
|
#define IMX8MN_CLK_GIC 194
|
|
|
|
#define IMX8MN_SYS_PLL1_40M_CG 195
|
|
#define IMX8MN_SYS_PLL1_80M_CG 196
|
|
#define IMX8MN_SYS_PLL1_100M_CG 197
|
|
#define IMX8MN_SYS_PLL1_133M_CG 198
|
|
#define IMX8MN_SYS_PLL1_160M_CG 199
|
|
#define IMX8MN_SYS_PLL1_200M_CG 200
|
|
#define IMX8MN_SYS_PLL1_266M_CG 201
|
|
#define IMX8MN_SYS_PLL1_400M_CG 202
|
|
#define IMX8MN_SYS_PLL2_50M_CG 203
|
|
#define IMX8MN_SYS_PLL2_100M_CG 204
|
|
#define IMX8MN_SYS_PLL2_125M_CG 205
|
|
#define IMX8MN_SYS_PLL2_166M_CG 206
|
|
#define IMX8MN_SYS_PLL2_200M_CG 207
|
|
#define IMX8MN_SYS_PLL2_250M_CG 208
|
|
#define IMX8MN_SYS_PLL2_333M_CG 209
|
|
#define IMX8MN_SYS_PLL2_500M_CG 210
|
|
|
|
#define IMX8MN_CLK_SNVS_ROOT 211
|
|
#define IMX8MN_CLK_GPU_CORE 212
|
|
#define IMX8MN_CLK_GPU_SHADER 213
|
|
|
|
#define IMX8MN_CLK_A53_CORE 214
|
|
|
|
#define IMX8MN_CLK_END 215
|
|
|
|
#endif
|