// SPDX-License-Identifier: GPL-2.0-only
/*
* Copyright (C) 2024 Ivaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
* Author: Ivaylo Ivanov <ivo.ivanov.ivanov1@gmail.com>
*
* Common Clock Framework support for Exynos8895 SoC.
*/
#include <linux/clk-provider.h>
#include <linux/mod_devicetable.h>
#include <linux/of.h>
#include <linux/platform_device.h>
#include <dt-bindings/clock/samsung,exynos8895.h>
#include "clk.h"
#include "clk-exynos-arm64.h"
/* NOTE: Must be equal to the last clock ID increased by one */
#define CLKS_NR_TOP (CLK_GOUT_CMU_VPU_BUS + 1)
#define CLKS_NR_FSYS0 (CLK_GOUT_FSYS0_XIU_P_FSYS0_ACLK + 1)
#define CLKS_NR_FSYS1 (CLK_GOUT_FSYS1_XIU_P_FSYS1_ACLK + 1)
#define CLKS_NR_PERIC0 (CLK_GOUT_PERIC0_USI03_I_SCLK_USI + 1)
#define CLKS_NR_PERIC1 (CLK_GOUT_PERIC1_XIU_P_PERIC1_ACLK + 1)
#define CLKS_NR_PERIS (CLK_GOUT_PERIS_XIU_P_PERIS_ACLK + 1)
/* ---- CMU_TOP ------------------------------------------------------------- */
/* Register Offset definitions for CMU_TOP (0x15a80000) */
#define PLL_LOCKTIME_PLL_SHARED0 0x0000
#define PLL_LOCKTIME_PLL_SHARED1 0x0004
#define PLL_LOCKTIME_PLL_SHARED2 0x0008
#define PLL_LOCKTIME_PLL_SHARED3 0x000c
#define PLL_LOCKTIME_PLL_SHARED4 0x0010
#define PLL_CON0_MUX_CP2AP_MIF_CLK_USER 0x0100
#define PLL_CON2_MUX_CP2AP_MIF_CLK_USER 0x0108
#define PLL_CON0_PLL_SHARED0 0x0120
#define PLL_CON0_PLL_SHARED1 0x0140
#define PLL_CON0_PLL_SHARED2 0x0160
#define PLL_CON0_PLL_SHARED3 0x0180
#define PLL_CON0_PLL_SHARED4 0x01a0
#define CLK_CON_MUX_MUX_CLKCMU_ABOX_CPUABOX 0x1000
#define CLK_CON_MUX_MUX_CLKCMU_APM_BUS 0x1004
#define CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS 0x1008
#define CLK_CON_MUX_MUX_CLKCMU_BUSC_BUS 0x100c
#define CLK_CON_MUX_MUX_CLKCMU_BUSC_BUSPHSI2C 0x1010
#define CLK_CON_MUX_MUX_CLKCMU_CAM_BUS 0x1014
#define CLK_CON_MUX_MUX_CLKCMU_CAM_TPU0 0x1018
#define CLK_CON_MUX_MUX_CLKCMU_CAM_TPU1 0x101c
#define CLK_CON_MUX_MUX_CLKCMU_CAM_VRA 0x1020
#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0 0x1024
#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1 0x1028
#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2 0x102c
#define CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3 0x1030
#define CLK_CON_MUX_MUX_CLKCMU_CORE_BUS 0x1034
#define CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH 0x1038
#define CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH 0x103c
#define CLK_CON_MUX_MUX_CLKCMU_DBG_BUS 0x1040
#define CLK_CON_MUX_MUX_CLKCMU_DCAM_BUS 0x1044
#define CLK_CON_MUX_MUX_CLKCMU_DCAM_IMGD 0x1048
#define CLK_CON_MUX_MUX_CLKCMU_DPU_BUS 0x104c
#define CLK_CON_MUX_MUX_CLKCMU_DROOPDETECTOR 0x1050
#define CLK_CON_MUX_MUX_CLKCMU_DSP_BUS 0x1054
#define CLK_CON_MUX_MUX_CLKCMU_FSYS0_BUS 0x1058
#define CLK_CON_MUX_MUX_CLKCMU_FSYS0_DPGTC 0x105c
#define CLK_CON_MUX_MUX_CLKCMU_FSYS0_MMC_EMBD 0x1060
#define CLK_CON_MUX_MUX_CLKCMU_FSYS0_UFS_EMBD 0x1064
#define CLK_CON_MUX_MUX_CLKCMU_FSYS0_USBDRD30 0x1068
#define CLK_CON_MUX_MUX_CLKCMU_FSYS1_BUS 0x106c
#define CLK_CON_MUX_MUX_CLKCMU_FSYS1_MMC_CARD 0x1070
#define CLK_CON_MUX_MUX_CLKCMU_FSYS1_PCIE 0x1074
#define CLK_CON_MUX_MUX_CLKCMU_FSYS1_UFS_CARD 0x1078
#define CLK_CON_MUX_MUX_CLKCMU_G2D_G2D 0x107c
#define CLK_CON_MUX_MUX_CLKCMU_G2D_JPEG 0x1080
#define CLK_CON_MUX_MUX_CLKCMU_HPM 0x1084
#define CLK_CON_MUX_MUX_CLKCMU_IMEM_BUS 0x1088
#define CLK_CON_MUX_MUX_CLKCMU_ISPHQ_BUS 0x108c
#define CLK_CON_MUX_MUX_CLKCMU_ISPLP_BUS 0x1090
#define CLK_CON_MUX_MUX_CLKCMU_IVA_BUS 0x1094
#define CLK_CON_MUX_MUX_CLKCMU_MFC_BUS 0x1098
#define CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH 0x109c
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS 0x10a0
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_UART_DBG 0x10a4
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI00 0x10a8
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI01 0x10ac
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI02 0x10b0
#define CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI03 0x10b4
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS 0x10b8
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPEEDY2 0x10bc
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM0 0x10c0
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM1 0x10c4
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_UART_BT 0x10c8
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI04 0x10cc
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI05 0x10d0
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI06 0x10d4
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI07 0x10d8
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI08 0x10dc
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI09 0x10e0
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI10 0x10e4
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI11 0x10e8
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI12 0x10ec
#define CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI13 0x10f0
#define CLK_CON_MUX_MUX_CLKCMU_PERIS_BUS 0x10f4
#define CLK_CON_MUX_MUX_CLKCMU_SRDZ_BUS 0x10f8
#define CLK_CON_MUX_MUX_CLKCMU_SRDZ_IMGD 0x10fc
#define CLK_CON_MUX_MUX_CLKCMU_VPU_BUS 0x1100
#define CLK_CON_MUX_MUX_CLK_CMU_CMUREF 0x1104
#define CLK_CON_MUX_MUX_CMU_CMUREF 0x1108
#define CLK_CON_DIV_CLKCMU_ABOX_CPUABOX 0x1800
#define CLK_CON_DIV_CLKCMU_APM_BUS 0x1804
#define CLK_CON_DIV_CLKCMU_BUS1_BUS 0x1808
#define CLK_CON_DIV_CLKCMU_BUSC_BUS 0x180c
#define CLK_CON_DIV_CLKCMU_BUSC_BUSPHSI2C 0x1810
#define CLK_CON_DIV_CLKCMU_CAM_BUS 0x1814
#define CLK_CON_DIV_CLKCMU_CAM_TPU0 0x1818
#define CLK_CON_DIV_CLKCMU_CAM_TPU1 0x181c
#define CLK_CON_DIV_CLKCMU_CAM_VRA 0x1820
#define CLK_CON_DIV_CLKCMU_CIS_CLK0 0x1824
#define CLK_CON_DIV_CLKCMU_CIS_CLK1 0x1828
#define CLK_CON_DIV_CLKCMU_CIS_CLK2 0x182c
#define CLK_CON_DIV_CLKCMU_CIS_CLK3 0x1830
#define CLK_CON_DIV_CLKCMU_CORE_BUS 0x1834
#define CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH 0x1838
#define CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH 0x183c
#define CLK_CON_DIV_CLKCMU_DBG_BUS 0x1840
#define CLK_CON_DIV_CLKCMU_DCAM_BUS 0x1844
#define CLK_CON_DIV_CLKCMU_DCAM_IMGD 0x1848
#define CLK_CON_DIV_CLKCMU_DPU_BUS 0x184c
#define CLK_CON_DIV_CLKCMU_DSP_BUS 0x1850
#define CLK_CON_DIV_CLKCMU_FSYS0_BUS 0x1854
#define CLK_CON_DIV_CLKCMU_FSYS0_DPGTC 0x1858
#define CLK_CON_DIV_CLKCMU_FSYS0_MMC_EMBD 0x185c
#define CLK_CON_DIV_CLKCMU_FSYS0_UFS_EMBD 0x1860
#define CLK_CON_DIV_CLKCMU_FSYS0_USBDRD30 0x1864
#define CLK_CON_DIV_CLKCMU_FSYS1_BUS 0x1868
#define CLK_CON_DIV_CLKCMU_FSYS1_MMC_CARD 0x186c
#define CLK_CON_DIV_CLKCMU_FSYS1_PCIE 0x1870
#define CLK_CON_DIV_CLKCMU_FSYS1_UFS_CARD 0x1874
#define CLK_CON_DIV_CLKCMU_G2D_G2D 0x1878
#define CLK_CON_DIV_CLKCMU_G2D_JPEG 0x187c
#define CLK_CON_DIV_CLKCMU_G3D_SWITCH 0x1880
#define CLK_CON_DIV_CLKCMU_HPM 0x1884
#define CLK_CON_DIV_CLKCMU_IMEM_BUS 0x1888
#define CLK_CON_DIV_CLKCMU_ISPHQ_BUS 0x188c
#define CLK_CON_DIV_CLKCMU_ISPLP_BUS 0x1890
#define CLK_CON_DIV_CLKCMU_IVA_BUS 0x1894
#define CLK_CON_DIV_CLKCMU_MFC_BUS 0x1898
#define CLK_CON_DIV_CLKCMU_MODEM_SHARED0 0x189c
#define CLK_CON_DIV_CLKCMU_MODEM_SHARED1 0x18a0
#define CLK_CON_DIV_CLKCMU_OTP 0x18a4
#define CLK_CON_DIV_CLKCMU_PERIC0_BUS 0x18a8
#define CLK_CON_DIV_CLKCMU_PERIC0_UART_DBG 0x18ac
#define CLK_CON_DIV_CLKCMU_PERIC0_USI00 0x18b0
#define CLK_CON_DIV_CLKCMU_PERIC0_USI01 0x18b4
#define CLK_CON_DIV_CLKCMU_PERIC0_USI02 0x18b8
#define CLK_CON_DIV_CLKCMU_PERIC0_USI03 0x18bc
#define CLK_CON_DIV_CLKCMU_PERIC1_BUS 0x18c0
#define CLK_CON_DIV_CLKCMU_PERIC1_SPEEDY2 0x18c4
#define CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM0 0x18c8
#define CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM1 0x18cc
#define CLK_CON_DIV_CLKCMU_PERIC1_UART_BT 0x18d0
#define CLK_CON_DIV_CLKCMU_PERIC1_USI04 0x18d4
#define CLK_CON_DIV_CLKCMU_PERIC1_USI05 0x18d8
#define CLK_CON_DIV_CLKCMU_PERIC1_USI06 0x18dc
#define CLK_CON_DIV_CLKCMU_PERIC1_USI07 0x18e0
#define CLK_CON_DIV_CLKCMU_PERIC1_USI08 0x18e4
#define CLK_CON_DIV_CLKCMU_PERIC1_USI09 0x18e8
#define CLK_CON_DIV_CLKCMU_PERIC1_USI10 0x18ec
#define CLK_CON_DIV_CLKCMU_PERIC1_USI11 0x18f0
#define CLK_CON_DIV_CLKCMU_PERIC1_USI12 0x18f4
#define CLK_CON_DIV_CLKCMU_PERIC1_USI13 0x18f8
#define CLK_CON_DIV_CLKCMU_PERIS_BUS 0x18fc
#define CLK_CON_DIV_CLKCMU_SRDZ_BUS 0x1900
#define CLK_CON_DIV_CLKCMU_SRDZ_IMGD 0x1904
#define CLK_CON_DIV_CLKCMU_VPU_BUS 0x1908
#define CLK_CON_DIV_DIV_CLK_CMU_CMUREF 0x190c
#define CLK_CON_DIV_DIV_CP2AP_MIF_CLK_DIV2 0x1910
#define CLK_CON_DIV_DIV_PLL_SHARED0_DIV2 0x1914
#define CLK_CON_DIV_DIV_PLL_SHARED0_DIV4 0x1918
#define CLK_CON_DIV_DIV_PLL_SHARED1_DIV2 0x191c
#define CLK_CON_DIV_DIV_PLL_SHARED1_DIV4 0x1920
#define CLK_CON_DIV_DIV_PLL_SHARED2_DIV2 0x1924
#define CLK_CON_DIV_DIV_PLL_SHARED3_DIV2 0x1928
#define CLK_CON_DIV_DIV_PLL_SHARED4_DIV2 0x192c
#define CLK_CON_GAT_CLKCMU_DROOPDETECTOR 0x2000
#define CLK_CON_GAT_CLKCMU_MIF_SWITCH 0x2004
#define CLK_CON_GAT_GATE_CLKCMU_ABOX_CPUABOX 0x2008
#define CLK_CON_GAT_GATE_CLKCMU_APM_BUS 0x200c
#define CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS 0x2010
#define CLK_CON_GAT_GATE_CLKCMU_BUSC_BUS 0x2014
#define CLK_CON_GAT_GATE_CLKCMU_BUSC_BUSPHSI2C 0x2018
#define CLK_CON_GAT_GATE_CLKCMU_CAM_BUS 0x201c
#define CLK_CON_GAT_GATE_CLKCMU_CAM_TPU0 0x2020
#define CLK_CON_GAT_GATE_CLKCMU_CAM_TPU1 0x2024
#define CLK_CON_GAT_GATE_CLKCMU_CAM_VRA 0x2028
#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0 0x202c
#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1 0x2030
#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2 0x2034
#define CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3 0x2038
#define CLK_CON_GAT_GATE_CLKCMU_CORE_BUS 0x203c
#define CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH 0x2040
#define CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH 0x2044
#define CLK_CON_GAT_GATE_CLKCMU_DBG_BUS 0x2048
#define CLK_CON_GAT_GATE_CLKCMU_DCAM_BUS 0x204c
#define CLK_CON_GAT_GATE_CLKCMU_DCAM_IMGD 0x2050
#define CLK_CON_GAT_GATE_CLKCMU_DPU_BUS 0x2054
#define CLK_CON_GAT_GATE_CLKCMU_DSP_BUS 0x2058
#define CLK_CON_GAT_GATE_CLKCMU_FSYS0_BUS 0x205c
#define CLK_CON_GAT_GATE_CLKCMU_FSYS0_DPGTC 0x2060
#define CLK_CON_GAT_GATE_CLKCMU_FSYS0_MMC_EMBD 0x2064
#define CLK_CON_GAT_GATE_CLKCMU_FSYS0_UFS_EMBD 0x2068
#define CLK_CON_GAT_GATE_CLKCMU_FSYS0_USBDRD30 0x206c
#define CLK_CON_GAT_GATE_CLKCMU_FSYS1_BUS 0x2070
#define CLK_CON_GAT_GATE_CLKCMU_FSYS1_MMC_CARD 0x2074
#define CLK_CON_GAT_GATE_CLKCMU_FSYS1_PCIE 0x2078
#define CLK_CON_GAT_GATE_CLKCMU_FSYS1_UFS_CARD 0x207c
#define CLK_CON_GAT_GATE_CLKCMU_G2D_G2D 0x2080
#define CLK_CON_GAT_GATE_CLKCMU_G2D_JPEG 0x2084
#define CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH 0x2088
#define CLK_CON_GAT_GATE_CLKCMU_HPM 0x208c
#define CLK_CON_GAT_GATE_CLKCMU_IMEM_BUS 0x2090
#define CLK_CON_GAT_GATE_CLKCMU_ISPHQ_BUS 0x2094
#define CLK_CON_GAT_GATE_CLKCMU_ISPLP_BUS 0x2098
#define CLK_CON_GAT_GATE_CLKCMU_IVA_BUS 0x209c
#define CLK_CON_GAT_GATE_CLKCMU_MFC_BUS 0x20a0
#define CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED0 0x20a4
#define CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED1 0x20a8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS 0x20ac
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_UART_DBG 0x20b0
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI00 0x20b4
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI01 0x20b8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI02 0x20bc
#define CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI03 0x20c0
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS 0x20c4
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPEEDY2 0x20c8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM0 0x20cc
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM1 0x20d0
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_UART_BT 0x20d4
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI04 0x20d8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI05 0x20dc
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI06 0x20e0
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI07 0x20e4
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI08 0x20e8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI09 0x20ec
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI10 0x20f0
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI11 0x20f4
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI12 0x20f8
#define CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI13 0x20fc
#define CLK_CON_GAT_GATE_CLKCMU_PERIS_BUS 0x2100
#define CLK_CON_GAT_GATE_CLKCMU_SRDZ_BUS 0x2104
#define CLK_CON_GAT_GATE_CLKCMU_SRDZ_IMGD 0x2108
#define CLK_CON_GAT_GATE_CLKCMU_VPU_BUS 0x210c
static const unsigned long top_clk_regs[] __initconst = {
PLL_LOCKTIME_PLL_SHARED0,
PLL_LOCKTIME_PLL_SHARED1,
PLL_LOCKTIME_PLL_SHARED2,
PLL_LOCKTIME_PLL_SHARED3,
PLL_LOCKTIME_PLL_SHARED4,
PLL_CON0_MUX_CP2AP_MIF_CLK_USER,
PLL_CON2_MUX_CP2AP_MIF_CLK_USER,
PLL_CON0_PLL_SHARED0,
PLL_CON0_PLL_SHARED1,
PLL_CON0_PLL_SHARED2,
PLL_CON0_PLL_SHARED3,
PLL_CON0_PLL_SHARED4,
CLK_CON_MUX_MUX_CLKCMU_ABOX_CPUABOX,
CLK_CON_MUX_MUX_CLKCMU_APM_BUS,
CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS,
CLK_CON_MUX_MUX_CLKCMU_BUSC_BUS,
CLK_CON_MUX_MUX_CLKCMU_BUSC_BUSPHSI2C,
CLK_CON_MUX_MUX_CLKCMU_CAM_BUS,
CLK_CON_MUX_MUX_CLKCMU_CAM_TPU0,
CLK_CON_MUX_MUX_CLKCMU_CAM_TPU1,
CLK_CON_MUX_MUX_CLKCMU_CAM_VRA,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3,
CLK_CON_MUX_MUX_CLKCMU_CORE_BUS,
CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH,
CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH,
CLK_CON_MUX_MUX_CLKCMU_DBG_BUS,
CLK_CON_MUX_MUX_CLKCMU_DCAM_BUS,
CLK_CON_MUX_MUX_CLKCMU_DCAM_IMGD,
CLK_CON_MUX_MUX_CLKCMU_DPU_BUS,
CLK_CON_MUX_MUX_CLKCMU_DROOPDETECTOR,
CLK_CON_MUX_MUX_CLKCMU_DSP_BUS,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_BUS,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_DPGTC,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_MMC_EMBD,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_UFS_EMBD,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_USBDRD30,
CLK_CON_MUX_MUX_CLKCMU_FSYS1_BUS,
CLK_CON_MUX_MUX_CLKCMU_FSYS1_MMC_CARD,
CLK_CON_MUX_MUX_CLKCMU_FSYS1_PCIE,
CLK_CON_MUX_MUX_CLKCMU_FSYS1_UFS_CARD,
CLK_CON_MUX_MUX_CLKCMU_G2D_G2D,
CLK_CON_MUX_MUX_CLKCMU_G2D_JPEG,
CLK_CON_MUX_MUX_CLKCMU_HPM,
CLK_CON_MUX_MUX_CLKCMU_IMEM_BUS,
CLK_CON_MUX_MUX_CLKCMU_ISPHQ_BUS,
CLK_CON_MUX_MUX_CLKCMU_ISPLP_BUS,
CLK_CON_MUX_MUX_CLKCMU_IVA_BUS,
CLK_CON_MUX_MUX_CLKCMU_MFC_BUS,
CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_UART_DBG,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI00,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI01,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI02,
CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI03,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPEEDY2,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM0,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM1,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_UART_BT,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI04,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI05,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI06,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI07,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI08,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI09,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI10,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI11,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI12,
CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI13,
CLK_CON_MUX_MUX_CLKCMU_PERIS_BUS,
CLK_CON_MUX_MUX_CLKCMU_SRDZ_BUS,
CLK_CON_MUX_MUX_CLKCMU_SRDZ_IMGD,
CLK_CON_MUX_MUX_CLKCMU_VPU_BUS,
CLK_CON_MUX_MUX_CLK_CMU_CMUREF,
CLK_CON_MUX_MUX_CMU_CMUREF,
CLK_CON_DIV_CLKCMU_ABOX_CPUABOX,
CLK_CON_DIV_CLKCMU_APM_BUS,
CLK_CON_DIV_CLKCMU_BUS1_BUS,
CLK_CON_DIV_CLKCMU_BUSC_BUS,
CLK_CON_DIV_CLKCMU_BUSC_BUSPHSI2C,
CLK_CON_DIV_CLKCMU_CAM_BUS,
CLK_CON_DIV_CLKCMU_CAM_TPU0,
CLK_CON_DIV_CLKCMU_CAM_TPU1,
CLK_CON_DIV_CLKCMU_CAM_VRA,
CLK_CON_DIV_CLKCMU_CIS_CLK0,
CLK_CON_DIV_CLKCMU_CIS_CLK1,
CLK_CON_DIV_CLKCMU_CIS_CLK2,
CLK_CON_DIV_CLKCMU_CIS_CLK3,
CLK_CON_DIV_CLKCMU_CORE_BUS,
CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH,
CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH,
CLK_CON_DIV_CLKCMU_DBG_BUS,
CLK_CON_DIV_CLKCMU_DCAM_BUS,
CLK_CON_DIV_CLKCMU_DCAM_IMGD,
CLK_CON_DIV_CLKCMU_DPU_BUS,
CLK_CON_DIV_CLKCMU_DSP_BUS,
CLK_CON_DIV_CLKCMU_FSYS0_BUS,
CLK_CON_DIV_CLKCMU_FSYS0_DPGTC,
CLK_CON_DIV_CLKCMU_FSYS0_MMC_EMBD,
CLK_CON_DIV_CLKCMU_FSYS0_UFS_EMBD,
CLK_CON_DIV_CLKCMU_FSYS0_USBDRD30,
CLK_CON_DIV_CLKCMU_FSYS1_BUS,
CLK_CON_DIV_CLKCMU_FSYS1_MMC_CARD,
CLK_CON_DIV_CLKCMU_FSYS1_PCIE,
CLK_CON_DIV_CLKCMU_FSYS1_UFS_CARD,
CLK_CON_DIV_CLKCMU_G2D_G2D,
CLK_CON_DIV_CLKCMU_G2D_JPEG,
CLK_CON_DIV_CLKCMU_G3D_SWITCH,
CLK_CON_DIV_CLKCMU_HPM,
CLK_CON_DIV_CLKCMU_IMEM_BUS,
CLK_CON_DIV_CLKCMU_ISPHQ_BUS,
CLK_CON_DIV_CLKCMU_ISPLP_BUS,
CLK_CON_DIV_CLKCMU_IVA_BUS,
CLK_CON_DIV_CLKCMU_MFC_BUS,
CLK_CON_DIV_CLKCMU_MODEM_SHARED0,
CLK_CON_DIV_CLKCMU_MODEM_SHARED1,
CLK_CON_DIV_CLKCMU_OTP,
CLK_CON_DIV_CLKCMU_PERIC0_BUS,
CLK_CON_DIV_CLKCMU_PERIC0_UART_DBG,
CLK_CON_DIV_CLKCMU_PERIC0_USI00,
CLK_CON_DIV_CLKCMU_PERIC0_USI01,
CLK_CON_DIV_CLKCMU_PERIC0_USI02,
CLK_CON_DIV_CLKCMU_PERIC0_USI03,
CLK_CON_DIV_CLKCMU_PERIC1_BUS,
CLK_CON_DIV_CLKCMU_PERIC1_SPEEDY2,
CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM0,
CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM1,
CLK_CON_DIV_CLKCMU_PERIC1_UART_BT,
CLK_CON_DIV_CLKCMU_PERIC1_USI04,
CLK_CON_DIV_CLKCMU_PERIC1_USI05,
CLK_CON_DIV_CLKCMU_PERIC1_USI06,
CLK_CON_DIV_CLKCMU_PERIC1_USI07,
CLK_CON_DIV_CLKCMU_PERIC1_USI08,
CLK_CON_DIV_CLKCMU_PERIC1_USI09,
CLK_CON_DIV_CLKCMU_PERIC1_USI10,
CLK_CON_DIV_CLKCMU_PERIC1_USI11,
CLK_CON_DIV_CLKCMU_PERIC1_USI12,
CLK_CON_DIV_CLKCMU_PERIC1_USI13,
CLK_CON_DIV_CLKCMU_PERIS_BUS,
CLK_CON_DIV_CLKCMU_SRDZ_BUS,
CLK_CON_DIV_CLKCMU_SRDZ_IMGD,
CLK_CON_DIV_CLKCMU_VPU_BUS,
CLK_CON_DIV_DIV_CLK_CMU_CMUREF,
CLK_CON_DIV_DIV_CP2AP_MIF_CLK_DIV2,
CLK_CON_DIV_DIV_PLL_SHARED0_DIV2,
CLK_CON_DIV_DIV_PLL_SHARED0_DIV4,
CLK_CON_DIV_DIV_PLL_SHARED1_DIV2,
CLK_CON_DIV_DIV_PLL_SHARED1_DIV4,
CLK_CON_DIV_DIV_PLL_SHARED2_DIV2,
CLK_CON_DIV_DIV_PLL_SHARED3_DIV2,
CLK_CON_DIV_DIV_PLL_SHARED4_DIV2,
CLK_CON_GAT_CLKCMU_DROOPDETECTOR,
CLK_CON_GAT_CLKCMU_MIF_SWITCH,
CLK_CON_GAT_GATE_CLKCMU_ABOX_CPUABOX,
CLK_CON_GAT_GATE_CLKCMU_APM_BUS,
CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS,
CLK_CON_GAT_GATE_CLKCMU_BUSC_BUS,
CLK_CON_GAT_GATE_CLKCMU_BUSC_BUSPHSI2C,
CLK_CON_GAT_GATE_CLKCMU_CAM_BUS,
CLK_CON_GAT_GATE_CLKCMU_CAM_TPU0,
CLK_CON_GAT_GATE_CLKCMU_CAM_TPU1,
CLK_CON_GAT_GATE_CLKCMU_CAM_VRA,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3,
CLK_CON_GAT_GATE_CLKCMU_CORE_BUS,
CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH,
CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH,
CLK_CON_GAT_GATE_CLKCMU_DBG_BUS,
CLK_CON_GAT_GATE_CLKCMU_DCAM_BUS,
CLK_CON_GAT_GATE_CLKCMU_DCAM_IMGD,
CLK_CON_GAT_GATE_CLKCMU_DPU_BUS,
CLK_CON_GAT_GATE_CLKCMU_DSP_BUS,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_BUS,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_DPGTC,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_MMC_EMBD,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_UFS_EMBD,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_USBDRD30,
CLK_CON_GAT_GATE_CLKCMU_FSYS1_BUS,
CLK_CON_GAT_GATE_CLKCMU_FSYS1_MMC_CARD,
CLK_CON_GAT_GATE_CLKCMU_FSYS1_PCIE,
CLK_CON_GAT_GATE_CLKCMU_FSYS1_UFS_CARD,
CLK_CON_GAT_GATE_CLKCMU_G2D_G2D,
CLK_CON_GAT_GATE_CLKCMU_G2D_JPEG,
CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH,
CLK_CON_GAT_GATE_CLKCMU_HPM,
CLK_CON_GAT_GATE_CLKCMU_IMEM_BUS,
CLK_CON_GAT_GATE_CLKCMU_ISPHQ_BUS,
CLK_CON_GAT_GATE_CLKCMU_ISPLP_BUS,
CLK_CON_GAT_GATE_CLKCMU_IVA_BUS,
CLK_CON_GAT_GATE_CLKCMU_MFC_BUS,
CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED0,
CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED1,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_UART_DBG,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI00,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI01,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI02,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI03,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPEEDY2,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM0,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM1,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_UART_BT,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI04,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI05,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI06,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI07,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI08,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI09,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI10,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI11,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI12,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI13,
CLK_CON_GAT_GATE_CLKCMU_PERIS_BUS,
CLK_CON_GAT_GATE_CLKCMU_SRDZ_BUS,
CLK_CON_GAT_GATE_CLKCMU_SRDZ_IMGD,
CLK_CON_GAT_GATE_CLKCMU_VPU_BUS,
};
static const struct samsung_pll_rate_table pll_shared0_rate_table[] __initconst = {
PLL_35XX_RATE(26 * MHZ, 2132000000U, 328, 4, 0),
};
static const struct samsung_pll_rate_table pll_shared1_rate_table[] __initconst = {
PLL_35XX_RATE(26 * MHZ, 1865500000U, 287, 4, 0),
};
static const struct samsung_pll_rate_table pll_shared2_rate_table[] __initconst = {
PLL_35XX_RATE(26 * MHZ, 800000000U, 400, 13, 0),
};
static const struct samsung_pll_rate_table pll_shared3_rate_table[] __initconst = {
PLL_35XX_RATE(26 * MHZ, 630000000U, 315, 13, 0),
};
static const struct samsung_pll_rate_table pll_shared4_rate_table[] __initconst = {
PLL_35XX_RATE(26 * MHZ, 667333333U, 154, 6, 0),
};
static const struct samsung_pll_clock top_pll_clks[] __initconst = {
/* CMU_TOP_PURECLKCOMP */
PLL(pll_1051x, CLK_FOUT_SHARED0_PLL, "fout_shared0_pll" , "oscclk" ,
PLL_LOCKTIME_PLL_SHARED0, PLL_CON0_PLL_SHARED0,
pll_shared0_rate_table),
PLL(pll_1051x, CLK_FOUT_SHARED1_PLL, "fout_shared1_pll" , "oscclk" ,
PLL_LOCKTIME_PLL_SHARED1, PLL_CON0_PLL_SHARED1,
pll_shared1_rate_table),
PLL(pll_1052x, CLK_FOUT_SHARED2_PLL, "fout_shared2_pll" , "oscclk" ,
PLL_LOCKTIME_PLL_SHARED2, PLL_CON0_PLL_SHARED2,
pll_shared2_rate_table),
PLL(pll_1052x, CLK_FOUT_SHARED3_PLL, "fout_shared3_pll" , "oscclk" ,
PLL_LOCKTIME_PLL_SHARED3, PLL_CON0_PLL_SHARED3,
pll_shared3_rate_table),
PLL(pll_1052x, CLK_FOUT_SHARED4_PLL, "fout_shared4_pll" , "oscclk" ,
PLL_LOCKTIME_PLL_SHARED4, PLL_CON0_PLL_SHARED4,
pll_shared4_rate_table),
};
/* List of parent clocks for Muxes in CMU_TOP */
PNAME(mout_pll_shared0_p) = { "oscclk" , "fout_shared0_pll" };
PNAME(mout_pll_shared1_p) = { "oscclk" , "fout_shared1_pll" };
PNAME(mout_pll_shared2_p) = { "oscclk" , "fout_shared2_pll" };
PNAME(mout_pll_shared3_p) = { "oscclk" , "fout_shared3_pll" };
PNAME(mout_pll_shared4_p) = { "oscclk" , "fout_shared4_pll" };
PNAME(mout_cp2ap_mif_clk_user_p) = { "oscclk" };
PNAME(mout_cmu_abox_cpuabox_p) = { "dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"fout_shared4_pll" };
PNAME(mout_cmu_apm_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_bus1_bus_p) = { "fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_busc_bus_p) = { "fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_cp2ap_mif_clk_div2" ,
"oscclk" , "oscclk" , "oscclk" };
PNAME(mout_cmu_busc_busphsi2c_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_cp2ap_mif_clk_div2" ,
"oscclk" };
PNAME(mout_cmu_cam_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_cam_tpu0_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_cam_tpu1_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_cam_vra_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_cis_clk0_p) = { "oscclk" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_cis_clk1_p) = { "oscclk" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_cis_clk2_p) = { "oscclk" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_cis_clk3_p) = { "oscclk" ,
"dout_cmu_shared2_div2" };
PNAME(mout_core_bus_p) = { "dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_cp2ap_mif_clk_div2" };
PNAME(mout_cmu_cpucl0_switch_p) = { "dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"fout_shared4_pll" };
PNAME(mout_cmu_cpucl1_switch_p) = { "dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"fout_shared4_pll" };
PNAME(mout_cmu_dbg_bus_p) = { "fout_shared2_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" };
PNAME(mout_cmu_dcam_bus_p) = { "fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_dcam_imgd_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_dpu_bus_p) = { "dout_cmu_shared0_div2" ,
"fout_shared3_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"oscclk" , "oscclk" , "oscclk" };
PNAME(mout_cmu_droopdetector_p) = { "oscclk" , "dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" };
PNAME(mout_cmu_dsp_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_fsys0_bus_p) = { "dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared0_div4" };
PNAME(mout_fsys0_dpgtc_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_fsys0_mmc_embd_p) = { "oscclk" , "fout_shared2_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"oscclk" , "oscclk" , "oscclk" };
PNAME(mout_fsys0_ufs_embd_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_fsys0_usbdrd30_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_fsys1_bus_p) = { "fout_shared2_pll" ,
"dout_cmu_shared0_div4" };
PNAME(mout_cmu_fsys1_mmc_card_p) = { "oscclk" , "fout_shared2_pll" ,
"fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"oscclk" , "oscclk" , "oscclk" };
PNAME(mout_cmu_fsys1_pcie_p) = { "oscclk" , "fout_shared2_pll" };
PNAME(mout_cmu_fsys1_ufs_card_p) = { "oscclk" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_g2d_g2d_p) = { "fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_g2d_jpeg_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_hpm_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_imem_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_isphq_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_isplp_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_iva_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_mfc_bus_p) = { "fout_shared4_pll" ,
"dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_mif_switch_p) = { "fout_shared0_pll" ,
"fout_shared1_pll" ,
"dout_cmu_shared0_div2" ,
"dout_cmu_shared1_div2" ,
"fout_shared2_pll" ,
"mout_cp2ap_mif_clk_user" ,
"oscclk" , "oscclk" };
PNAME(mout_cmu_peric0_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_peric0_uart_dbg_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric0_usi00_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric0_usi01_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric0_usi02_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric0_usi03_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_peric1_speedy2_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"oscclk" };
PNAME(mout_cmu_peric1_spi_cam0_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_spi_cam1_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_uart_bt_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi04_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi05_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi06_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi07_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi08_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi09_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi10_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi11_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi12_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peric1_usi13_p) = { "oscclk" , "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_peris_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared2_div2" };
PNAME(mout_cmu_srdz_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_srdz_imgd_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
PNAME(mout_cmu_vpu_bus_p) = { "dout_cmu_shared0_div4" ,
"dout_cmu_shared1_div4" ,
"dout_cmu_shared2_div2" ,
"dout_cmu_shared4_div2" };
/*
* Register name to clock name mangling strategy used in this file
*
* Replace PLL_CON0_PLL with CLK_MOUT_PLL and mout_pll
* Replace CLK_CON_MUX_MUX_CLKCMU with CLK_MOUT_CMU and mout_cmu
* Replace CLK_CON_DIV_CLKCMU with CLK_DOUT_CMU and dout_cmu
* Replace CLK_CON_DIV_DIV_CLKCMU with CLK_DOUT_CMU and dout_cmu
* Replace CLK_CON_GAT_CLKCMU with CLK_GOUT_CMU and gout_cmu
* Replace CLK_CON_GAT_GATE_CLKCMU with CLK_GOUT_CMU and gout_cmu
*
* For gates remove _UID _BLK _IPCLKPORT and _RSTNSYNC
*/
static const struct samsung_mux_clock top_mux_clks[] __initconst = {
MUX(CLK_MOUT_PLL_SHARED0, "mout_pll_shared0" , mout_pll_shared0_p,
PLL_CON0_PLL_SHARED0, 4, 1),
MUX(CLK_MOUT_PLL_SHARED1, "mout_pll_shared1" , mout_pll_shared1_p,
PLL_CON0_PLL_SHARED1, 4, 1),
MUX(CLK_MOUT_PLL_SHARED2, "mout_pll_shared2" , mout_pll_shared2_p,
PLL_CON0_PLL_SHARED2, 4, 1),
MUX(CLK_MOUT_PLL_SHARED3, "mout_pll_shared3" , mout_pll_shared3_p,
PLL_CON0_PLL_SHARED3, 4, 1),
MUX(CLK_MOUT_PLL_SHARED4, "mout_pll_shared4" , mout_pll_shared4_p,
PLL_CON0_PLL_SHARED4, 4, 1),
MUX(CLK_MOUT_CP2AP_MIF_CLK_USER, "mout_cp2ap_mif_clk_user" ,
mout_cp2ap_mif_clk_user_p, PLL_CON0_MUX_CP2AP_MIF_CLK_USER, 4, 1),
MUX(CLK_MOUT_CMU_ABOX_CPUABOX, "mout_cmu_abox_cpuabox" ,
mout_cmu_abox_cpuabox_p, CLK_CON_MUX_MUX_CLKCMU_ABOX_CPUABOX,
0, 2),
MUX(CLK_MOUT_CMU_APM_BUS, "mout_cmu_apm_bus" , mout_cmu_apm_bus_p,
CLK_CON_MUX_MUX_CLKCMU_APM_BUS, 0, 1),
MUX(CLK_MOUT_CMU_BUS1_BUS, "mout_cmu_bus1_bus" , mout_cmu_bus1_bus_p,
CLK_CON_MUX_MUX_CLKCMU_BUS1_BUS, 0, 2),
MUX(CLK_MOUT_CMU_BUSC_BUS, "mout_cmu_busc_bus" , mout_cmu_busc_bus_p,
CLK_CON_MUX_MUX_CLKCMU_BUSC_BUS, 0, 3),
MUX(CLK_MOUT_CMU_BUSC_BUSPHSI2C, "mout_cmu_busc_busphsi2c" ,
mout_cmu_busc_busphsi2c_p, CLK_CON_MUX_MUX_CLKCMU_BUSC_BUSPHSI2C,
0, 2),
MUX(CLK_MOUT_CMU_CAM_BUS, "mout_cmu_cam_bus" , mout_cmu_cam_bus_p,
CLK_CON_MUX_MUX_CLKCMU_CAM_BUS, 0, 2),
MUX(CLK_MOUT_CMU_CAM_TPU0, "mout_cmu_cam_tpu0" , mout_cmu_cam_tpu0_p,
CLK_CON_MUX_MUX_CLKCMU_CAM_TPU0, 0, 2),
MUX(CLK_MOUT_CMU_CAM_TPU1, "mout_cmu_cam_tpu1" , mout_cmu_cam_tpu1_p,
CLK_CON_MUX_MUX_CLKCMU_CAM_TPU1, 0, 2),
MUX(CLK_MOUT_CMU_CAM_VRA, "mout_cmu_cam_vra" , mout_cmu_cam_vra_p,
CLK_CON_MUX_MUX_CLKCMU_CAM_VRA, 0, 2),
MUX(CLK_MOUT_CMU_CIS_CLK0, "mout_cmu_cis_clk0" , mout_cmu_cis_clk0_p,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK0, 0, 1),
MUX(CLK_MOUT_CMU_CIS_CLK1, "mout_cmu_cis_clk1" , mout_cmu_cis_clk1_p,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK1, 0, 1),
MUX(CLK_MOUT_CMU_CIS_CLK2, "mout_cmu_cis_clk2" , mout_cmu_cis_clk2_p,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK2, 0, 1),
MUX(CLK_MOUT_CMU_CIS_CLK3, "mout_cmu_cis_clk3" , mout_cmu_cis_clk3_p,
CLK_CON_MUX_MUX_CLKCMU_CIS_CLK3, 0, 1),
MUX(CLK_MOUT_CMU_CORE_BUS, "mout_core_bus" , mout_core_bus_p,
CLK_CON_MUX_MUX_CLKCMU_CORE_BUS, 0, 3),
MUX(CLK_MOUT_CMU_CPUCL0_SWITCH, "mout_cmu_cpucl0_switch" ,
mout_cmu_cpucl0_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL0_SWITCH,
0, 2),
MUX(CLK_MOUT_CMU_CPUCL1_SWITCH, "mout_cmu_cpucl1_switch" ,
mout_cmu_cpucl1_switch_p, CLK_CON_MUX_MUX_CLKCMU_CPUCL1_SWITCH,
0, 2),
MUX(CLK_MOUT_CMU_DBG_BUS, "mout_cmu_dbg_bus" , mout_cmu_dbg_bus_p,
CLK_CON_MUX_MUX_CLKCMU_DBG_BUS, 0, 2),
MUX(CLK_MOUT_CMU_DCAM_BUS, "mout_cmu_dcam_bus" , mout_cmu_dcam_bus_p,
CLK_CON_MUX_MUX_CLKCMU_DCAM_BUS, 0, 2),
MUX(CLK_MOUT_CMU_DCAM_IMGD, "mout_cmu_dcam_imgd" , mout_cmu_dcam_imgd_p,
CLK_CON_MUX_MUX_CLKCMU_DCAM_IMGD, 0, 2),
MUX(CLK_MOUT_CMU_DPU_BUS, "mout_cmu_dpu_bus" , mout_cmu_dpu_bus_p,
CLK_CON_MUX_MUX_CLKCMU_DPU_BUS, 0, 3),
MUX(CLK_MOUT_CMU_DROOPDETECTOR, "mout_cmu_droopdetector" ,
mout_cmu_droopdetector_p, CLK_CON_MUX_MUX_CLKCMU_DROOPDETECTOR,
0, 2),
MUX(CLK_MOUT_CMU_DSP_BUS, "mout_cmu_dsp_bus" , mout_cmu_dsp_bus_p,
CLK_CON_MUX_MUX_CLKCMU_DSP_BUS, 0, 2),
MUX(CLK_MOUT_CMU_FSYS0_BUS, "mout_fsys0_bus" , mout_fsys0_bus_p,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_BUS, 0, 2),
MUX(CLK_MOUT_CMU_FSYS0_DPGTC, "mout_fsys0_dpgtc" , mout_fsys0_dpgtc_p,
CLK_CON_MUX_MUX_CLKCMU_FSYS0_DPGTC, 0, 2),
MUX(CLK_MOUT_CMU_FSYS0_MMC_EMBD, "mout_fsys0_mmc_embd" ,
mout_fsys0_mmc_embd_p, CLK_CON_MUX_MUX_CLKCMU_FSYS0_MMC_EMBD,
0, 3),
MUX(CLK_MOUT_CMU_FSYS0_UFS_EMBD, "mout_fsys0_ufs_embd" ,
mout_fsys0_ufs_embd_p, CLK_CON_MUX_MUX_CLKCMU_FSYS0_UFS_EMBD,
0, 2),
MUX(CLK_MOUT_CMU_FSYS0_USBDRD30, "mout_fsys0_usbdrd30" ,
mout_fsys0_usbdrd30_p, CLK_CON_MUX_MUX_CLKCMU_FSYS0_USBDRD30,
0, 2),
MUX(CLK_MOUT_CMU_FSYS1_BUS, "mout_cmu_fsys1_bus" , mout_cmu_fsys1_bus_p,
CLK_CON_MUX_MUX_CLKCMU_FSYS1_BUS, 0, 1),
MUX(CLK_MOUT_CMU_FSYS1_MMC_CARD, "mout_cmu_fsys1_mmc_card" ,
mout_cmu_fsys1_mmc_card_p, CLK_CON_MUX_MUX_CLKCMU_FSYS1_MMC_CARD,
0, 3),
MUX(CLK_MOUT_CMU_FSYS1_PCIE, "mout_cmu_fsys1_pcie" ,
mout_cmu_fsys1_pcie_p, CLK_CON_MUX_MUX_CLKCMU_FSYS1_PCIE, 0, 1),
MUX(CLK_MOUT_CMU_FSYS1_UFS_CARD, "mout_cmu_fsys1_ufs_card" ,
mout_cmu_fsys1_ufs_card_p, CLK_CON_MUX_MUX_CLKCMU_FSYS1_UFS_CARD,
0, 2),
MUX(CLK_MOUT_CMU_G2D_G2D, "mout_cmu_g2d_g2d" , mout_cmu_g2d_g2d_p,
CLK_CON_MUX_MUX_CLKCMU_G2D_G2D, 0, 2),
MUX(CLK_MOUT_CMU_G2D_JPEG, "mout_cmu_g2d_jpeg" , mout_cmu_g2d_jpeg_p,
CLK_CON_MUX_MUX_CLKCMU_G2D_JPEG, 0, 2),
MUX(CLK_MOUT_CMU_HPM, "mout_cmu_hpm" , mout_cmu_hpm_p,
CLK_CON_MUX_MUX_CLKCMU_HPM, 0, 2),
MUX(CLK_MOUT_CMU_IMEM_BUS, "mout_cmu_imem_bus" , mout_cmu_imem_bus_p,
CLK_CON_MUX_MUX_CLKCMU_IMEM_BUS, 0, 2),
MUX(CLK_MOUT_CMU_ISPHQ_BUS, "mout_cmu_isphq_bus" , mout_cmu_isphq_bus_p,
CLK_CON_MUX_MUX_CLKCMU_ISPHQ_BUS, 0, 2),
MUX(CLK_MOUT_CMU_ISPLP_BUS, "mout_cmu_isplp_bus" , mout_cmu_isplp_bus_p,
CLK_CON_MUX_MUX_CLKCMU_ISPLP_BUS, 0, 2),
MUX(CLK_MOUT_CMU_IVA_BUS, "mout_cmu_iva_bus" , mout_cmu_iva_bus_p,
CLK_CON_MUX_MUX_CLKCMU_IVA_BUS, 0, 2),
MUX(CLK_MOUT_CMU_MFC_BUS, "mout_cmu_mfc_bus" , mout_cmu_mfc_bus_p,
CLK_CON_MUX_MUX_CLKCMU_MFC_BUS, 0, 2),
MUX(CLK_MOUT_CMU_MIF_SWITCH, "mout_cmu_mif_switch" ,
mout_cmu_mif_switch_p, CLK_CON_MUX_MUX_CLKCMU_MIF_SWITCH, 0, 3),
MUX(CLK_MOUT_CMU_PERIC0_BUS, "mout_cmu_peric0_bus" ,
mout_cmu_peric0_bus_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_BUS, 0, 1),
MUX(CLK_MOUT_CMU_PERIC0_UART_DBG, "mout_cmu_peric0_uart_dbg" ,
mout_cmu_peric0_uart_dbg_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_UART_DBG,
0, 2),
MUX(CLK_MOUT_CMU_PERIC0_USI00, "mout_cmu_peric0_usi00" ,
mout_cmu_peric0_usi00_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI00,
0, 2),
MUX(CLK_MOUT_CMU_PERIC0_USI01, "mout_cmu_peric0_usi01" ,
mout_cmu_peric0_usi01_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI01,
0, 2),
MUX(CLK_MOUT_CMU_PERIC0_USI02, "mout_cmu_peric0_usi02" ,
mout_cmu_peric0_usi02_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI02,
0, 2),
MUX(CLK_MOUT_CMU_PERIC0_USI03, "mout_cmu_peric0_usi03" ,
mout_cmu_peric0_usi03_p, CLK_CON_MUX_MUX_CLKCMU_PERIC0_USI03,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_BUS, "mout_cmu_peric1_bus" ,
mout_cmu_peric1_bus_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_BUS, 0, 1),
MUX(CLK_MOUT_CMU_PERIC1_SPEEDY2, "mout_cmu_peric1_speedy2" ,
mout_cmu_peric1_speedy2_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPEEDY2,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_SPI_CAM0, "mout_cmu_peric1_spi_cam0" ,
mout_cmu_peric1_spi_cam0_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM0,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_SPI_CAM1, "mout_cmu_peric1_spi_cam1" ,
mout_cmu_peric1_spi_cam1_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_SPI_CAM1,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_UART_BT, "mout_cmu_peric1_uart_bt" ,
mout_cmu_peric1_uart_bt_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_UART_BT,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI04, "mout_cmu_peric1_usi04" ,
mout_cmu_peric1_usi04_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI04,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI05, "mout_cmu_peric1_usi05" ,
mout_cmu_peric1_usi05_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI05,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI06, "mout_cmu_peric1_usi06" ,
mout_cmu_peric1_usi06_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI06,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI07, "mout_cmu_peric1_usi07" ,
mout_cmu_peric1_usi07_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI07,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI08, "mout_cmu_peric1_usi08" ,
mout_cmu_peric1_usi08_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI08,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI09, "mout_cmu_peric1_usi09" ,
mout_cmu_peric1_usi09_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI09,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI10, "mout_cmu_peric1_usi10" ,
mout_cmu_peric1_usi10_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI10,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI11, "mout_cmu_peric1_usi11" ,
mout_cmu_peric1_usi11_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI11,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI12, "mout_cmu_peric1_usi12" ,
mout_cmu_peric1_usi12_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI12,
0, 2),
MUX(CLK_MOUT_CMU_PERIC1_USI13, "mout_cmu_peric1_usi13" ,
mout_cmu_peric1_usi13_p, CLK_CON_MUX_MUX_CLKCMU_PERIC1_USI13,
0, 2),
MUX(CLK_MOUT_CMU_PERIS_BUS, "mout_cmu_peris_bus" , mout_cmu_peris_bus_p,
CLK_CON_MUX_MUX_CLKCMU_PERIS_BUS, 0, 1),
MUX(CLK_MOUT_CMU_SRDZ_BUS, "mout_cmu_srdz_bus" , mout_cmu_srdz_bus_p,
CLK_CON_MUX_MUX_CLKCMU_SRDZ_BUS, 0, 2),
MUX(CLK_MOUT_CMU_SRDZ_IMGD, "mout_cmu_srdz_imgd" , mout_cmu_srdz_imgd_p,
CLK_CON_MUX_MUX_CLKCMU_SRDZ_IMGD, 0, 2),
MUX(CLK_MOUT_CMU_VPU_BUS, "mout_cmu_vpu_bus" , mout_cmu_vpu_bus_p,
CLK_CON_MUX_MUX_CLKCMU_VPU_BUS, 0, 2),
};
static const struct samsung_div_clock top_div_clks[] __initconst = {
DIV(CLK_DOUT_CMU_ABOX_CPUABOX, "dout_cmu_cmu_abox_cpuabox" ,
"gout_cmu_abox_cpuabox" , CLK_CON_DIV_CLKCMU_ABOX_CPUABOX, 0, 3),
DIV(CLK_DOUT_CMU_APM_BUS, "dout_cmu_apm_bus" , "gout_cmu_apm_bus" ,
CLK_CON_DIV_CLKCMU_APM_BUS, 0, 3),
DIV(CLK_DOUT_CMU_BUS1_BUS, "dout_cmu_bus1_bus" , "gout_cmu_bus1_bus" ,
CLK_CON_DIV_CLKCMU_BUS1_BUS, 0, 4),
DIV(CLK_DOUT_CMU_BUSC_BUS, "dout_cmu_busc_bus" ,
"gout_cmu_clkcmu_busc_bus" , CLK_CON_DIV_CLKCMU_BUSC_BUS, 0, 4),
DIV(CLK_DOUT_CMU_BUSC_BUSPHSI2C, "dout_cmu_busc_busphsi2c" ,
"gout_cmu_busc_busphsi2c" , CLK_CON_DIV_CLKCMU_BUSC_BUSPHSI2C,
0, 4),
DIV(CLK_DOUT_CMU_CAM_BUS, "dout_cmu_cam_bus" , "gout_cmu_cam_bus" ,
CLK_CON_DIV_CLKCMU_CAM_BUS, 0, 4),
DIV(CLK_DOUT_CMU_CAM_TPU0, "dout_cmu_cam_tpu0" , "gout_cmu_cam_tpu0" ,
CLK_CON_DIV_CLKCMU_CAM_TPU0, 0, 4),
DIV(CLK_DOUT_CMU_CAM_TPU1, "dout_cmu_cam_tpu1" , "gout_cmu_cam_tpu1" ,
CLK_CON_DIV_CLKCMU_CAM_TPU1, 0, 4),
DIV(CLK_DOUT_CMU_CAM_VRA, "dout_cmu_cam_vra" , "gout_cmu_cam_vra" ,
CLK_CON_DIV_CLKCMU_CAM_VRA, 0, 4),
DIV(CLK_DOUT_CMU_CIS_CLK0, "dout_cmu_cis_clk0" , "gout_cmu_cis_clk0" ,
CLK_CON_DIV_CLKCMU_CIS_CLK0, 0, 5),
DIV(CLK_DOUT_CMU_CIS_CLK1, "dout_cmu_cis_clk1" , "gout_cmu_cis_clk1" ,
CLK_CON_DIV_CLKCMU_CIS_CLK1, 0, 5),
DIV(CLK_DOUT_CMU_CIS_CLK2, "dout_cmu_cis_clk2" , "gout_cmu_cis_clk2" ,
CLK_CON_DIV_CLKCMU_CIS_CLK2, 0, 5),
DIV(CLK_DOUT_CMU_CIS_CLK3, "dout_cmu_cis_clk3" , "gout_cmu_cis_clk3" ,
CLK_CON_DIV_CLKCMU_CIS_CLK3, 0, 5),
DIV(CLK_DOUT_CMU_CORE_BUS, "dout_cmu_core_bus" , "gout_cmu_core_bus" ,
CLK_CON_DIV_CLKCMU_CORE_BUS, 0, 4),
DIV(CLK_DOUT_CMU_CPUCL0_SWITCH, "dout_cmu_cpucl0_switch" ,
"gout_cmu_cpucl0_switch" , CLK_CON_DIV_CLKCMU_CPUCL0_SWITCH, 0, 3),
DIV(CLK_DOUT_CMU_CPUCL1_SWITCH, "dout_cmu_cpucl1_switch" ,
"gout_cmu_cpucl1_switch" , CLK_CON_DIV_CLKCMU_CPUCL1_SWITCH, 0, 3),
DIV(CLK_DOUT_CMU_DBG_BUS, "dout_cmu_dbg_bus" , "gout_cmu_dbg_bus" ,
CLK_CON_DIV_CLKCMU_DBG_BUS, 0, 4),
DIV(CLK_DOUT_CMU_DCAM_BUS, "dout_cmu_dcam_bus" , "gout_cmu_dcam_bus" ,
CLK_CON_DIV_CLKCMU_DCAM_BUS, 0, 4),
DIV(CLK_DOUT_CMU_DCAM_IMGD, "dout_cmu_dcam_imgd" , "gout_cmu_dcam_imgd" ,
CLK_CON_DIV_CLKCMU_DCAM_IMGD, 0, 4),
DIV(CLK_DOUT_CMU_DPU_BUS, "dout_cmu_dpu_bus" , "gout_cmu_dpu_bus" ,
CLK_CON_DIV_CLKCMU_DPU_BUS, 0, 4),
DIV(CLK_DOUT_CMU_DSP_BUS, "dout_cmu_dsp_bus" , "gout_cmu_dsp_bus" ,
CLK_CON_DIV_CLKCMU_DSP_BUS, 0, 4),
DIV(CLK_DOUT_CMU_FSYS0_BUS, "dout_cmu_fsys0_bus" , "gout_cmu_fsys0_bus" ,
CLK_CON_DIV_CLKCMU_FSYS0_BUS, 0, 4),
DIV(CLK_DOUT_CMU_FSYS0_DPGTC, "dout_cmu_fsys0_dpgtc" ,
"gout_cmu_fsys0_dpgtc" , CLK_CON_DIV_CLKCMU_FSYS0_DPGTC, 0, 3),
DIV(CLK_DOUT_CMU_FSYS0_MMC_EMBD, "dout_cmu_fsys0_mmc_embd" ,
"gout_cmu_fsys0_mmc_embd" , CLK_CON_DIV_CLKCMU_FSYS0_MMC_EMBD,
0, 9),
DIV(CLK_DOUT_CMU_FSYS0_UFS_EMBD, "dout_cmu_fsys0_ufs_embd" ,
"gout_cmu_fsys0_ufs_embd" , CLK_CON_DIV_CLKCMU_FSYS0_UFS_EMBD,
0, 3),
DIV(CLK_DOUT_CMU_FSYS0_USBDRD30, "dout_cmu_fsys0_usbdrd30" ,
"gout_cmu_fsys0_usbdrd30" , CLK_CON_DIV_CLKCMU_FSYS0_USBDRD30,
0, 4),
DIV(CLK_DOUT_CMU_FSYS1_BUS, "dout_cmu_fsys1_bus" , "gout_cmu_fsys1_bus" ,
CLK_CON_DIV_CLKCMU_FSYS1_BUS, 0, 4),
DIV(CLK_DOUT_CMU_FSYS1_MMC_CARD, "dout_cmu_fsys1_mmc_card" ,
"gout_cmu_fsys1_mmc_card" , CLK_CON_DIV_CLKCMU_FSYS1_MMC_CARD,
0, 9),
DIV(CLK_DOUT_CMU_FSYS1_UFS_CARD, "dout_cmu_fsys1_ufs_card" ,
"gout_cmu_fsys1_ufs_card" , CLK_CON_DIV_CLKCMU_FSYS1_UFS_CARD,
0, 4),
DIV(CLK_DOUT_CMU_G2D_G2D, "dout_cmu_g2d_g2d" , "gout_cmu_g2d_g2d" ,
CLK_CON_DIV_CLKCMU_G2D_G2D, 0, 4),
DIV(CLK_DOUT_CMU_G2D_JPEG, "dout_cmu_g2d_jpeg" , "gout_cmu_g2d_jpeg" ,
CLK_CON_DIV_CLKCMU_G2D_JPEG, 0, 4),
DIV(CLK_DOUT_CMU_G3D_SWITCH, "dout_cmu_g3d_switch" ,
"gout_cmu_g3d_switch" , CLK_CON_DIV_CLKCMU_G3D_SWITCH, 0, 3),
DIV(CLK_DOUT_CMU_HPM, "dout_cmu_hpm" , "gout_cmu_hpm" ,
CLK_CON_DIV_CLKCMU_HPM, 0, 2),
DIV(CLK_DOUT_CMU_IMEM_BUS, "dout_cmu_imem_bus" , "gout_cmu_imem_bus" ,
CLK_CON_DIV_CLKCMU_IMEM_BUS, 0, 4),
DIV(CLK_DOUT_CMU_ISPHQ_BUS, "dout_cmu_isphq_bus" , "gout_cmu_isphq_bus" ,
CLK_CON_DIV_CLKCMU_ISPHQ_BUS, 0, 4),
DIV(CLK_DOUT_CMU_ISPLP_BUS, "dout_cmu_isplp_bus" , "gout_cmu_isplp_bus" ,
CLK_CON_DIV_CLKCMU_ISPLP_BUS, 0, 4),
DIV(CLK_DOUT_CMU_IVA_BUS, "dout_cmu_iva_bus" , "gout_cmu_iva_bus" ,
CLK_CON_DIV_CLKCMU_IVA_BUS, 0, 4),
DIV(CLK_DOUT_CMU_MFC_BUS, "dout_cmu_mfc_bus" , "gout_cmu_mfc_bus" ,
CLK_CON_DIV_CLKCMU_MFC_BUS, 0, 4),
DIV(CLK_DOUT_CMU_MODEM_SHARED0, "dout_cmu_modem_shared0" ,
"gout_cmu_modem_shared0" , CLK_CON_DIV_CLKCMU_MODEM_SHARED0, 0, 3),
DIV(CLK_DOUT_CMU_MODEM_SHARED1, "dout_cmu_modem_shared1" ,
"gout_cmu_modem_shared1" , CLK_CON_DIV_CLKCMU_MODEM_SHARED1, 0, 3),
DIV(CLK_DOUT_CMU_PERIC0_BUS, "dout_cmu_peric0_bus" ,
"gout_cmu_peric0_bus" , CLK_CON_DIV_CLKCMU_PERIC0_BUS, 0, 4),
DIV(CLK_DOUT_CMU_PERIC0_UART_DBG, "dout_cmu_peric0_uart_dbg" ,
"gout_cmu_peric0_uart_dbg" , CLK_CON_DIV_CLKCMU_PERIC0_UART_DBG,
0, 4),
DIV(CLK_DOUT_CMU_PERIC0_USI00, "dout_cmu_peric0_usi00" ,
"gout_cmu_peric0_usi00" , CLK_CON_DIV_CLKCMU_PERIC0_USI00, 0, 4),
DIV(CLK_DOUT_CMU_PERIC0_USI01, "dout_cmu_peric0_usi01" ,
"gout_cmu_peric0_usi01" , CLK_CON_DIV_CLKCMU_PERIC0_USI01, 0, 4),
DIV(CLK_DOUT_CMU_PERIC0_USI02, "dout_cmu_peric0_usi02" ,
"gout_cmu_peric0_usi02" , CLK_CON_DIV_CLKCMU_PERIC0_USI02, 0, 4),
DIV(CLK_DOUT_CMU_PERIC0_USI03, "dout_cmu_peric0_usi03" ,
"gout_cmu_peric0_usi03" , CLK_CON_DIV_CLKCMU_PERIC0_USI03, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_BUS, "dout_cmu_peric1_bus" ,
"gout_cmu_peric1_bus" , CLK_CON_DIV_CLKCMU_PERIC1_BUS, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_SPEEDY2, "dout_cmu_peric1_speedy2" ,
"gout_cmu_peric1_speedy2" , CLK_CON_DIV_CLKCMU_PERIC1_SPEEDY2,
0, 4),
DIV(CLK_DOUT_CMU_PERIC1_SPI_CAM0, "dout_cmu_peric1_spi_cam0" ,
"gout_cmu_peric1_spi_cam0" , CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM0,
0, 4),
DIV(CLK_DOUT_CMU_PERIC1_SPI_CAM1, "dout_cmu_peric1_spi_cam1" ,
"gout_cmu_peric1_spi_cam1" , CLK_CON_DIV_CLKCMU_PERIC1_SPI_CAM1,
0, 4),
DIV(CLK_DOUT_CMU_PERIC1_UART_BT, "dout_cmu_peric1_uart_bt" ,
"gout_cmu_peric1_uart_bt" , CLK_CON_DIV_CLKCMU_PERIC1_UART_BT,
0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI04, "dout_cmu_peric1_usi04" ,
"gout_cmu_peric1_usi04" , CLK_CON_DIV_CLKCMU_PERIC1_USI04, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI05, "dout_cmu_peric1_usi05" ,
"gout_cmu_peric1_usi05" , CLK_CON_DIV_CLKCMU_PERIC1_USI05, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI06, "dout_cmu_peric1_usi06" ,
"gout_cmu_peric1_usi06" , CLK_CON_DIV_CLKCMU_PERIC1_USI06, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI07, "dout_cmu_peric1_usi07" ,
"gout_cmu_peric1_usi07" , CLK_CON_DIV_CLKCMU_PERIC1_USI07, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI08, "dout_cmu_peric1_usi08" ,
"gout_cmu_peric1_usi08" , CLK_CON_DIV_CLKCMU_PERIC1_USI08, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI09, "dout_cmu_peric1_usi09" ,
"gout_cmu_peric1_usi09" , CLK_CON_DIV_CLKCMU_PERIC1_USI09, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI10, "dout_cmu_peric1_usi10" ,
"gout_cmu_peric1_usi10" , CLK_CON_DIV_CLKCMU_PERIC1_USI10, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI11, "dout_cmu_peric1_usi11" ,
"gout_cmu_peric1_usi11" , CLK_CON_DIV_CLKCMU_PERIC1_USI11, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI12, "dout_cmu_peric1_usi12" ,
"gout_cmu_peric1_usi12" , CLK_CON_DIV_CLKCMU_PERIC1_USI12, 0, 4),
DIV(CLK_DOUT_CMU_PERIC1_USI13, "dout_cmu_peric1_usi13" ,
"gout_cmu_peric1_usi13" , CLK_CON_DIV_CLKCMU_PERIC1_USI13, 0, 4),
DIV(CLK_DOUT_CMU_PERIS_BUS, "dout_cmu_peris_bus" , "gout_cmu_peris_bus" ,
CLK_CON_DIV_CLKCMU_PERIS_BUS, 0, 4),
DIV(CLK_DOUT_CMU_SRDZ_BUS, "dout_cmu_srdz_bus" , "gout_cmu_srdz_bus" ,
CLK_CON_DIV_CLKCMU_SRDZ_BUS, 0, 4),
DIV(CLK_DOUT_CMU_SRDZ_IMGD, "dout_cmu_srdz_imgd" , "gout_cmu_srdz_imgd" ,
CLK_CON_DIV_CLKCMU_SRDZ_IMGD, 0, 4),
DIV(CLK_DOUT_CMU_VPU_BUS, "dout_cmu_vpu_bus" , "gout_cmu_vpu_bus" ,
CLK_CON_DIV_CLKCMU_VPU_BUS, 0, 4),
};
static const struct samsung_fixed_factor_clock top_fixed_factor_clks[] __initconst = {
FFACTOR(CLK_DOUT_CMU_SHARED0_DIV2, "dout_cmu_shared0_div2" ,
"mout_pll_shared0" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_SHARED0_DIV4, "dout_cmu_shared0_div4" ,
"mout_pll_shared0" , 1, 4, 0),
FFACTOR(CLK_DOUT_CMU_SHARED1_DIV2, "dout_cmu_shared1_div2" ,
"mout_pll_shared1" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_SHARED1_DIV4, "dout_cmu_shared1_div4" ,
"mout_pll_shared1" , 1, 4, 0),
FFACTOR(CLK_DOUT_CMU_SHARED2_DIV2, "dout_cmu_shared2_div2" ,
"mout_pll_shared2" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_SHARED3_DIV2, "dout_cmu_shared3_div2" ,
"mout_pll_shared3" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_SHARED4_DIV2, "dout_cmu_shared4_div2" ,
"mout_pll_shared4" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_FSYS1_PCIE, "dout_cmu_fsys1_pcie" ,
"gout_cmu_fsys1_pcie" , 1, 8, 0),
FFACTOR(CLK_DOUT_CMU_CP2AP_MIF_CLK_DIV2, "dout_cmu_cp2ap_mif_clk_div2" ,
"mout_cp2ap_mif_clk_user" , 1, 2, 0),
FFACTOR(CLK_DOUT_CMU_CMU_OTP, "dout_cmu_cmu_otp" , "oscclk" , 1, 8, 0),
};
static const struct samsung_gate_clock top_gate_clks[] __initconst = {
GATE(CLK_GOUT_CMU_DROOPDETECTOR, "gout_droopdetector" ,
"mout_cmu_droopdetector" , CLK_CON_GAT_CLKCMU_DROOPDETECTOR,
21, 0, 0),
GATE(CLK_GOUT_CMU_MIF_SWITCH, "gout_cmu_mif_switch" ,
"mout_cmu_mif_switch" , CLK_CON_GAT_CLKCMU_MIF_SWITCH, 21, 0, 0),
GATE(CLK_GOUT_CMU_ABOX_CPUABOX, "gout_cmu_abox_cpuabox" ,
"mout_cmu_abox_cpuabox" , CLK_CON_GAT_GATE_CLKCMU_ABOX_CPUABOX,
21, 0, 0),
GATE(CLK_GOUT_CMU_APM_BUS, "gout_cmu_apm_bus" , "mout_cmu_apm_bus" ,
CLK_CON_GAT_GATE_CLKCMU_APM_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_BUS1_BUS, "gout_cmu_bus1_bus" , "mout_cmu_bus1_bus" ,
CLK_CON_GAT_GATE_CLKCMU_BUS1_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_BUSC_BUS, "gout_cmu_busc_bus" , "mout_cmu_busc_bus" ,
CLK_CON_GAT_GATE_CLKCMU_BUSC_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_BUSC_BUSPHSI2C, "gout_cmu_busc_busphsi2c" ,
"mout_cmu_busc_busphsi2c" , CLK_CON_GAT_GATE_CLKCMU_BUSC_BUSPHSI2C,
21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_CAM_BUS, "gout_cmu_cam_bus" , "mout_cmu_cam_bus" ,
CLK_CON_GAT_GATE_CLKCMU_CAM_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_CAM_TPU0, "gout_cmu_cam_tpu0" , "mout_cmu_cam_tpu0" ,
CLK_CON_GAT_GATE_CLKCMU_CAM_TPU0, 21, 0, 0),
GATE(CLK_GOUT_CMU_CAM_TPU1, "gout_cmu_cam_tpu1" , "mout_cmu_cam_tpu1" ,
CLK_CON_GAT_GATE_CLKCMU_CAM_TPU1, 21, 0, 0),
GATE(CLK_GOUT_CMU_CAM_VRA, "gout_cmu_cam_vra" , "mout_cmu_cam_vra" ,
CLK_CON_GAT_GATE_CLKCMU_CAM_VRA, 21, 0, 0),
GATE(CLK_GOUT_CMU_CIS_CLK0, "gout_cmu_cis_clk0" , "mout_cmu_cis_clk0" ,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK0, 21, 0, 0),
GATE(CLK_GOUT_CMU_CIS_CLK1, "gout_cmu_cis_clk1" , "mout_cmu_cis_clk1" ,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK1, 21, 0, 0),
GATE(CLK_GOUT_CMU_CIS_CLK2, "gout_cmu_cis_clk2" , "mout_cmu_cis_clk2" ,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK2, 21, 0, 0),
GATE(CLK_GOUT_CMU_CIS_CLK3, "gout_cmu_cis_clk3" , "mout_cmu_cis_clk3" ,
CLK_CON_GAT_GATE_CLKCMU_CIS_CLK3, 21, 0, 0),
GATE(CLK_GOUT_CMU_CORE_BUS, "gout_cmu_core_bus" , "mout_core_bus" ,
CLK_CON_GAT_GATE_CLKCMU_CORE_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_CPUCL0_SWITCH, "gout_cmu_cpucl0_switch" ,
"mout_cmu_cpucl0_switch" , CLK_CON_GAT_GATE_CLKCMU_CPUCL0_SWITCH,
21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_CPUCL1_SWITCH, "gout_cmu_cpucl1_switch" ,
"mout_cmu_cpucl1_switch" , CLK_CON_GAT_GATE_CLKCMU_CPUCL1_SWITCH,
21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_DBG_BUS, "gout_cmu_dbg_bus" , "mout_cmu_dbg_bus" ,
CLK_CON_GAT_GATE_CLKCMU_DBG_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_DCAM_BUS, "gout_cmu_dcam_bus" , "mout_cmu_dcam_bus" ,
CLK_CON_GAT_GATE_CLKCMU_DCAM_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_DCAM_IMGD, "gout_cmu_dcam_imgd" ,
"mout_cmu_dcam_imgd" , CLK_CON_GAT_GATE_CLKCMU_DCAM_IMGD,
21, 0, 0),
GATE(CLK_GOUT_CMU_DPU_BUS, "gout_cmu_dpu_bus" , "mout_cmu_dpu_bus" ,
CLK_CON_GAT_GATE_CLKCMU_DPU_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_DSP_BUS, "gout_cmu_dsp_bus" , "mout_cmu_dsp_bus" ,
CLK_CON_GAT_GATE_CLKCMU_DSP_BUS, 21, CLK_IGNORE_UNUSED, 0),
GATE(CLK_GOUT_CMU_FSYS0_BUS, "gout_cmu_fsys0_bus" , "mout_fsys0_bus" ,
CLK_CON_GAT_GATE_CLKCMU_FSYS0_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS0_DPGTC, "gout_cmu_fsys0_dpgtc" ,
"mout_fsys0_dpgtc" , CLK_CON_GAT_GATE_CLKCMU_FSYS0_DPGTC,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS0_MMC_EMBD, "gout_cmu_fsys0_mmc_embd" ,
"mout_fsys0_mmc_embd" , CLK_CON_GAT_GATE_CLKCMU_FSYS0_MMC_EMBD,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS0_UFS_EMBD, "gout_cmu_fsys0_ufs_embd" ,
"mout_fsys0_ufs_embd" , CLK_CON_GAT_GATE_CLKCMU_FSYS0_UFS_EMBD,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS0_USBDRD30, "gout_cmu_fsys0_usbdrd30" ,
"mout_fsys0_usbdrd30" , CLK_CON_GAT_GATE_CLKCMU_FSYS0_USBDRD30,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS1_BUS, "gout_cmu_fsys1_bus" ,
"mout_cmu_fsys1_bus" , CLK_CON_GAT_GATE_CLKCMU_FSYS1_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS1_MMC_CARD, "gout_cmu_fsys1_mmc_card" ,
"mout_cmu_fsys1_mmc_card" , CLK_CON_GAT_GATE_CLKCMU_FSYS1_MMC_CARD,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS1_PCIE, "gout_cmu_fsys1_pcie" ,
"mout_cmu_fsys1_pcie" , CLK_CON_GAT_GATE_CLKCMU_FSYS1_PCIE,
21, 0, 0),
GATE(CLK_GOUT_CMU_FSYS1_UFS_CARD, "gout_cmu_fsys1_ufs_card" ,
"mout_cmu_fsys1_ufs_card" , CLK_CON_GAT_GATE_CLKCMU_FSYS1_UFS_CARD,
21, 0, 0),
GATE(CLK_GOUT_CMU_G2D_G2D, "gout_cmu_g2d_g2d" , "mout_cmu_g2d_g2d" ,
CLK_CON_GAT_GATE_CLKCMU_G2D_G2D, 21, 0, 0),
GATE(CLK_GOUT_CMU_G2D_JPEG, "gout_cmu_g2d_jpeg" , "mout_cmu_g2d_jpeg" ,
CLK_CON_GAT_GATE_CLKCMU_G2D_JPEG, 21, 0, 0),
GATE(CLK_GOUT_CMU_G3D_SWITCH, "gout_cmu_g3d_switch" ,
"fout_shared2_pll" , CLK_CON_GAT_GATE_CLKCMU_G3D_SWITCH, 21, 0, 0),
GATE(CLK_GOUT_CMU_HPM, "gout_cmu_hpm" , "mout_cmu_hpm" ,
CLK_CON_GAT_GATE_CLKCMU_HPM, 21, 0, 0),
GATE(CLK_GOUT_CMU_IMEM_BUS, "gout_cmu_imem_bus" , "mout_cmu_imem_bus" ,
CLK_CON_GAT_GATE_CLKCMU_IMEM_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_ISPHQ_BUS, "gout_cmu_isphq_bus" ,
"mout_cmu_isphq_bus" , CLK_CON_GAT_GATE_CLKCMU_ISPHQ_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_ISPLP_BUS, "gout_cmu_isplp_bus" ,
"mout_cmu_isplp_bus" , CLK_CON_GAT_GATE_CLKCMU_ISPLP_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_IVA_BUS, "gout_cmu_iva_bus" , "mout_cmu_iva_bus" ,
CLK_CON_GAT_GATE_CLKCMU_IVA_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_MFC_BUS, "gout_cmu_mfc_bus" , "mout_cmu_mfc_bus" ,
CLK_CON_GAT_GATE_CLKCMU_MFC_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_MODEM_SHARED0, "gout_cmu_modem_shared0" ,
"dout_cmu_shared0_div2" , CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED0,
21, 0, 0),
GATE(CLK_GOUT_CMU_MODEM_SHARED1, "gout_cmu_modem_shared1" ,
"fout_shared2_pll" , CLK_CON_GAT_GATE_CLKCMU_MODEM_SHARED1,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_BUS, "gout_cmu_peric0_bus" ,
"mout_cmu_peric0_bus" , CLK_CON_GAT_GATE_CLKCMU_PERIC0_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_UART_DBG, "gout_cmu_peric0_uart_dbg" ,
"mout_cmu_peric0_uart_dbg" ,
CLK_CON_GAT_GATE_CLKCMU_PERIC0_UART_DBG, 21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_USI00, "gout_cmu_peric0_usi00" ,
"mout_cmu_peric0_usi00" , CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI00,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_USI01, "gout_cmu_peric0_usi01" ,
"mout_cmu_peric0_usi01" , CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI01,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_USI02, "gout_cmu_peric0_usi02" ,
"mout_cmu_peric0_usi02" , CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI02,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC0_USI03, "gout_cmu_peric0_usi03" ,
"mout_cmu_peric0_usi03" , CLK_CON_GAT_GATE_CLKCMU_PERIC0_USI03,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_BUS, "gout_cmu_peric1_bus" ,
"mout_cmu_peric1_bus" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_SPEEDY2, "gout_cmu_peric1_speedy2" ,
"mout_cmu_peric1_speedy2" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPEEDY2,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_SPI_CAM0, "gout_cmu_peric1_spi_cam0" ,
"mout_cmu_peric1_spi_cam0" ,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM0, 21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_SPI_CAM1, "gout_cmu_peric1_spi_cam1" ,
"mout_cmu_peric1_spi_cam1" ,
CLK_CON_GAT_GATE_CLKCMU_PERIC1_SPI_CAM1, 21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_UART_BT, "gout_cmu_peric1_uart_bt" ,
"mout_cmu_peric1_uart_bt" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_UART_BT,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI04, "gout_cmu_peric1_usi04" ,
"mout_cmu_peric1_usi04" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI04,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI05, "gout_cmu_peric1_usi05" ,
"mout_cmu_peric1_usi05" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI05,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI06, "gout_cmu_peric1_usi06" ,
"mout_cmu_peric1_usi06" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI06,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI07, "gout_cmu_peric1_usi07" ,
"mout_cmu_peric1_usi07" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI07,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI08, "gout_cmu_peric1_usi08" ,
"mout_cmu_peric1_usi08" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI08,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI09, "gout_cmu_peric1_usi09" ,
"mout_cmu_peric1_usi09" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI09,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI10, "gout_cmu_peric1_usi10" ,
"mout_cmu_peric1_usi10" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI10,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI11, "gout_cmu_peric1_usi11" ,
"mout_cmu_peric1_usi11" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI11,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI12, "gout_cmu_peric1_usi12" ,
"mout_cmu_peric1_usi12" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI12,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIC1_USI13, "gout_cmu_peric1_usi13" ,
"mout_cmu_peric1_usi13" , CLK_CON_GAT_GATE_CLKCMU_PERIC1_USI13,
21, 0, 0),
GATE(CLK_GOUT_CMU_PERIS_BUS, "gout_cmu_peris_bus" ,
"mout_cmu_peris_bus" , CLK_CON_GAT_GATE_CLKCMU_PERIS_BUS,
21, 0, 0),
GATE(CLK_GOUT_CMU_SRDZ_BUS, "gout_cmu_srdz_bus" , "mout_cmu_srdz_bus" ,
CLK_CON_GAT_GATE_CLKCMU_SRDZ_BUS, 21, 0, 0),
GATE(CLK_GOUT_CMU_SRDZ_IMGD, "gout_cmu_srdz_imgd" ,
"mout_cmu_srdz_imgd" , CLK_CON_GAT_GATE_CLKCMU_SRDZ_IMGD,
21, 0, 0),
GATE(CLK_GOUT_CMU_VPU_BUS, "gout_cmu_vpu_bus" , "mout_cmu_vpu_bus" ,
CLK_CON_GAT_GATE_CLKCMU_VPU_BUS, 21, 0, 0),
};
static const struct samsung_cmu_info top_cmu_info __initconst = {
.pll_clks = top_pll_clks,
.nr_pll_clks = ARRAY_SIZE(top_pll_clks),
.mux_clks = top_mux_clks,
.nr_mux_clks = ARRAY_SIZE(top_mux_clks),
.div_clks = top_div_clks,
.nr_div_clks = ARRAY_SIZE(top_div_clks),
.fixed_factor_clks = top_fixed_factor_clks,
.nr_fixed_factor_clks = ARRAY_SIZE(top_fixed_factor_clks),
.gate_clks = top_gate_clks,
.nr_gate_clks = ARRAY_SIZE(top_gate_clks),
.nr_clk_ids = CLKS_NR_TOP,
.clk_regs = top_clk_regs,
.nr_clk_regs = ARRAY_SIZE(top_clk_regs),
};
static void __init exynos8895_cmu_top_init(struct device_node *np)
{
exynos_arm64_register_cmu(NULL, np, &top_cmu_info);
}
/* Register CMU_TOP early, as it's a dependency for other early domains */
CLK_OF_DECLARE(exynos8895_cmu_top, "samsung,exynos8895-cmu-top" ,
exynos8895_cmu_top_init);
/* ---- CMU_PERIS ----------------------------------------------------------- */
/* Register Offset definitions for CMU_PERIS (0x10010000) */
#define PLL_CON0_MUX_CLKCMU_PERIS_BUS_USER 0x0100
#define PLL_CON2_MUX_CLKCMU_PERIS_BUS_USER 0x0108
#define CLK_CON_MUX_MUX_CLK_PERIS_GIC 0x1000
#define CLK_CON_GAT_CLK_BLK_PERIS_UID_PERIS_CMU_PERIS_IPCLKPORT_PCLK 0x2000
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_AD_AXI_P_PERIS_IPCLKPORT_ACLKM 0x2010
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_AD_AXI_P_PERIS_IPCLKPORT_ACLKS 0x2014
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_AXI2APB_PERISP0_IPCLKPORT_ACLK 0x2018
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_AXI2APB_PERISP1_IPCLKPORT_ACLK 0x201c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_BUSIF_TMU_IPCLKPORT_PCLK 0x2020
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_GIC_IPCLKPORT_CLK 0x2024
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_LHM_AXI_P_PERIS_IPCLKPORT_I_CLK 0x2028
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_MCT_IPCLKPORT_PCLK 0x202c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_PCLK 0x2030
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_PCLK 0x2034
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_PMU_PERIS_IPCLKPORT_PCLK 0x2038
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_BUSP_IPCLKPORT_CLK 0x203c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_GIC_IPCLKPORT_CLK 0x2040
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_SYSREG_PERIS_IPCLKPORT_PCLK 0x2044
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC00_IPCLKPORT_PCLK 0x2048
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC01_IPCLKPORT_PCLK 0x204c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC02_IPCLKPORT_PCLK 0x2050
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC03_IPCLKPORT_PCLK 0x2054
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC04_IPCLKPORT_PCLK 0x2058
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC05_IPCLKPORT_PCLK 0x205c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC06_IPCLKPORT_PCLK 0x2060
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC07_IPCLKPORT_PCLK 0x2064
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC08_IPCLKPORT_PCLK 0x2068
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC09_IPCLKPORT_PCLK 0x206c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC10_IPCLKPORT_PCLK 0x2070
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC11_IPCLKPORT_PCLK 0x2074
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC12_IPCLKPORT_PCLK 0x2078
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC13_IPCLKPORT_PCLK 0x207c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC14_IPCLKPORT_PCLK 0x2080
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC15_IPCLKPORT_PCLK 0x2084
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_WDT_CLUSTER0_IPCLKPORT_PCLK 0x2088
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_WDT_CLUSTER1_IPCLKPORT_PCLK 0x208c
#define CLK_CON_GAT_GOUT_BLK_PERIS_UID_XIU_P_PERIS_IPCLKPORT_ACLK 0x2090
static const unsigned long peris_clk_regs[] __initconst = {
PLL_CON0_MUX_CLKCMU_PERIS_BUS_USER,
PLL_CON2_MUX_CLKCMU_PERIS_BUS_USER,
CLK_CON_MUX_MUX_CLK_PERIS_GIC,
CLK_CON_GAT_CLK_BLK_PERIS_UID_PERIS_CMU_PERIS_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_AD_AXI_P_PERIS_IPCLKPORT_ACLKM,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_AD_AXI_P_PERIS_IPCLKPORT_ACLKS,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_AXI2APB_PERISP0_IPCLKPORT_ACLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_AXI2APB_PERISP1_IPCLKPORT_ACLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_BUSIF_TMU_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_GIC_IPCLKPORT_CLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_LHM_AXI_P_PERIS_IPCLKPORT_I_CLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_MCT_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_OTP_CON_BIRA_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_OTP_CON_TOP_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_PMU_PERIS_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_BUSP_IPCLKPORT_CLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_RSTNSYNC_CLK_PERIS_GIC_IPCLKPORT_CLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_SYSREG_PERIS_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC00_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC01_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC02_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC03_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC04_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC05_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC06_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC07_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC08_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC09_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC10_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC11_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC12_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC13_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC14_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_TZPC15_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_WDT_CLUSTER0_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_WDT_CLUSTER1_IPCLKPORT_PCLK,
CLK_CON_GAT_GOUT_BLK_PERIS_UID_XIU_P_PERIS_IPCLKPORT_ACLK,
};
/* List of parent clocks for Muxes in CMU_PERIS */
PNAME(mout_peris_bus_user_p) = { "oscclk" , "dout_cmu_peris_bus" };
PNAME(mout_peris_gic_p) = { "oscclk" , "mout_peris_bus_user" };
static const struct samsung_mux_clock peris_mux_clks[] __initconst = {
MUX(CLK_MOUT_PERIS_BUS_USER, "mout_peris_bus_user" ,
mout_peris_bus_user_p, PLL_CON0_MUX_CLKCMU_PERIS_BUS_USER, 4, 1),
MUX(CLK_MOUT_PERIS_GIC, "mout_peris_gic" ,
mout_peris_gic_p, CLK_CON_MUX_MUX_CLK_PERIS_GIC, 0, 5),
};
static const struct samsung_gate_clock peris_gate_clks[] __initconst = {
GATE(CLK_GOUT_PERIS_CMU_PERIS_PCLK, "gout_peris_cmu_peris_pclk" ,
"mout_peris_bus_user" ,
--> --------------------
--> maximum size reached
--> --------------------
Messung V0.5 C=95 H=94 G=94
¤ Dauer der Verarbeitung: 0.6 Sekunden
(vorverarbeitet)
¤
*© Formatika GbR, Deutschland