This patch adds clock description for MUX, DIV, GATE and PLL
clocks available in TOPC, TOP0, TOP1, BUS0, BUS1, FSYS0, FSYS1,
CCORE, PERIC0, PERIC1, PERIS, DISP, G3D, MSCL and MFC blocks.

Adds Gate clocks for UART, HSI2C, SPI, SPDIF, TMU, PWM, WDT,
USB, MMC, RTC and DISP block clocks.

This patch adds PLL tables for the following PLLs
1450x PLL which drives A57, DPHY block
1451x PLL which drives BUS0 block
1452x PLL which drives BUS1, MFC, G3D, HSIC blocks
1460x PLL which drives AUD, DISP blocks on Exynos7 SoC.

Also adds the documentation for device tree bindings

Signed-off-by: Naveen Krishna Chatradhi <ch.nav...@samsung.com>
Cc: Tomasz Figa <t.f...@samsung.com>
Cc: Mike Turquette <mturque...@linaro.org>
Cc: Thomas Abraham <thomas...@samsung.com>
---
Currently about 13 CMU blocks have been described in clk-exynos7.c
If required, I can split it and group them to different files.

 .../devicetree/bindings/clock/exynos7-clock.txt    |  209 +++
 drivers/clk/samsung/Makefile                       |    1 +
 drivers/clk/samsung/clk-exynos7.c                  | 1929 ++++++++++++++++++++
 include/dt-bindings/clock/exynos7-clk.h            |  236 +++
 4 files changed, 2375 insertions(+)
 create mode 100644 Documentation/devicetree/bindings/clock/exynos7-clock.txt
 create mode 100644 drivers/clk/samsung/clk-exynos7.c
 create mode 100644 include/dt-bindings/clock/exynos7-clk.h

diff --git a/Documentation/devicetree/bindings/clock/exynos7-clock.txt 
b/Documentation/devicetree/bindings/clock/exynos7-clock.txt
new file mode 100644
index 0000000..c361525
--- /dev/null
+++ b/Documentation/devicetree/bindings/clock/exynos7-clock.txt
@@ -0,0 +1,209 @@
+* Samsung Exynos7 Clock Controller
+
+Exynos7 clock controller has 25 blocks which are instantiated
+independently from the device-tree. These clock controllers
+generate and supply clocks to various hardware blocks within
+the SoC.
+
+Each clock is assigned an identifier and client nodes can use
+this identifier to specify the clock which they consume. All
+available clocks are defined as preprocessor macros in
+dt-bindings/clock/exynos7-clk.h header and can be used in
+device tree sources.
+
+External clocks:
+
+There are several clocks that are generated outside the SoC. It
+is expected that they are defined using standard clock bindings
+with following clock-output-names:
+
+ - "fin_pll" - PLL input clock from XXTI
+
+Phy clocks:
+
+There are several clocks which are generated by specific PHYs.
+These clocks are fed into the clock controller and then routed to
+the hardware blocks. These clocks are defined as fixed clocks in the
+driver with following names:
+
+Required Properties for Clock Controller:
+
+ - compatible: should be one of the following.
+       1) "samsung,exynos7-clock-topc"
+       2) "samsung,exynos7-clock-top0"
+       3) "samsung,exynos7-clock-top1"
+       4) "samsung,exynos7-clock-atlas"
+       5) "samsung,exynos7-clock-ccore"
+       6) "samsung,exynos7-clock-imem"
+       7) "samsung,exynos7-clock-g3d"
+       8) "samsung,exynos7-clock-mif0"
+       9) "samsung,exynos7-clock-mif1"
+       10) "samsung,exynos7-clock-mif2"
+       11) "samsung,exynos7-clock-mif3"
+       12) "samsung,exynos7-clock-peric0"
+       13) "samsung,exynos7-clock-peric1"
+       14) "samsung,exynos7-clock-peris"
+       15) "samsung,exynos7-clock-bus0"
+       16) "samsung,exynos7-clock-bus1"
+       17) "samsung,exynos7-clock-fsys0"
+       18) "samsung,exynos7-clock-fsys1"
+       19) "samsung,exynos7-clock-disp"
+       20) "samsung,exynos7-clock-aud"
+       21) "samsung,exynos7-clock-mscl"
+       22) "samsung,exynos7-clock-mfc"
+
+ - reg: physical base address of the controller and the length of
+       memory mapped region.
+
+ - #clock-cells: should be 1.
+
+ - clocks: list of clock identifiers which are fed as the input to
+       the given clock controller. Please refer the next section to find
+       the input clocks for a given controller.
+
+ - clock-names: list of names of clocks which are fed as the input
+       to the given clock controller.
+
+Input clocks for topc clock controller:
+       - fin_pll
+       - fout_aud_pll
+       - fout_bus0_pl
+       - fout_bus1_pl
+       - fout_cc_pll
+       - fout_mfc_pll
+       - dout_sclk_cmu_apbif
+
+Input clocks for top0 clock controller:
+       - fin_pll
+       - fout_mif01_pll
+       - sclk_bus0_pll_mif
+       - sclk_bus0_pll_a
+       - sclk_bus1_pll_a
+       - sclk_cc_pll_a
+       - sclk_mfc_pll_a
+       - sclk_aud_pll
+       - sclk_cmu_apbif
+       - ioclk_audiocdclk0
+       - ioclk_audiocdclk1
+       - ioclk_spdif_extclk
+
+Input clocks for top1 clock controller:
+       - fin_pll
+       - fout_mif23_pll
+       - sclk_bus0_pll_mif
+       - sclk_bus0_pll_b
+       - sclk_bus1_pll_b
+       - sclk_cc_pll_b
+       - sclk_mfc_pll_b
+       - sclk_cmu_apbif
+
+Input clocks for ccore clock controller:
+       - fin_pll
+       - aclk_ccore_532
+       - aclk_ccore_133
+
+Input clocks for peric0 clock controller:
+       - fin_pll
+       - aclk_peric0_66
+       - sclk_uart0
+
+Input clocks for peric1 clock controller:
+       - fin_pll
+       - aclk_peric01_66
+       - sclk_uart1
+       - sclk_uart2
+       - sclk_uart3
+       - sclk_spi0
+       - sclk_spi1
+       - sclk_spi2
+       - sclk_spi3
+       - sclk_spi4
+       - sclk_i2s1
+       - sclk_pcm1
+       - sclk_spdif
+       - ioclk_i2s1_bclk
+       - ioclk_spi0_clk
+       - ioclk_spi1_clk
+       - ioclk_spi2_clk
+       - ioclk_spi3_clk
+       - ioclk_spi4_clk
+
+Input clocks for peris clock controller:
+       - fin_pll
+       - aclk_peris_66
+       - rtclk (blk_rtc)
+
+Input clocks for bus0 clock controller:
+       - fin_pll
+       - aclk_bus0_532
+
+Input clocks for bus1 clock controller:
+       - fin_pll
+       - aclk_bus1_200
+       - aclk_bus1_532
+
+Input clocks for fsys0 clock controller:
+       - fin_pll
+       - fout_hsic_pll
+       - aclk_fsys0_200
+       - sclk_phy_fsys0_26m
+       - aclk_usbdrd200
+       - sclk_mmc2
+       - sclk_ufsunipro11
+       - sclk_phy_fsys0
+       - phyclk_usbdrd300_udrd30_phyclock
+       - phyclk_usbdrd300_udrd30_pipe_pclk
+       - phyclk_usbhost20_phy_freeclk_hsic1
+       - phyclk_usbhost20_phy_phyclk_hsic1
+       - phyclk_ufs_tx0_symbol
+       - phyclk_ufs_rx0_symbol
+       - phyclk_lli_tx0_symbol
+       - phyclk_lli_rx0_symbol
+       - phyclk_pcie_tx0
+       - phyclk_pcie_rx0
+
+Input clocks for fsys1 clock controller:
+       - fin_pll
+       - aclk_fsys1_200
+       - sclk_phy_fsys1_26m
+       - sclk_mmc0
+       - sclk_mmc1
+       - sclk_ufsunipro20
+       - sclk_phy_fsys1
+       - sclk_txl400_wifi1
+       - phyclk_ufs20_tx0_symbol
+       - phyclk_ufs20_rx0_symbol
+       - phyclk_ufs20_rx1_symbol
+       - phyclk_pcie_wifi1_tx0
+       - phyclk_pcie_wifi1_rx0
+
+Input clocks for disp clock controller:
+       - fin_pll
+       - fout_disp_pll
+       - fout_dphy_pll
+       - aclk_disp_400
+       - sclk_dsd
+       - sclk_hdmi_spdif
+       - sclk_decon_int_eclk
+       - sclk_decon_ext_eclk
+       - sclk_decon_vclk
+       - phyclk_mipidphy0_rxclkesc0
+       - phyclk_mipidphy0_bitclkdiv8
+       - phyclk_mipidphy1_rxclkesc0
+       - phyclk_mipidphy1_bitclkdiv8
+       - sclk_rgb_vclk_dsim0
+       - sclk_rgb_vclk_dsim1
+       - sclk_decon_ext_vclk
+       - phyclk_dpphy_ch3_txd_clk
+       - phyclk_dpphy_ch2_txd_clk
+       - phyclk_dpphy_ch1_txd_clk
+       - phyclk_dpphy_ch0_txd_clk
+       - phyclk_hdmi_phy_tmds_clko
+       - phyclk_hdmi_phy_pixel_clko
+
+Input clocks for audio clock controller:
+       - fin_pll
+       - fout_aud_pll
+       - ioclk_audiocdclk0
+       - ioclk_slimbus_clk
+       - ioclk_i2s_bclk
diff --git a/drivers/clk/samsung/Makefile b/drivers/clk/samsung/Makefile
index 6fb4bc6..5da0ba9 100644
--- a/drivers/clk/samsung/Makefile
+++ b/drivers/clk/samsung/Makefile
@@ -18,3 +18,4 @@ obj-$(CONFIG_S3C2412_COMMON_CLK)+= clk-s3c2412.o
 obj-$(CONFIG_S3C2443_COMMON_CLK)+= clk-s3c2443.o
 obj-$(CONFIG_ARCH_S3C64XX)     += clk-s3c64xx.o
 obj-$(CONFIG_ARCH_S5PV210)     += clk-s5pv210.o clk-s5pv210-audss.o
+obj-$(CONFIG_ARCH_EXYNOS7)     += clk-exynos7.o
diff --git a/drivers/clk/samsung/clk-exynos7.c 
b/drivers/clk/samsung/clk-exynos7.c
new file mode 100644
index 0000000..b62251f
--- /dev/null
+++ b/drivers/clk/samsung/clk-exynos7.c
@@ -0,0 +1,1929 @@
+/*
+ * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Author: Naveen Krishna Chatradhi <ch.nav...@samsung.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * Common Clock Framework support for TOP0, TOP1 and TOPC,
+ * CCORE, PERIC0, PERIC1 and PERIS, BUS0, BUS1, FSYS0, FSYS1,
+ * Multi media subsystems such as G3D, AUD, DISP, MSCL and
+ * MFC blocks of the Exynos7 clock controller.
+ */
+
+#include <linux/clk.h>
+#include <linux/clkdev.h>
+#include <linux/clk-provider.h>
+#include <linux/of.h>
+
+#include "clk.h"
+#include <dt-bindings/clock/exynos7-clk.h>
+
+/* PMS values for PLL 1451x */
+static const struct samsung_pll_rate_table pll1451x_24mhz_tbl[] = {
+       /* rate, m, p, s */
+       PLL_35XX_RATE(660000000, 165, 3, 1),
+       PLL_35XX_RATE(1800000000, 150, 2, 0),
+       PLL_35XX_RATE(1700000000, 425, 6, 0),
+       PLL_35XX_RATE(1600000000, 200, 3, 0),
+       PLL_35XX_RATE(1500000000, 125, 2, 0),
+       PLL_35XX_RATE(1400000000, 175, 3, 0),
+       PLL_35XX_RATE(1380000000, 115, 2, 0),
+       PLL_35XX_RATE(1300000000, 325, 6, 0),
+       PLL_35XX_RATE(1200000000, 100, 2, 0),
+       PLL_35XX_RATE(1180000000, 295, 6, 0),
+       PLL_35XX_RATE(1104000000, 276, 6, 0),
+       PLL_35XX_RATE(1100000000, 275, 6, 0),
+       PLL_35XX_RATE(1064000000, 133, 3, 0),
+       PLL_35XX_RATE(1000000000, 125, 3, 0),
+       PLL_35XX_RATE(932000000, 233, 6, 0),
+       PLL_35XX_RATE(900000000, 150, 2, 1),
+       PLL_35XX_RATE(825000000, 275, 4, 1),
+       PLL_35XX_RATE(800000000, 200, 3, 1),
+       PLL_35XX_RATE(750000000, 125, 2, 1),
+       PLL_35XX_RATE(700000000, 175, 3, 1),
+       PLL_35XX_RATE(690000000, 115, 2, 1),
+       PLL_35XX_RATE(668000000, 167, 3, 1),
+       PLL_35XX_RATE(600000000, 100, 2, 1),
+       PLL_35XX_RATE(590000000, 295, 6, 1),
+       PLL_35XX_RATE(552000000, 92,  2, 1),
+       PLL_35XX_RATE(532000000, 133, 3, 1),
+       PLL_35XX_RATE(500000000, 125, 3, 1),
+       PLL_35XX_RATE(492000000, 82,  2, 1),
+       PLL_35XX_RATE(468000000, 78,  2, 1),
+       PLL_35XX_RATE(450000000, 150, 2, 2),
+       PLL_35XX_RATE(432000000, 144, 2, 2),
+       PLL_35XX_RATE(420000000, 140, 2, 2),
+       PLL_35XX_RATE(400000000, 200, 3, 2),
+       PLL_35XX_RATE(368000000, 184, 3, 2),
+       PLL_35XX_RATE(350000000, 175, 3, 2),
+       PLL_35XX_RATE(334000000, 167, 3, 2),
+       PLL_35XX_RATE(300000000, 100, 2, 2),
+       PLL_35XX_RATE(276000000, 92,  2, 2),
+       PLL_35XX_RATE(266000000, 133, 3, 2),
+       PLL_35XX_RATE(233000000, 233, 6, 2),
+       PLL_35XX_RATE(200000000, 200, 3, 3),
+       PLL_35XX_RATE(177000000, 118, 2, 3),
+       PLL_35XX_RATE(167000000, 167, 3, 3),
+       PLL_35XX_RATE(150000000, 100, 2, 3),
+       PLL_35XX_RATE(133000000, 133, 3, 3),
+       PLL_35XX_RATE(100000000, 200, 3, 4),
+       PLL_35XX_RATE(84000000, 112, 2, 4),
+       PLL_35XX_RATE(75000000, 100, 2, 4),
+       PLL_35XX_RATE(66000000, 88, 2, 4),
+};
+
+/* PMS values for PLL 1452x */
+static const struct samsung_pll_rate_table pll1452x_24mhz_tbl[] = {
+       /* rate, m, p, s */
+       PLL_35XX_RATE(260000000, 130, 6, 1),
+       PLL_35XX_RATE(480000000, 240, 6, 1),
+       PLL_35XX_RATE(652000000, 163, 6, 0),
+       PLL_35XX_RATE(1000000000, 250, 6, 0),
+       PLL_35XX_RATE(932000000, 233, 6, 0),
+       PLL_35XX_RATE(900000000, 225, 6, 0),
+       PLL_35XX_RATE(800000000, 200, 6, 0),
+       PLL_35XX_RATE(752000000, 188, 6, 0),
+       PLL_35XX_RATE(700000000, 175, 6, 0),
+       PLL_35XX_RATE(692000000, 173, 6, 0),
+       PLL_35XX_RATE(668000000, 167, 6, 0),
+       PLL_35XX_RATE(600000000, 150, 6, 0),
+       PLL_35XX_RATE(592000000, 148, 6, 0),
+       PLL_35XX_RATE(552000000, 138, 6, 0),
+       PLL_35XX_RATE(532000000, 133, 6, 0),
+       PLL_35XX_RATE(500000000, 250, 6, 1),
+       PLL_35XX_RATE(492000000, 246, 6, 1),
+       PLL_35XX_RATE(468000000, 234, 6, 1),
+       PLL_35XX_RATE(450000000, 225, 6, 1),
+       PLL_35XX_RATE(432000000, 216, 6, 1),
+       PLL_35XX_RATE(420000000, 210, 6, 1),
+       PLL_35XX_RATE(400000000, 200, 6, 1),
+       PLL_35XX_RATE(368000000, 184, 6, 1),
+       PLL_35XX_RATE(350000000, 175, 6, 1),
+       PLL_35XX_RATE(334000000, 167, 6, 1),
+       PLL_35XX_RATE(300000000, 150, 6, 1),
+       PLL_35XX_RATE(276000000, 138, 6, 1),
+       PLL_35XX_RATE(266000000, 133, 6, 1),
+       PLL_35XX_RATE(233000000, 233, 6, 2),
+       PLL_35XX_RATE(200000000, 200, 6, 2),
+       PLL_35XX_RATE(177000000, 177, 6, 2),
+       PLL_35XX_RATE(167000000, 167, 6, 2),
+       PLL_35XX_RATE(150000000, 150, 6, 2),
+       PLL_35XX_RATE(133000000, 133, 6, 2),
+       PLL_35XX_RATE(100000000, 200, 6, 3),
+       PLL_35XX_RATE(84000000, 168, 6, 3),
+       PLL_35XX_RATE(75000000, 150, 6, 3),
+       PLL_35XX_RATE(66000000, 132, 6, 3),
+};
+
+/* PMS values for PLL 1460x */
+static const struct samsung_pll_rate_table pll1460x_24mhz_tbl[] = {
+       /* rate, m, p, s, k */
+       PLL_36XX_RATE(96000000, 32, 1, 3, 0),
+       PLL_36XX_RATE(491520000, 20, 1, 0, 31457),
+       PLL_36XX_RATE(396000000, 33, 1, 1, 0),
+       PLL_36XX_RATE(393216000, 33, 1, 1, -15204),
+       PLL_36XX_RATE(384000000, 32, 1, 1, 0),
+       PLL_36XX_RATE(368640000, 31, 1, 1, -18350),
+       PLL_36XX_RATE(361507000, 30, 1, 1, 8231),
+       PLL_36XX_RATE(338668000, 28, 1, 1, 14571),
+       PLL_36XX_RATE(294912000, 25, 1, 1, -27787),
+       PLL_36XX_RATE(288000000, 24, 1, 1, 0),
+       PLL_36XX_RATE(252000000, 21, 1, 1, 0),
+       PLL_36XX_RATE(800000000, 33, 1, 0, 21845),
+       PLL_36XX_RATE(750000000, 31, 1, 0, 16384),
+       PLL_36XX_RATE(700000000, 29, 1, 0, 10923),
+       PLL_36XX_RATE(690000000, 29, 1, 0, -16384),
+       PLL_36XX_RATE(668000000, 28, 1, 0, -10923),
+       PLL_36XX_RATE(600000000, 25, 1, 0, 0),
+       PLL_36XX_RATE(590000000, 25, 1, 0, -27307),
+       PLL_36XX_RATE(552000000, 23, 1, 0, 0),
+       PLL_36XX_RATE(532000000, 22, 1, 0, 10923),
+       PLL_36XX_RATE(500000000, 21, 1, 0, -10923),
+       PLL_36XX_RATE(492000000, 21, 1, 0, -32768),
+       PLL_36XX_RATE(491520000, 20, 1, 0, 31457),
+       PLL_36XX_RATE(468000000, 20, 1, 0, -32768),
+       PLL_36XX_RATE(450000000, 19, 1, 0, -16384),
+       PLL_36XX_RATE(432000000, 18, 1, 0, 0),
+       PLL_36XX_RATE(420000000, 18, 1, 0, -32768),
+       PLL_36XX_RATE(400000000, 33, 1, 1, 21845),
+       PLL_36XX_RATE(396000000, 33, 1, 1, 0),
+       PLL_36XX_RATE(393216000, 33, 1, 1, -15204),
+       PLL_36XX_RATE(384000000, 32, 1, 1, 0),
+       PLL_36XX_RATE(368640000, 31, 1, 1, -18350),
+       PLL_36XX_RATE(368000000, 31, 1, 1, -21845),
+       PLL_36XX_RATE(361507000, 30, 1, 1, 8231),
+       PLL_36XX_RATE(350000000, 29, 1, 1, 10923),
+       PLL_36XX_RATE(338638000, 28, 1, 1, 14571),
+       PLL_36XX_RATE(334000000, 28, 1, 1, -10923),
+       PLL_36XX_RATE(300000000, 25, 1, 1, 0),
+       PLL_36XX_RATE(294912000, 25, 1, 1, -27787),
+       PLL_36XX_RATE(288000000, 24, 1, 1, 0),
+       PLL_36XX_RATE(276000000, 23, 1, 1, 0),
+       PLL_36XX_RATE(266000000, 22, 1, 1, 10923),
+       PLL_36XX_RATE(252000000, 21, 1, 1, 0),
+       PLL_36XX_RATE(233000000, 19, 1, 1, 27307),
+       PLL_36XX_RATE(200000000, 33, 1, 2, 21845),
+       PLL_36XX_RATE(177000000, 30, 1, 2, -32768),
+       PLL_36XX_RATE(167000000, 28, 1, 2, -10923),
+       PLL_36XX_RATE(150000000, 25, 1, 2, 0),
+       PLL_36XX_RATE(133000000, 22, 1, 2, 10923),
+       PLL_36XX_RATE(100000000, 33, 1,  3, 21845),
+       PLL_36XX_RATE(84000000, 28, 1, 3, 0),
+       PLL_36XX_RATE(75000000, 25, 1, 3, 0),
+       PLL_36XX_RATE(66000000, 22, 1, 3, 0),
+};
+
+/* Register Offset definitions for CMU_TOPC (0x10570000) */
+#define        CC_PLL_LOCK                     0x0000
+#define        BUS0_PLL_LOCK                   0x0004
+#define        BUS1_DPLL_LOCK                  0x0008
+#define        MFC_PLL_LOCK                    0x000C
+#define        AUD_PLL_LOCK                    0x0010
+#define        MIF_PLL_LOCK                    0x0014
+#define        CC_PLL_CON0                     0x0100
+#define        CC_PLL_CON1                     0x0104
+#define        BUS0_PLL_CON0                   0x0110
+#define        BUS0_PLL_CON1                   0x0114
+#define        BUS1_DPLL_CON0                  0x0120
+#define        BUS1_DPLL_CON1                  0x0124
+#define        MFC_PLL_CON0                    0x0130
+#define        MFC_PPL_CON1                    0x0134
+#define        AUD_PLL_CON0                    0x0140
+#define        AUD_PLL_CON1                    0x0144
+#define        AUD_PLL_CON2                    0x0148
+#define        MIF_PLL_CON0                    0x0150
+#define        MIF_PLL_CON1                    0x0154
+#define        MIF_PLL_CON2                    0x0158
+#define        MUX_SEL_TOPC0                   0x0200
+#define        MUX_SEL_TOPC1                   0x0204
+#define        MUX_SEL_TOPC2                   0x0208
+#define        MUX_SEL_TOPC3                   0x020C
+#define        MUX_SEL_TOPC4                   0x0210
+#define        MUX_SEL_TOPC5                   0x0214
+#define        DIV_TOPC0                       0x0600
+#define        DIV_TOPC1                       0x0604
+#define        DIV_TOPC2                       0x0608
+#define        DIV_TOPC3                       0x060C
+#define        ENABLE_ACLK_TOPC0               0x0800
+#define        ENABLE_ACLK_TOPC1               0x0804
+#define        ENABLE_ACLK_TOPC2               0x0808
+#define        ENABLE_SCLK_TOPC0               0x0A00
+#define        ENABLE_SCLK_TOPC1               0x0A04
+
+static struct samsung_fixed_factor_clock topc_fixed_factor_clks[] __initdata = 
{
+       FFACTOR(0, "ffac_topc_bus0_pll_div2",
+                       "mout_bus0_pll_ctrl", 1, 2, 0),
+       FFACTOR(0, "ffac_topc_bus0_pll_div4",
+                       "ffac_topc_bus0_pll_div2", 1, 2, 0),
+       FFACTOR(0, "ffac_topc_bus1_pll_div2",
+                       "mout_bus1_pll_ctrl", 1, 2, 0),
+       FFACTOR(0, "ffac_topc_cc_pll_div2",
+                       "mout_cc_pll_ctrl", 1, 2, 0),
+       FFACTOR(0, "ffac_topc_mfc_pll_div2",
+                       "mout_mfc_pll_ctrl", 1, 2, 0),
+};
+
+/* List of parent clocks for Muxes in CMU_TOPC */
+PNAME(mout_aud_pll_ctrl_p)     = { "fin_pll", "fout_aud_pll" };
+PNAME(mout_bus0_pll_ctrl_p)    = { "fin_pll", "fout_bus0_pll" };
+PNAME(mout_bus1_pll_ctrl_p)    = { "fin_pll", "fout_bus1_pll" };
+PNAME(mout_cc_pll_ctrl_p)      = { "fin_pll", "fout_cc_pll" };
+PNAME(mout_mfc_pll_ctrl_p)     = { "fin_pll", "fout_mfc_pll" };
+
+PNAME(mout_topc_group1)        = { "mout_bus0_pll_ctrl", 
"ffac_topc_bus0_pll_div2",
+        "mout_bus1_pll_ctrl", "mout_cc_pll" };
+PNAME(mout_topc_group2)        = { "mout_sclk_bus0_pll_cmuc",
+       "mout_sclk_bus1_pll_cmuc", "mout_sclk_cc_pll_cmuc",
+       "mout_sclk_mfc_pll_cmuc" };
+
+PNAME(mout_sclk_bus0_pll_cmuc_p) = { "mout_bus0_pll_ctrl",
+       "ffac_topc_bus0_pll_div2", "ffac_topc_bus0_pll_div4"};
+PNAME(mout_sclk_bus1_pll_cmuc_p) = { "mout_bus1_pll_ctrl",
+       "ffac_topc_bus1_pll_div2"};
+PNAME(mout_sclk_cc_pll_cmuc_p) = { "mout_cc_pll_ctrl",
+       "ffac_topc_cc_pll_div2"};
+PNAME(mout_sclk_mfc_pll_cmuc_p) = { "mout_mfc_pll_ctrl",
+       "ffac_topc_mfc_pll_div2"};
+
+PNAME(mout_sclk_bus0_pll_out_p)        = {"mout_bus0_pll_ctrl",
+       "ffac_topc_bus0_pll_div2"};
+PNAME(mout_sclk_cmu_apbif_p)   = {"fin_pll", "dout_sclk_cmu_apbif"};
+
+static unsigned long topc_clk_regs[] __initdata = {
+       CC_PLL_LOCK,
+       BUS0_PLL_LOCK,
+       BUS1_DPLL_LOCK,
+       MFC_PLL_LOCK,
+       AUD_PLL_LOCK,
+       MIF_PLL_LOCK,
+       CC_PLL_CON0,
+       CC_PLL_CON1,
+       BUS0_PLL_CON0,
+       BUS0_PLL_CON1,
+       BUS1_DPLL_CON0,
+       BUS1_DPLL_CON1,
+       MFC_PLL_CON0,
+       MFC_PPL_CON1,
+       AUD_PLL_CON0,
+       AUD_PLL_CON1,
+       AUD_PLL_CON2,
+       MIF_PLL_CON0,
+       MIF_PLL_CON1,
+       MIF_PLL_CON2,
+       MUX_SEL_TOPC0,
+       MUX_SEL_TOPC1,
+       MUX_SEL_TOPC2,
+       MUX_SEL_TOPC3,
+       MUX_SEL_TOPC4,
+       MUX_SEL_TOPC5,
+       DIV_TOPC0,
+       DIV_TOPC1,
+       DIV_TOPC2,
+       DIV_TOPC3,
+       DIV_TOPC3,
+       ENABLE_ACLK_TOPC0,
+       ENABLE_ACLK_TOPC1,
+       ENABLE_ACLK_TOPC2,
+       ENABLE_SCLK_TOPC0,
+       ENABLE_SCLK_TOPC1,
+};
+
+static struct samsung_mux_clock topc_mux_clks[] __initdata = {
+       /* Check TOPC TOP0 and TOP1 clocks again*/
+       MUX(0, "mout_bus0_pll_ctrl", mout_bus0_pll_ctrl_p, MUX_SEL_TOPC0, 0, 1),
+       MUX(0, "mout_bus1_pll_ctrl", mout_bus1_pll_ctrl_p, MUX_SEL_TOPC0, 4, 1),
+       MUX(0, "mout_cc_pll_ctrl", mout_cc_pll_ctrl_p, MUX_SEL_TOPC0, 8, 1),
+       MUX(0, "mout_mfc_pll_ctrl", mout_mfc_pll_ctrl_p, MUX_SEL_TOPC0, 12, 1),
+
+       MUX(0, "mout_sclk_bus0_pll_cmuc",
+                       mout_sclk_bus0_pll_cmuc_p, MUX_SEL_TOPC0, 16, 2),
+       MUX(0, "mout_sclk_bus1_pll_cmuc",
+                       mout_sclk_bus1_pll_cmuc_p, MUX_SEL_TOPC0, 20, 1),
+       MUX(0, "mout_sclk_cc_pll_cmuc",
+                       mout_sclk_cc_pll_cmuc_p, MUX_SEL_TOPC0, 24, 1),
+       MUX(0, "mout_sclk_mfc_pll_cmuc",
+                       mout_sclk_mfc_pll_cmuc_p, MUX_SEL_TOPC0, 28, 1),
+
+       MUX(0, "mout_sclk_bus_pll_g3d",
+                       mout_topc_group1, MUX_SEL_TOPC1, 20, 2),
+       MUX(0, "mout_sclk_bus0_pll_out",
+                       mout_sclk_bus0_pll_out_p, MUX_SEL_TOPC1, 16, 1),
+       MUX(0, "mout_sclk_bus0_pll_mif",
+                       mout_topc_group1, MUX_SEL_TOPC1, 12, 2),
+       MUX(0, "mout_sclk_bus0_pll_atlas",
+                       mout_topc_group1, MUX_SEL_TOPC1, 4, 2),
+       MUX(0, "mout_aud_pll_ctrl",
+                       mout_aud_pll_ctrl_p, MUX_SEL_TOPC1, 0, 1),
+
+       MUX(0, "mout_aclk_ccore_532", mout_topc_group2, MUX_SEL_TOPC2, 0, 2),
+       MUX(0, "mout_aclk_ccore_133", mout_topc_group2, MUX_SEL_TOPC2, 4, 2),
+       MUX(0, "mout_aclk_bus0_532", mout_topc_group2, MUX_SEL_TOPC2, 8, 2),
+       MUX(0, "mout_aclk_bus1_532", mout_topc_group2, MUX_SEL_TOPC2, 12, 2),
+       MUX(0, "mout_aclk_bus1_200", mout_topc_group2, MUX_SEL_TOPC2, 16, 2),
+       MUX(0, "mout_aclk_imem_266", mout_topc_group2, MUX_SEL_TOPC2, 20, 2),
+       MUX(0, "mout_aclk_imem_200", mout_topc_group2, MUX_SEL_TOPC2, 24, 2),
+       MUX(0, "mout_aclk_imem_100", mout_topc_group2, MUX_SEL_TOPC2, 28, 2),
+
+       MUX(0, "mout_aclk_g2d_400", mout_topc_group2, MUX_SEL_TOPC3, 0, 2),
+       MUX(0, "mout_aclk_g2d_266", mout_topc_group2, MUX_SEL_TOPC3, 4, 2),
+       MUX(0, "mout_aclk_mfc_532", mout_topc_group2, MUX_SEL_TOPC3, 8, 2),
+       MUX(0, "mout_aclk_hevc_532", mout_topc_group2, MUX_SEL_TOPC3, 12, 2),
+       MUX(0, "mout_aclk_mfc_bus_532", mout_topc_group2,
+                       MUX_SEL_TOPC3, 16, 2),
+       MUX(0, "mout_aclk_mscl_532", mout_topc_group2, MUX_SEL_TOPC3, 20, 2),
+       MUX(0, "mout_aclk_peris_66", mout_topc_group2, MUX_SEL_TOPC3, 24, 2),
+
+       MUX(0, "mout_sclk_cmu_apbif", mout_topc_group2, MUX_SEL_TOPC4, 0, 2),
+       MUX(0, "mout_sclk_cmuc_apbif", mout_sclk_cmu_apbif_p,
+                       MUX_SEL_TOPC4, 16, 1),
+};
+
+static struct samsung_div_clock topc_div_clks[] __initdata = {
+       DIV(0, "dout_aclk_ccore_532", "mout_aclk_ccore_532", DIV_TOPC0, 0, 3),
+       DIV(0, "dout_aclk_ccore_133", "mout_aclk_ccore_133", DIV_TOPC0, 4, 4),
+       DIV(0, "dout_aclk_bus0_532", "mout_aclk_bus0_532", DIV_TOPC0, 8, 3),
+       DIV(0, "dout_aclk_bus1_532", "mout_aclk_bus1_532", DIV_TOPC0, 12, 3),
+       DIV(0, "dout_aclk_bus1_200", "mout_aclk_bus1_200", DIV_TOPC0, 16, 3),
+       DIV(0, "dout_aclk_imem_266", "mout_aclk_imem_266", DIV_TOPC0, 20, 3),
+       DIV(0, "dout_aclk_imem_200", "mout_aclk_imem_200", DIV_TOPC0, 24, 3),
+       DIV(0, "dout_aclk_imem_100", "mout_aclk_imem_100", DIV_TOPC0, 28, 3),
+
+       DIV(0, "dout_aclk_g2d_400", "mout_aclk_g2d_400", DIV_TOPC1, 0, 3),
+       DIV(0, "dout_aclk_g2d_266", "mout_aclk_g2d_266", DIV_TOPC1, 4, 3),
+       DIV(0, "dout_aclk_mfc_532", "mout_aclk_mfc_532", DIV_TOPC1, 8, 3),
+       DIV(0, "dout_aclk_hevc_532", "mout_aclk_hevc_532", DIV_TOPC1, 12, 3),
+       DIV(0, "dout_aclk_mfc_bus_532", "mout_aclk_mfc_bus_532",
+                       DIV_TOPC1, 16, 3),
+       DIV(0, "dout_aclk_mscl_532", "mout_aclk_mscl_532", DIV_TOPC1, 20, 3),
+       DIV(0, "dout_aclk_peris_66", "mout_aclk_peris_66", DIV_TOPC1, 24, 4),
+
+       DIV(0, "dout_sclk_cmu_apbif", "mout_sclk_cmu_apbif", DIV_TOPC2, 0, 4),
+
+       DIV(0, "dout_sclk_bus0_pll", "mout_sclk_bus0_pll_out", DIV_TOPC3, 0, 3),
+       DIV(0, "dout_sclk_bus0_pll_mif", "mout_sclk_bus0_pll_mif",
+                       DIV_TOPC3, 4, 3),
+       DIV(0, "dout_sclk_bus1_pll", "mout_bus1_pll_ctrl", DIV_TOPC3, 8, 3),
+       DIV(0, "dout_sclk_cc_pll", "mout_cc_pll_ctrl", DIV_TOPC3, 12, 3),
+       DIV(0, "dout_sclk_mfc_pll", "mout_mfc_pll_ctrl", DIV_TOPC3, 16, 3),
+       DIV(0, "dout_sclk_bus_pll_g3d", "mout_sclk_bus_pll_g3d",
+                       DIV_TOPC3, 20, 3),
+       DIV(0, "dout_sclk_aud_pll", "mout_aud_pll_ctrl", DIV_TOPC3, 28, 3),
+};
+
+static struct samsung_gate_clock topc_gate_clks[] __initdata = {
+       GATE(ACLK_CCORE_532, "aclk_ccore_532", "dout_aclk_ccore_532",
+               ENABLE_ACLK_TOPC0, 0, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_CCORE_133, "aclk_ccore_133", "dout_aclk_ccore_133",
+               ENABLE_ACLK_TOPC0, 4, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_BUS0_532, "aclk_bus0_532", "dout_aclk_bus0_532",
+               ENABLE_ACLK_TOPC0, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_BUS1_532, "aclk_bus1_532", "dout_aclk_bus1_532",
+               ENABLE_ACLK_TOPC0, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_BUS1_200, "aclk_bus1_200", "dout_aclk_bus1_200",
+               ENABLE_ACLK_TOPC0, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_IMEM_266, "aclk_imem_266", "dout_aclk_imem_266",
+               ENABLE_ACLK_TOPC0, 20, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_IMEM_200, "aclk_imem_200", "dout_aclk_imem_200",
+               ENABLE_ACLK_TOPC0, 24, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_IMEM_100, "aclk_imem_100", "dout_aclk_imem_100",
+               ENABLE_ACLK_TOPC0, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(ACLK_G2D_400, "aclk_g2d_400", "dout_aclk_g2d_400",
+               ENABLE_ACLK_TOPC1, 0, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_G2D_266, "aclk_g2d_266", "dout_aclk_g2d_266",
+               ENABLE_ACLK_TOPC1, 4, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_MFC_532, "aclk_mfc_532", "dout_aclk_mfc_532",
+               ENABLE_ACLK_TOPC1, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_HEVC_532, "aclk_hevc_532", "dout_aclk_hevc_532",
+               ENABLE_ACLK_TOPC1, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_MFC_BUS_532, "aclk_mfc_bus_532", "dout_aclk_mfc_bus_532",
+               ENABLE_ACLK_TOPC1, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_MSCL_532, "aclk_mscl_532", "dout_aclk_mscl_532",
+               ENABLE_ACLK_TOPC1, 20, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_PERIS_66, "aclk_peris_66", "dout_aclk_peris_66",
+               ENABLE_ACLK_TOPC1, 24, CLK_IGNORE_UNUSED, 0),
+
+       GATE(SCLK_CMU_APBIF, "sclk_cmu_apbif", "dout_sclk_cmu_apbif",
+               ENABLE_SCLK_TOPC0, 0, CLK_IGNORE_UNUSED, 0),
+
+       GATE(SCLK_CC_PLL_A, "sclk_cc_pll_a", "dout_sclk_cc_pll",
+               ENABLE_SCLK_TOPC1, 0, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_CC_PLL_B, "sclk_cc_pll_b", "dout_sclk_cc_pll",
+               ENABLE_SCLK_TOPC1, 1, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS0_PLL_A, "sclk_bus0_pll_a", "dout_sclk_bus0_pll",
+               ENABLE_SCLK_TOPC1, 4, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS0_PLL_B, "sclk_bus0_pll_b", "dout_sclk_bus0_pll",
+               ENABLE_SCLK_TOPC1, 5, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS0_PLL_MIF, "sclk_bus0_pll_mif", "dout_sclk_bus0_pll_mif",
+               ENABLE_SCLK_TOPC1, 6, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS0_PLL_ATLAS, "sclk_bus0_pll_atlas",
+               "dout_sclk_bus0_pll_atlas",
+               ENABLE_SCLK_TOPC1, 7, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS_PLL_G3D, "sclk_bus_pll_g3d", "dout_sclk_bus_pll_g3d",
+               ENABLE_SCLK_TOPC1, 9, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS1_PLL_A, "sclk_bus1_pll_a", "dout_sclk_bus1_pll",
+               ENABLE_SCLK_TOPC1, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_BUS1_PLL_B, "sclk_bus1_pll_b", "dout_sclk_bus1_pll",
+               ENABLE_SCLK_TOPC1, 13, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_MFC_PLL_A, "sclk_mfc_pll_a", "dout_sclk_mfc_pll",
+               ENABLE_SCLK_TOPC1, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_MFC_PLL_B, "sclk_mfc_pll_b", "dout_sclk_mfc_pll",
+               ENABLE_SCLK_TOPC1, 17, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_AUD_PLL, "sclk_aud_pll", "dout_sclk_aud_pll",
+               ENABLE_SCLK_TOPC1, 20, CLK_IGNORE_UNUSED, 0),
+};
+
+static struct samsung_pll_clock topc_pll_clks[] __initdata = {
+       PLL(pll_1451x, 0, "fout_bus0_pll", "fin_pll",
+               BUS0_PLL_LOCK, BUS0_PLL_CON0,
+               pll1451x_24mhz_tbl),
+       PLL(pll_1452x, 0, "fout_cc_pll", "fin_pll",
+               CC_PLL_LOCK, CC_PLL_CON0,
+               pll1452x_24mhz_tbl),
+       PLL(pll_1452x, 0, "fout_bus1_pll", "fin_pll",
+               BUS1_DPLL_LOCK, BUS1_DPLL_CON0,
+               pll1452x_24mhz_tbl),
+       PLL(pll_1452x, 0, "fout_mfc_pll", "fin_pll",
+               MFC_PLL_LOCK, MFC_PLL_CON0,
+               pll1452x_24mhz_tbl),
+       PLL(pll_1460x, 0, "fout_aud_pll", "fin_pll",
+               AUD_PLL_LOCK, AUD_PLL_CON0,
+               pll1460x_24mhz_tbl),
+};
+
+static void __init exynos7_clk_topc_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.pll_clks = topc_pll_clks;
+       cmu.nr_pll_clks = ARRAY_SIZE(topc_pll_clks);
+       cmu.mux_clks = topc_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(topc_mux_clks);
+       cmu.div_clks = topc_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(topc_div_clks);
+       cmu.gate_clks = topc_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(topc_gate_clks);
+       cmu.fixed_factor_clks = topc_fixed_factor_clks;
+       cmu.nr_fixed_factor_clks = ARRAY_SIZE(topc_fixed_factor_clks);
+       cmu.nr_clk_ids = TOPC_NR_CLK;
+       cmu.clk_regs = topc_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(topc_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_topc, "samsung,exynos7-clock-topc",
+               exynos7_clk_topc_init);
+
+/* Register Offset definitions for CMU_TOP0 (0x105D0000) */
+#define        MUX_SEL_TOP00                   0x0200
+#define        MUX_SEL_TOP01                   0x0204
+#define        MUX_SEL_TOP03                   0x020C
+#define        MUX_SEL_TOP04                   0x0210
+#define        MUX_SEL_TOP05                   0x0214
+#define        MUX_SEL_TOP06                   0x0218
+#define        MUX_SEL_TOP07                   0x021C
+#define        MUX_SEL_TOP0_DISP               0x0220
+#define        MUX_SEL_TOP0_PERIC0             0x0230
+#define        MUX_SEL_TOP0_PERIC1             0x0234
+#define        MUX_SEL_TOP0_PERIC2             0x0238
+#define        MUX_SEL_TOP0_PERIC3             0x023C
+#define        DIV_TOP03                       0x060C
+#define        DIV_TOP04                       0x0610
+#define        DIV_TOP05                       0x0614
+#define        DIV_TOP06                       0x0618
+#define        DIV_TOP07                       0x061C
+#define        DIV_TOP0_DISP                   0x0620
+#define        DIV_TOP0_PERIC0                 0x0630
+#define        DIV_TOP0_PERIC1                 0x0634
+#define        DIV_TOP0_PERIC2                 0x0638
+#define        DIV_TOP0_PERIC3                 0x063C
+#define        ENABLE_ACLK_TOP02               0x0808
+#define        ENABLE_ACLK_TOP03               0x080C
+#define        ENABLE_ACLK_TOP04               0x0810
+#define        ENABLE_ACLK_TOP05               0x0814
+#define        ENABLE_ACLK_TOP06               0x0818
+#define        ENABLE_ACLK_TOP07               0x081C
+#define        ENABLE_SCLK_TOP0_DISP           0x0A20
+#define        ENABLE_SCLK_TOP0_PERIC0         0x0A30
+#define        ENABLE_SCLK_TOP0_PERIC1         0x0A34
+#define        ENABLE_SCLK_TOP0_PERIC2         0x0A38
+#define        ENABLE_SCLK_TOP0_PERIC3         0x0A3C
+
+/* List of parent clocks for Muxes in CMU_TOP0 */
+PNAME(mout_bus0_pll_p) = { "fin_pll", "sclk_bus0_pll_a" };
+PNAME(mout_bus1_pll_p) = { "fin_pll", "sclk_bus1_pll_a" };
+PNAME(mout_cc_pll_p)   = { "fin_pll", "sclk_cc_pll_a" };
+PNAME(mout_mfc_pll_p)  = { "fin_pll", "sclk_mfc_pll_a" };
+
+PNAME(mout_top0_half_bus0_pll_p) = {"mout_top0_bus0_pll",
+       "ffac_top0_bus0_pll_div2"};
+PNAME(mout_top0_half_bus1_pll_p) = {"mout_top0_bus1_pll",
+       "ffac_top0_bus1_pll_div2"};
+PNAME(mout_top0_half_cc_pll_p) = {"mout_top0_cc_pll",
+       "ffac_top0_cc_pll_div2"};
+PNAME(mout_top0_half_mfc_pll_p) = {"mout_top0_mfc_pll",
+       "ffac_top0_mfc_pll_div2"};
+
+PNAME(mout_top0_aud_pll_p)     = {"fin_pll", "sclk_aud_pll"};
+
+PNAME(mout_sclk_cmu0_apbif_p)  = {"fin_pll", "sclk_cmu_apbif"};
+
+PNAME(mout_top0_group1)        = {"mout_top0_half_bus0_pll",
+       "mout_top0_half_bus1_pll", "mout_top0_half_cc_pll",
+       "mout_top0_half_mfc_pll"};
+PNAME(mout_top0_group3) = {"ioclk_audiocdclk0",
+       "ioclk_audiocdclk1", "ioclk_spdif_extclk",
+       "mout_top0_aud_pll",    "mout_top0_half_bus0_pll",
+       "mout_top0_half_bus1_pll"};
+PNAME(mout_top0_group4) = {"ioclk_audiocdclk1", "mout_top0_aud_pll",
+       "mout_top0_half_bus0_pll", "mout_top0_half_bus1_pll"};
+
+static unsigned long top0_clk_regs[] __initdata = {
+       MUX_SEL_TOP00,
+       MUX_SEL_TOP01,
+       MUX_SEL_TOP03,
+       MUX_SEL_TOP04,
+       MUX_SEL_TOP05,
+       MUX_SEL_TOP06,
+       MUX_SEL_TOP07,
+       MUX_SEL_TOP0_DISP,
+       MUX_SEL_TOP0_PERIC0,
+       MUX_SEL_TOP0_PERIC1,
+       MUX_SEL_TOP0_PERIC2,
+       MUX_SEL_TOP0_PERIC3,
+       DIV_TOP03,
+       DIV_TOP04,
+       DIV_TOP05,
+       DIV_TOP06,
+       DIV_TOP07,
+       DIV_TOP0_DISP,
+       DIV_TOP0_PERIC0,
+       DIV_TOP0_PERIC1,
+       DIV_TOP0_PERIC2,
+       DIV_TOP0_PERIC3,
+       ENABLE_ACLK_TOP02,
+       ENABLE_ACLK_TOP03,
+       ENABLE_ACLK_TOP04,
+       ENABLE_ACLK_TOP05,
+       ENABLE_ACLK_TOP06,
+       ENABLE_ACLK_TOP07,
+       ENABLE_SCLK_TOP0_DISP,
+       ENABLE_SCLK_TOP0_PERIC0,
+       ENABLE_SCLK_TOP0_PERIC1,
+       ENABLE_SCLK_TOP0_PERIC2,
+       ENABLE_SCLK_TOP0_PERIC3,
+};
+
+static struct samsung_mux_clock top0_mux_clks[] __initdata = {
+       MUX(0, "mout_top0_aud_pll", mout_top0_aud_pll_p, MUX_SEL_TOP00, 0, 1),
+       MUX(0, "mout_top0_mfc_pll", mout_mfc_pll_p, MUX_SEL_TOP00, 4, 1),
+       MUX(0, "mout_top0_cc_pll", mout_cc_pll_p, MUX_SEL_TOP00, 8, 1),
+       MUX(0, "mout_top0_bus1_pll", mout_bus1_pll_p, MUX_SEL_TOP00, 12, 1),
+       MUX(0, "mout_top0_bus0_pll", mout_bus0_pll_p, MUX_SEL_TOP00, 16, 1),
+
+       MUX(0, "mout_top0_half_mfc_pll",
+                       mout_top0_half_mfc_pll_p, MUX_SEL_TOP01, 4, 1),
+       MUX(0, "mout_top0_half_cc_pll",
+                       mout_top0_half_cc_pll_p, MUX_SEL_TOP01, 8, 1),
+       MUX(0, "mout_top0_half_bus1_pll",
+                       mout_top0_half_bus1_pll_p, MUX_SEL_TOP01, 12, 1),
+       MUX(0, "mout_top0_half_bus0_pll",
+                       mout_top0_half_bus0_pll_p, MUX_SEL_TOP01, 16, 1),
+       MUX(0, "mout_sclk_cmu0_apbif",
+                       mout_sclk_cmu0_apbif_p, MUX_SEL_TOP01, 28, 1),
+
+       MUX(0, "mout_aclk_vpp1_400", mout_top0_group1, MUX_SEL_TOP03, 4, 2),
+       MUX(0, "mout_aclk_vpp0_400", mout_top0_group1, MUX_SEL_TOP03, 8, 2),
+       MUX(0, "mout_aclk_peric1_66", mout_top0_group1, MUX_SEL_TOP03, 12, 2),
+       MUX(0, "mout_aclk_peric0_66", mout_top0_group1, MUX_SEL_TOP03, 20, 2),
+       MUX(0, "mout_aclk_disp_400", mout_top0_group1, MUX_SEL_TOP03, 28, 2),
+       /* top0 block for disp */
+       MUX(0, "mout_sclk_hdmi_spdif", mout_top0_group3,
+                       MUX_SEL_TOP0_DISP, 12, 3),
+       MUX(0, "mout_sclk_dsd", mout_top0_group1,
+                       MUX_SEL_TOP0_DISP, 16, 2),
+       MUX(0, "mout_sclk_decon_vclk", mout_top0_group1,
+                       MUX_SEL_TOP0_DISP, 20, 2),
+       MUX(0, "mout_sclk_decon_ext_eclk",
+                       mout_top0_group1, MUX_SEL_TOP0_DISP, 24, 2),
+       MUX(0, "mout_sclk_decon_int_eclk",
+                       mout_top0_group1, MUX_SEL_TOP0_DISP, 28, 2),
+       /* top0 block for peric */
+       MUX(0, "mout_sclk_spdif", mout_top0_group3, MUX_SEL_TOP0_PERIC0, 4, 3),
+       MUX(0, "mout_sclk_pcm1", mout_top0_group4, MUX_SEL_TOP0_PERIC0, 8, 2),
+       MUX(0, "mout_sclk_i2s1", mout_top0_group4, MUX_SEL_TOP0_PERIC0, 20, 2),
+
+       MUX(0, "mout_sclk_spi1", mout_top0_group1, MUX_SEL_TOP0_PERIC1, 8, 2),
+       MUX(0, "mout_sclk_spi0", mout_top0_group1, MUX_SEL_TOP0_PERIC1, 20, 2),
+
+       MUX(0, "mout_sclk_spi3", mout_top0_group1, MUX_SEL_TOP0_PERIC2, 8, 2),
+       MUX(0, "mout_sclk_spi2", mout_top0_group1, MUX_SEL_TOP0_PERIC2, 20, 2),
+
+       MUX(0, "mout_sclk_uart3", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 4, 2),
+       MUX(0, "mout_sclk_uart2", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 8, 2),
+       MUX(0, "mout_sclk_uart1", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 12, 2),
+       MUX(0, "mout_sclk_uart0", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 16, 2),
+       MUX(0, "mout_sclk_spi4", mout_top0_group1, MUX_SEL_TOP0_PERIC3, 20, 2),
+};
+
+static struct samsung_div_clock top0_div_clks[] __initdata = {
+       DIV(0, "dout_aclk_peric1_66", "mout_aclk_peric1_66", DIV_TOP03, 12, 6),
+       DIV(0, "dout_aclk_peric0_66", "mout_aclk_peric0_66", DIV_TOP03, 20, 6),
+       DIV(0, "dout_aclk_disp_400", "mout_aclk_disp_400", DIV_TOP03, 28, 4),
+
+       DIV(0, "dout_sclk_hdmi_spdif",
+                       "mout_sclk_hdmi_spdif", DIV_TOP0_DISP, 12, 4),
+       DIV(0, "dout_sclk_dsd", "mout_sclk_dsd", DIV_TOP0_DISP, 16, 4),
+       DIV(0, "dout_sclk_decon_vclk",
+                       "mout_sclk_decon_vclk", DIV_TOP0_DISP, 20, 4),
+       DIV(0, "dout_sclk_decon_ext_eclk",
+                       "mout_sclk_decon_ext_eclk", DIV_TOP0_DISP, 24, 4),
+       DIV(0, "dout_sclk_decon_int_eclk",
+                       "mout_sclk_decon_int_eclk", DIV_TOP0_DISP, 28, 4),
+
+       DIV(0, "dout_sclk_spdif", "mout_sclk_spdif", DIV_TOP0_PERIC0, 4, 4),
+       DIV(0, "dout_sclk_pcm1", "mout_sclk_pcm1", DIV_TOP0_PERIC0, 8, 12),
+       DIV(0, "dout_sclk_i2s1", "mout_sclk_i2s1", DIV_TOP0_PERIC0, 20, 10),
+
+       DIV(0, "dout_sclk_spi1", "mout_sclk_spi1", DIV_TOP0_PERIC1, 8, 12),
+       DIV(0, "dout_sclk_spi0", "mout_sclk_spi0", DIV_TOP0_PERIC1, 20, 12),
+
+       DIV(0, "dout_sclk_spi3", "mout_sclk_spi3", DIV_TOP0_PERIC2, 8, 12),
+       DIV(0, "dout_sclk_spi2", "mout_sclk_spi2", DIV_TOP0_PERIC2, 20, 12),
+
+       DIV(0, "dout_sclk_uart3", "mout_sclk_uart3", DIV_TOP0_PERIC3, 4, 4),
+       DIV(0, "dout_sclk_uart2", "mout_sclk_uart2", DIV_TOP0_PERIC3, 8, 4),
+       DIV(0, "dout_sclk_uart1", "mout_sclk_uart1", DIV_TOP0_PERIC3, 12, 4),
+       DIV(0, "dout_sclk_uart0", "mout_sclk_uart0", DIV_TOP0_PERIC3, 16, 4),
+       DIV(0, "dout_sclk_spi4", "mout_sclk_spi4", DIV_TOP0_PERIC3, 20, 12),
+};
+
+static struct samsung_gate_clock top0_gate_clks[] __initdata = {
+       GATE(CLK_ACLK_PERIC1_66, "aclk_peric1_66", "dout_aclk_peric1_66",
+                       ENABLE_ACLK_TOP03, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_ACLK_PERIC0_66, "aclk_peric0_66", "dout_aclk_peric0_66",
+                       ENABLE_ACLK_TOP03, 20, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_ACLK_DISP_400, "aclk_disp_400", "dout_aclk_disp_400",
+                       ENABLE_ACLK_TOP03, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_HDMI_SPDIF, "sclk_hdmi_spdif", "dout_sclk_hdmi_spdif",
+                       ENABLE_SCLK_TOP0_DISP, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_DSD, "sclk_dsd", "dout_sclk_dsd",
+                       ENABLE_SCLK_TOP0_DISP, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_DECON_VCLK, "sclk_decon_vclk", "dout_sclk_decon_vclk",
+                       ENABLE_SCLK_TOP0_DISP, 20, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_DECON_EXT_ECLK, "sclk_decon_ext_eclk",
+                       "dout_sclk_decon_ext_eclk",
+                       ENABLE_SCLK_TOP0_DISP, 24, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_DECON_INT_ECLK, "sclk_decon_int_eclk",
+                       "dout_sclk_decon_int_eclk",
+                       ENABLE_SCLK_TOP0_DISP, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_SPDIF, "sclk_spdif", "dout_sclk_spdif",
+                       ENABLE_SCLK_TOP0_PERIC0, 4, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_PCM1, "sclk_pcm1", "dout_sclk_pcm1",
+                       ENABLE_SCLK_TOP0_PERIC0, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_I2S1, "sclk_i2s1", "dout_sclk_i2s1",
+                       ENABLE_SCLK_TOP0_PERIC0, 20, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_SPI1, "sclk_spi1", "dout_sclk_spi1",
+                       ENABLE_SCLK_TOP0_PERIC1, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_SPI0, "sclk_spi0", "dout_sclk_spi0",
+                       ENABLE_SCLK_TOP0_PERIC1, 20, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_SPI3, "sclk_spi3", "dout_sclk_spi3",
+                       ENABLE_SCLK_TOP0_PERIC2, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_SPI2, "sclk_spi2", "dout_sclk_spi2",
+                       ENABLE_SCLK_TOP0_PERIC2, 20, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_UART3, "sclk_uart3", "dout_sclk_uart3",
+                       ENABLE_SCLK_TOP0_PERIC3, 4, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_UART2, "sclk_uart2", "dout_sclk_uart2",
+                       ENABLE_SCLK_TOP0_PERIC3, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_UART1, "sclk_uart1", "dout_sclk_uart1",
+                       ENABLE_SCLK_TOP0_PERIC3, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_UART0, "sclk_uart0", "dout_sclk_uart0",
+                       ENABLE_SCLK_TOP0_PERIC3, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_SPI4, "sclk_spi4", "dout_sclk_spi4",
+                       ENABLE_SCLK_TOP0_PERIC3, 20, CLK_IGNORE_UNUSED, 0),
+};
+
+static struct samsung_fixed_factor_clock top0_fixed_factor_clks[] __initdata = 
{
+       FFACTOR(0, "ffac_top0_bus0_pll_div2", "mout_top0_bus0_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top0_bus1_pll_div2", "mout_top0_bus1_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top0_cc_pll_div2", "mout_top0_cc_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top0_mfc_pll_div2", "mout_top0_mfc_pll", 1, 2, 0),
+};
+
+static void __init exynos7_clk_top0_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = top0_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(top0_mux_clks);
+       cmu.div_clks = top0_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(top0_div_clks);
+       cmu.gate_clks = top0_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(top0_gate_clks);
+       cmu.fixed_factor_clks = top0_fixed_factor_clks;
+       cmu.nr_fixed_factor_clks = ARRAY_SIZE(top0_fixed_factor_clks);
+       cmu.nr_clk_ids = TOP0_NR_CLK;
+       cmu.clk_regs = top0_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(top0_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_top0, "samsung,exynos7-clock-top0",
+               exynos7_clk_top0_init);
+
+/* Register Offset definitions for CMU_TOP1 (0x105E0000) */
+#define        MUX_SEL_TOP10                   0x0200
+#define        MUX_SEL_TOP11                   0x0204
+#define        MUX_SEL_TOP13                   0x020C
+#define        MUX_SEL_TOP1_FSYS0              0x0224
+#define        MUX_SEL_TOP1_FSYS1              0x0228
+#define        MUX_SEL_TOP1_FSYS11             0x022C
+#define        DIV_TOP13                       0x060C
+#define        DIV_TOP1_FSYS0                  0x0624
+#define        DIV_TOP1_FSYS1                  0x0628
+#define        DIV_TOP1_FSYS11                 0x062C
+#define        ENABLE_ACLK_TOP12               0x0808
+#define        ENABLE_ACLK_TOP13               0x080C
+#define        ENABLE_SCLK_TOP1_FSYS0          0x0A24
+#define        ENABLE_SCLK_TOP1_FSYS1          0x0A28
+#define        ENABLE_SCLK_TOP1_FSYS11         0x0A2C
+
+/* List of parent clocks for Muxes in CMU_TOP1 */
+PNAME(mout_top1_bus0_pll_p)    = { "fin_pll", "sclk_bus0_pll_b" };
+PNAME(mout_top1_bus1_pll_p)    = { "fin_pll", "sclk_bus1_pll_b" };
+PNAME(mout_top1_cc_pll_p)      = { "fin_pll", "sclk_cc_pll_b" };
+PNAME(mout_top1_mfc_pll_p)     = { "fin_pll", "sclk_mfc_pll_b" };
+
+PNAME(mout_top1_half_bus0_pll_p) = {"mout_top1_bus0_pll",
+       "ffac_top1_bus0_pll_div2"};
+PNAME(mout_top1_half_bus1_pll_p) = {"mout_top1_bus1_pll",
+       "ffac_top1_bus1_pll_div2"};
+PNAME(mout_top1_half_cc_pll_p) = {"mout_top1_cc_pll",
+       "ffac_top1_cc_pll_div2"};
+PNAME(mout_top1_half_mfc_pll_p) = {"mout_top1_mfc_pll",
+       "ffac_top1_mfc_pll_div2"};
+
+PNAME(mout_top1_group1) = {"mout_top1_half_bus0_pll",
+       "mout_top1_half_bus1_pll", "mout_top1_half_cc_pll",
+       "mout_top1_half_mfc_pll"};
+
+PNAME(mout_sclk_cmu1_apbif_p)  = {"fin_pll", "sclk_cmu_apbif"};
+
+static unsigned long top1_clk_regs[] __initdata = {
+       MUX_SEL_TOP10,
+       MUX_SEL_TOP11,
+       MUX_SEL_TOP13,
+       MUX_SEL_TOP1_FSYS0,
+       MUX_SEL_TOP1_FSYS1,
+       MUX_SEL_TOP1_FSYS11,
+       DIV_TOP13,
+       DIV_TOP0_DISP,
+       DIV_TOP1_FSYS0,
+       DIV_TOP1_FSYS1,
+       DIV_TOP1_FSYS11,
+       ENABLE_ACLK_TOP12,
+       ENABLE_ACLK_TOP13,
+       ENABLE_SCLK_TOP1_FSYS0,
+       ENABLE_SCLK_TOP1_FSYS1,
+       ENABLE_SCLK_TOP1_FSYS11,
+};
+
+static struct samsung_mux_clock top1_mux_clks[] __initdata = {
+       MUX(0, "mout_top1_mfc_pll", mout_top1_mfc_pll_p, MUX_SEL_TOP10, 4, 1),
+       MUX(0, "mout_top1_cc_pll", mout_top1_cc_pll_p, MUX_SEL_TOP10, 8, 1),
+       MUX(0, "mout_top1_bus1_pll", mout_top1_bus1_pll_p,
+                       MUX_SEL_TOP10, 12, 1),
+       MUX(0, "mout_top1_bus0_pll", mout_top1_bus0_pll_p,
+                       MUX_SEL_TOP10, 16, 1),
+
+       MUX(0, "mout_top1_half_mfc_pll", mout_top1_half_mfc_pll_p,
+                       MUX_SEL_TOP11, 4, 1),
+       MUX(0, "mout_top1_half_cc_pll", mout_top1_half_cc_pll_p,
+                       MUX_SEL_TOP11, 8, 1),
+       MUX(0, "mout_top1_half_bus1_pll", mout_top1_half_bus1_pll_p,
+                       MUX_SEL_TOP11, 12, 1),
+       MUX(0, "mout_top1_half_bus0_pll", mout_top1_half_bus0_pll_p,
+                       MUX_SEL_TOP11, 16, 1),
+       MUX(0, "mout_sclk_cmu1_apbif", mout_sclk_cmu1_apbif_p,
+                       MUX_SEL_TOP11, 28, 1),
+
+       MUX(0, "mout_aclk_fsys1_200", mout_top1_group1,
+                       MUX_SEL_TOP13, 24, 2),
+       MUX(0, "mout_aclk_fsys0_200", mout_top1_group1,
+                       MUX_SEL_TOP13, 28, 2),
+
+       /* top1 block for fsys */
+       MUX(0, "mout_sclk_phy_fsys0_26m", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS0, 0, 2),
+       MUX(0, "mout_sclk_phy_fsys0", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS0, 8, 2),
+       MUX(0, "mout_sclk_ufsunipro11", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS0, 16, 2),
+       MUX(0, "mout_sclk_mmc2", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS0, 24, 2),
+       MUX(0, "mout_sclk_usbdrd300", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS0, 28, 2),
+
+       MUX(0, "mout_sclk_phy_fsys1", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS1, 0, 2),
+       MUX(0, "mout_sclk_tlx400_wifi1", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS1, 8, 2),
+       MUX(0, "mout_sclk_ufsunipro20", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS1, 16, 2),
+       MUX(0, "mout_sclk_mmc1", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS1, 24, 2),
+       MUX(0, "mout_sclk_mmc0", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS1, 28, 2),
+
+       MUX(0, "mout_sclk_phy_fsys1_26m", mout_top1_group1,
+                       MUX_SEL_TOP1_FSYS11, 24, 2),
+};
+
+static struct samsung_div_clock top1_div_clks[] __initdata = {
+       DIV(0, "dout_aclk_fsys1_200", "mout_aclk_fsys1_200", DIV_TOP13, 24, 4),
+       DIV(0, "dout_aclk_fsys0_200", "mout_aclk_fsys0_200", DIV_TOP13, 28, 4),
+
+       /* top1 block for fsys */
+       DIV(0, "dout_sclk_phy_fsys0_26m", "mout_sclk_phy_fsys0_26m",
+                       DIV_TOP1_FSYS0, 0, 6),
+       DIV(0, "dout_sclk_phy_fsys0", "mout_sclk_phy_fsys0",
+                       DIV_TOP1_FSYS0, 8, 6),
+       DIV(0, "dout_sclk_ufsunipro11", "mout_sclk_ufsunipro11",
+                       DIV_TOP1_FSYS0, 16, 6),
+       DIV(0, "dout_sclk_mmc2", "mout_sclk_mmc2",
+                       DIV_TOP1_FSYS0, 24, 4),
+       DIV(0, "dout_sclk_usbdrd300", "mout_sclk_usbdrd300",
+                       DIV_TOP1_FSYS0, 28, 4),
+
+       DIV(0, "dout_sclk_phy_fsys1", "mout_sclk_phy_fsys1",
+                       DIV_TOP1_FSYS1, 0, 6),
+       DIV(0, "dout_sclk_tlx400_wifi1", "mout_sclk_tlx400_wifi1",
+                       DIV_TOP1_FSYS1, 8, 6),
+       DIV(0, "dout_sclk_ufsunipro20", "mout_sclk_ufsunipro20",
+                       DIV_TOP1_FSYS1, 16, 6),
+       DIV(0, "dout_sclk_mmc1", "mout_sclk_mmc1", DIV_TOP1_FSYS1, 24, 4),
+       DIV(0, "dout_sclk_mmc0", "mout_sclk_mmc0", DIV_TOP1_FSYS1, 28, 4),
+
+       DIV(0, "dout_sclk_phy_fsys1_26m", "mout_sclk_phy_fsys1_26m",
+                       DIV_TOP1_FSYS11, 24, 6),
+};
+
+static struct samsung_gate_clock top1_gate_clks[] __initdata = {
+       GATE(ACLK_FSYS1_200, "aclk_fsys1_200", "dout_aclk_fsys1_200",
+                       ENABLE_ACLK_TOP13, 24, CLK_IGNORE_UNUSED, 0),
+       GATE(ACLK_FSYS0_200, "aclk_fsys0_200", "dout_aclk_fsys0_200",
+                       ENABLE_ACLK_TOP13, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_PHY_FSYS0_26M, "sclk_phy_fsys0_26m",
+                       "dout_sclk_phy_fsys0_26m",
+                       ENABLE_SCLK_TOP1_FSYS0, 0, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_PHY_FSYS0, "sclk_phy_fsys0", "dout_sclk_phy_fsys0",
+                       ENABLE_SCLK_TOP1_FSYS0, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_UFSUNIPRO11, "sclk_ufsunipro11",
+                       "dout_sclk_ufsunipro11",
+                       ENABLE_SCLK_TOP1_FSYS0, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_MMC2, "sclk_mmc2", "dout_sclk_mmc2",
+                       ENABLE_SCLK_TOP1_FSYS0, 24, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_USBDRD300, "sclk_usbdrd300", "dout_sclk_usbdrd300",
+                       ENABLE_SCLK_TOP1_FSYS0, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_PHY_FSYS1, "sclk_phy_fsys1", "dout_sclk_phy_fsys1",
+                       ENABLE_SCLK_TOP1_FSYS1, 0, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_TLX400_WIFI1, "sclk_tlx400_wifi1",
+                       "dout_sclk_tlx400_wifi1",
+                       ENABLE_SCLK_TOP1_FSYS1, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_UFSUNIPRO20, "sclk_ufsunipro20",
+                       "dout_sclk_ufsunipro20",
+                       ENABLE_SCLK_TOP1_FSYS1, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_MMC1, "sclk_mmc1", "dout_sclk_mmc1",
+                       ENABLE_SCLK_TOP1_FSYS1, 24, CLK_IGNORE_UNUSED, 0),
+       GATE(CLK_SCLK_MMC0, "sclk_mmc0", "dout_sclk_mmc0",
+                       ENABLE_SCLK_TOP1_FSYS1, 28, CLK_IGNORE_UNUSED, 0),
+
+       GATE(CLK_SCLK_PHY_FSYS1_26M, "sclk_phy_fsys1_26m",
+                       "dout_sclk_phy_fsys1_26m",
+                       ENABLE_SCLK_TOP1_FSYS11, 24, CLK_IGNORE_UNUSED, 0),
+};
+
+static struct samsung_fixed_factor_clock top1_fixed_factor_clks[] __initdata = 
{
+       FFACTOR(0, "ffac_top1_bus0_pll_div2", "mout_top1_bus0_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top1_bus1_pll_div2", "mout_top1_bus1_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top1_cc_pll_div2", "mout_top1_cc_pll", 1, 2, 0),
+       FFACTOR(0, "ffac_top1_mfc_pll_div2", "mout_top1_mfc_pll", 1, 2, 0),
+};
+
+static void __init exynos7_clk_top1_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = top1_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(top1_mux_clks);
+       cmu.div_clks = top1_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(top1_div_clks);
+       cmu.gate_clks = top1_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(top1_gate_clks);
+       cmu.fixed_factor_clks = top1_fixed_factor_clks;
+       cmu.nr_fixed_factor_clks = ARRAY_SIZE(top1_fixed_factor_clks);
+       cmu.nr_clk_ids = TOP1_NR_CLK;
+       cmu.clk_regs = top1_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(top1_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_top1, "samsung,exynos7-clock-top1",
+               exynos7_clk_top1_init);
+
+/* Register Offset definitions for CMU_CCORE (0x105B0000) */
+#define        MUX_SEL_CCORE                   0x0200
+#define        DIV_CCORE                       0x0600
+#define        ENABLE_ACLK_CCORE0              0x0800
+#define        ENABLE_ACLK_CCORE1              0x0804
+#define        ENABLE_PCLK_CCORE               0x0900
+
+/*
+ * List of parent clocks for Muxes in CMU_CCORE
+ */
+PNAME(mout_aclk_ccore_532_p)   = { "fin_pll", "aclk_ccore_532" };
+PNAME(mout_aclk_ccore_133_p)   = { "fin_pll", "aclk_ccore_133" };
+
+static unsigned long ccore_clk_regs[] __initdata = {
+       MUX_SEL_CCORE,
+       DIV_CCORE,
+       ENABLE_ACLK_CCORE0,
+       ENABLE_ACLK_CCORE1,
+       ENABLE_PCLK_CCORE,
+};
+
+static struct samsung_mux_clock ccore_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_ccore_532_user",
+                       mout_aclk_ccore_532_p,
+                       MUX_SEL_CCORE, 0, 1),
+       MUX(0, "mout_aclk_ccore_133_user",
+                       mout_aclk_ccore_133_p,
+                       MUX_SEL_CCORE, 1, 1),
+};
+
+struct samsung_div_clock ccore_div_clks[] __initdata = {
+       DIV(0, "dout_aclk_ccore_266", "mout_aclk_ccore_532_user",
+                       DIV_CCORE, 0, 3),
+};
+
+static struct samsung_gate_clock ccore_gate_clks[] __initdata = {
+       GATE(PCLK_RTC, "pclk_rtc", "mout_aclk_ccore_133_user",
+                       ENABLE_PCLK_CCORE, 8, 0, 0),
+};
+
+static void __init exynos7_clk_ccore_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = ccore_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(ccore_mux_clks);
+       cmu.div_clks = ccore_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(ccore_div_clks);
+       cmu.gate_clks = ccore_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(ccore_gate_clks);
+       cmu.nr_clk_ids = CCORE_NR_CLK;
+       cmu.clk_regs = ccore_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(ccore_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_ccore, "samsung,exynos7-clock-ccore",
+               exynos7_clk_ccore_init);
+
+/* Register Offset definitions for CMU_PERIC0 (0x13610000) */
+#define        MUX_SEL_PERIC0                  0x0200
+#define        ENABLE_PCLK_PERIC0              0x0900
+#define        ENABLE_SCLK_PERIC0              0x0A00
+
+/* List of parent clocks for Muxes in CMU_PERIC0 */
+PNAME(mout_aclk_peric0_66_p)   = { "fin_pll", "aclk_peric0_66" };
+PNAME(mout_sclk_uart0_p)       = { "fin_pll", "sclk_uart0" };
+
+static unsigned long peric0_clk_regs[] __initdata = {
+       MUX_SEL_PERIC0,
+       ENABLE_PCLK_PERIC0,
+       ENABLE_SCLK_PERIC0,
+};
+
+static struct samsung_mux_clock peric0_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_peric0_66_user",
+                       mout_aclk_peric0_66_p, MUX_SEL_PERIC0, 0, 1),
+       MUX(0, "mout_sclk_uart0_user", mout_sclk_uart0_p,
+                       MUX_SEL_PERIC0, 16, 1),
+};
+
+static struct samsung_gate_clock peric0_gate_clks[] __initdata = {
+       GATE(PCLK_HSI2C0, "pclk_hsi2c0", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 8, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C1, "pclk_hsi2c1", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 9, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C4, "pclk_hsi2c4", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 10, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C5, "pclk_hsi2c5", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 11, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C9, "pclk_hsi2c9", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 12, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C10, "pclk_hsi2c10", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 13, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_HSI2C11, "pclk_hsi2c11", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 14, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_UART0, "pclk_uart0", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_ADCIF, "plk_adcif", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 20, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_PWM, "pclk_pwm", "mout_aclk_peric0_66_user",
+                       ENABLE_PCLK_PERIC0, 21, CLK_IGNORE_UNUSED, 0),
+
+       GATE(SCLK_UART0, "sclk_uart0_user", "mout_sclk_uart0_user",
+                       ENABLE_SCLK_PERIC0, 16, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_PWM, "sclk_pwm", "fin_pll",
+                       ENABLE_SCLK_PERIC0, 21, CLK_IGNORE_UNUSED, 0),
+};
+
+static void __init exynos7_clk_peric0_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = peric0_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(peric0_mux_clks);
+       cmu.gate_clks = peric0_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(peric0_gate_clks);
+       cmu.nr_clk_ids = PERIC0_NR_CLK;
+       cmu.clk_regs = peric0_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(peric0_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+/* Register Offset definitions for CMU_PERIC1 (0x14C80000) */
+#define        MUX_SEL_PERIC10                 0x0200
+#define        MUX_SEL_PERIC11                 0x0204
+#define        ENABLE_PCLK_PERIC1              0x0900
+#define        ENABLE_SCLK_PERIC10             0x0A00
+#define        ENABLE_SCLK_PERIC11             0x0A04
+
+CLK_OF_DECLARE(exynos7_clk_peric0, "samsung,exynos7-clock-peric0",
+               exynos7_clk_peric0_init);
+
+/* List of parent clocks for Muxes in CMU_PERIC1 */
+PNAME(mout_aclk_peric1_66_p)   = { "fin_pll", "aclk_peric1_66" };
+PNAME(mout_sclk_uart1_p)       = { "fin_pll", "sclk_uart1" };
+PNAME(mout_sclk_uart2_p)       = { "fin_pll", "sclk_uart2" };
+PNAME(mout_sclk_uart3_p)       = { "fin_pll", "sclk_uart3" };
+PNAME(mout_sclk_spi0_p)                = { "fin_pll", "sclk_spi0" };
+PNAME(mout_sclk_spi1_p)                = { "fin_pll", "sclk_spi1" };
+PNAME(mout_sclk_spi2_p)                = { "fin_pll", "sclk_spi2" };
+PNAME(mout_sclk_spi3_p)                = { "fin_pll", "sclk_spi3" };
+PNAME(mout_sclk_spi4_p)                = { "fin_pll", "sclk_spi4" };
+
+/* fixed rate clocks used in the PERIC1 block */
+struct samsung_fixed_rate_clock fixed_rate_clks_peric1[] __initdata = {
+       FRATE(0, "ioclk_i2s1_bclk", NULL, CLK_IS_ROOT, 25000000),
+       FRATE(0, "ioclk_spi0_clk", NULL, CLK_IS_ROOT, 100000000),
+       FRATE(0, "ioclk_spi1_clk", NULL, CLK_IS_ROOT, 100000000),
+       FRATE(0, "ioclk_spi2_clk", NULL, CLK_IS_ROOT, 100000000),
+       FRATE(0, "ioclk_spi3_clk", NULL, CLK_IS_ROOT, 100000000),
+       FRATE(0, "ioclk_spi4_clk", NULL, CLK_IS_ROOT, 100000000),
+};
+
+static unsigned long peric1_clk_regs[] __initdata = {
+       MUX_SEL_PERIC10,
+       MUX_SEL_PERIC11,
+       ENABLE_PCLK_PERIC1,
+       ENABLE_SCLK_PERIC10,
+       ENABLE_SCLK_PERIC11,
+};
+
+static struct samsung_mux_clock peric1_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_peric1_66_user",
+               mout_aclk_peric1_66_p, MUX_SEL_PERIC10, 0, 1),
+
+       MUX(0, "mout_sclk_spi0_user", mout_sclk_spi0_p, MUX_SEL_PERIC11, 0, 1),
+       MUX(0, "mout_sclk_spi1_user", mout_sclk_spi1_p, MUX_SEL_PERIC11, 4, 1),
+       MUX(0, "mout_sclk_spi2_user", mout_sclk_spi2_p, MUX_SEL_PERIC11, 8, 1),
+       MUX(0, "mout_sclk_spi3_user", mout_sclk_spi3_p, MUX_SEL_PERIC11, 12, 1),
+       MUX(0, "mout_sclk_spi4_user", mout_sclk_spi4_p, MUX_SEL_PERIC11, 16, 1),
+       MUX(0, "mout_sclk_uart1_user", mout_sclk_uart1_p,
+                       MUX_SEL_PERIC11, 20, 1),
+       MUX(0, "mout_sclk_uart2_user", mout_sclk_uart2_p,
+                       MUX_SEL_PERIC11, 24, 1),
+       MUX(0, "mout_sclk_uart3_user", mout_sclk_uart3_p,
+                       MUX_SEL_PERIC11, 28, 1),
+};
+
+static struct samsung_gate_clock peric1_gate_clks[] __initdata = {
+       GATE(PCLK_HSI2C2, "pclk_hsi2c2", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 4, 0, 0),
+       GATE(PCLK_HSI2C3, "pclk_hsi2c3", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 5, 0, 0),
+       GATE(PCLK_HSI2C6, "pclk_hsi2c6", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 6, 0, 0),
+       GATE(PCLK_HSI2C7, "pclk_hsi2c7", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 7, 0, 0),
+       GATE(PCLK_HSI2C8, "pclk_hsi2c8", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 8, 0, 0),
+       GATE(PCLK_UART1, "pclk_uart1", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 9, 0, 0),
+       GATE(PCLK_UART2, "pclk_uart2", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 10, CLK_IGNORE_UNUSED, 0),
+       GATE(PCLK_UART3, "pclk_uart3", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 11, 0, 0),
+       GATE(PCLK_SPI0, "pclk_spi0", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 12, 0, 0),
+       GATE(PCLK_SPI1, "pclk_spi1", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 13, 0, 0),
+       GATE(PCLK_SPI2, "pclk_spi2", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 14, 0, 0),
+       GATE(PCLK_SPI3, "pclk_spi3", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 15, 0, 0),
+       GATE(PCLK_SPI4, "pclk_spi4", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 16, 0, 0),
+       GATE(PCLK_I2S1, "pclk_i2s1", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 17, 0, 0),
+       GATE(PCLK_PCM1, "pclk_pcm1", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 18, 0, 0),
+       GATE(PCLK_SPDIF, "pclk_spdif", "mout_aclk_peric1_66_user",
+                       ENABLE_PCLK_PERIC1, 19, 0, 0),
+
+       GATE(SCLK_UART1, "sclk_uart1_user", "mout_sclk_uart1_user",
+                       ENABLE_SCLK_PERIC10, 9, 0, 0),
+       GATE(SCLK_UART2, "sclk_uart2_user", "mout_sclk_uart2_user",
+                       ENABLE_SCLK_PERIC10, 10, CLK_IGNORE_UNUSED, 0),
+       GATE(SCLK_UART3, "sclk_uart3_user", "mout_sclk_uart3_user",
+                       ENABLE_SCLK_PERIC10, 11, 0, 0),
+       GATE(SCLK_SPI0, "sclk_spi0_user", "mout_sclk_spi0_user",
+                       ENABLE_SCLK_PERIC10, 12, 0, 0),
+       GATE(SCLK_SPI1, "sclk_spi1_user", "mout_sclk_spi1_user",
+                       ENABLE_SCLK_PERIC10, 13, 0, 0),
+       GATE(SCLK_SPI2, "sclk_spi2_user", "mout_sclk_spi2_user",
+                       ENABLE_SCLK_PERIC10, 14, 0, 0),
+       GATE(SCLK_SPI3, "sclk_spi3_user", "mout_sclk_spi3_user",
+                       ENABLE_SCLK_PERIC10, 15, 0, 0),
+       GATE(SCLK_SPI4, "sclk_spi4_user", "mout_sclk_spi4_user",
+                       ENABLE_SCLK_PERIC10, 16, 0, 0),
+       GATE(SCLK_I2S1, "sclk_i2s1_user", "dout_sclk_i2s1",
+                       ENABLE_SCLK_PERIC10, 17, 0, 0),
+       GATE(SCLK_PCM1, "sclk_pcm1_user", "dout_sclk_pcm1",
+                       ENABLE_SCLK_PERIC10, 18, 0, 0),
+       GATE(SCLK_SPDIF, "sclk_spdif_user", "dout_sclk_spdif",
+                       ENABLE_SCLK_PERIC10, 19, 0, 0),
+
+       GATE(IOCLK_SPI0_CLK, "ioclk_spi0", "dout_sclk_spi0",
+                       ENABLE_SCLK_PERIC11, 12, 0, 0),
+       GATE(IOCLK_SPI1_CLK, "ioclk_spi1", "dout_sclk_spi1",
+                       ENABLE_SCLK_PERIC11, 13, 0, 0),
+       GATE(IOCLK_SPI2_CLK, "ioclk_spi2", "dout_sclk_spi2",
+                       ENABLE_SCLK_PERIC11, 14, 0, 0),
+       GATE(IOCLK_SPI3_CLK, "ioclk_spi3", "dout_sclk_spi3",
+                       ENABLE_SCLK_PERIC11, 15, 0, 0),
+       GATE(IOCLK_SPI4_CLK, "ioclk_spi4", "dout_sclk_spi4",
+                       ENABLE_SCLK_PERIC11, 16, 0, 0),
+       GATE(IOCLK_I2S1_BCLK, "ioclk_i2s1", "dout_sclk_i2s1",
+                       ENABLE_SCLK_PERIC11, 17, 0, 0),
+};
+
+static void __init exynos7_clk_peric1_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.fixed_clks = fixed_rate_clks_peric1;
+       cmu.nr_fixed_clks = ARRAY_SIZE(fixed_rate_clks_peric1);
+       cmu.mux_clks = peric1_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(peric1_mux_clks);
+       cmu.gate_clks = peric1_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(peric1_gate_clks);
+       cmu.nr_clk_ids = PERIC1_NR_CLK;
+       cmu.clk_regs = peric1_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(peric1_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_peric1, "samsung,exynos7-clock-peric1",
+               exynos7_clk_peric1_init);
+
+/* Register Offset definitions for CMU_PERIS (0x10040000) */
+#define        MUX_SEL_PERIS                   0x0200
+#define        ENABLE_PCLK_PERIS               0x0900
+#define ENABLE_PCLK_PERIS_SECURE_CHIPID        0x0910
+#define        ENABLE_SCLK_PERIS               0x0A00
+#define ENABLE_SCLK_PERIS_SECURE_CHIPID        0x0A10
+
+/* List of parent clocks for Muxes in CMU_PERIS */
+PNAME(mout_aclk_peris_66_p)    = { "fin_pll", "aclk_peris_66" };
+
+static unsigned long peris_clk_regs[] __initdata = {
+       MUX_SEL_PERIS,
+       ENABLE_PCLK_PERIS,
+       ENABLE_SCLK_PERIS,
+       ENABLE_PCLK_PERIS_SECURE_CHIPID,
+       ENABLE_SCLK_PERIS_SECURE_CHIPID,
+};
+
+static struct samsung_mux_clock peris_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_peris_66_user",
+               mout_aclk_peris_66_p, MUX_SEL_PERIS, 0, 1),
+};
+
+static struct samsung_gate_clock peris_gate_clks[] __initdata = {
+       GATE(PCLK_MCT, "pclk_mct", "mout_aclk_peris_66_user",
+                       ENABLE_PCLK_PERIS, 5, 0, 0),
+       GATE(PCLK_WDT_ATLAS, "pclk_wdt_atlas", "mout_aclk_peris_66_user",
+                       ENABLE_PCLK_PERIS, 6, 0, 0),
+       GATE(PCLK_SYSREG, "pclk_sysreg", "mout_aclk_peris_66_user",
+                       ENABLE_PCLK_PERIS, 9, 0, 0),
+       GATE(PCLK_TMU, "pclk_tmu_apbif", "mout_aclk_peris_66_user",
+                       ENABLE_PCLK_PERIS, 10, 0, 0),
+
+       GATE(PCLK_CHIPID, "pclk_chipid", "mout_aclk_peris_66_user",
+                       ENABLE_PCLK_PERIS_SECURE_CHIPID, 0, 0, 0),
+
+       GATE(SCLK_TMU, "sclk_tmu", "fin_pll",
+                       ENABLE_SCLK_PERIS, 10, 0, 0),
+
+       GATE(SCLK_CHIPID, "sclk_chipid", "fin_pll",
+                       ENABLE_SCLK_PERIS_SECURE_CHIPID, 0, 0, 0),
+};
+
+static void __init exynos7_clk_peris_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = peris_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(peris_mux_clks);
+       cmu.gate_clks = peris_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(peris_gate_clks);
+       cmu.nr_clk_ids = PERIS_NR_CLK;
+       cmu.clk_regs = peris_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(peris_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_peris, "samsung,exynos7-clock-peris",
+               exynos7_clk_peris_init);
+
+/* Register Offset definitions for CMU_BUS0 (0x13400000) */
+#define        MUX_SEL_BUS0                    0x0200
+#define        DIV_BUS0                        0x0600
+#define        ENABLE_ACLK_BUS0                0x0800
+#define        ENABLE_PCLK_BUS0                0x0900
+
+/* List of parent clocks for Muxes in CMU_BUS0 */
+PNAME(mout_aclk_bus0_532_user_p)       = { "fin_pll", "aclk_bus0_532" };
+
+static unsigned long bus0_clk_regs[] __initdata = {
+       MUX_SEL_BUS0,
+       DIV_BUS0,
+       ENABLE_PCLK_BUS0,
+};
+
+static struct samsung_mux_clock bus0_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_bus0_532_user",
+               mout_aclk_bus0_532_user_p, MUX_SEL_BUS0, 0, 1),
+};
+
+static struct samsung_div_clock bus0_div_clks[] __initdata = {
+       DIV(0, "dout_pclk_bus0_133", "mout_aclk_bus0_532_user", DIV_BUS0, 0, 3),
+};
+
+static struct samsung_gate_clock bus0_gate_clks[] __initdata = {
+       GATE(ACLK_LH_DISP0, "aclk_lh_disp0", "dout_pclk_bus0_532",
+               ENABLE_ACLK_BUS0, 3, 0, 0),
+       GATE(ACLK_LH_DISP1, "aclk_lh_disp1", "dout_pclk_bus0_532",
+               ENABLE_ACLK_BUS0, 4, 0, 0),
+       GATE(PCLK_GPIO_BUS0, "pclk_gpio_bus0", "dout_pclk_bus0_133",
+               ENABLE_PCLK_BUS0, 13, 0, 0),
+};
+
+static void __init exynos7_clk_bus0_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = bus0_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(bus0_mux_clks);
+       cmu.div_clks = bus0_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(bus0_div_clks);
+       cmu.gate_clks = bus0_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(bus0_gate_clks);
+       cmu.nr_clk_ids = BUS0_NR_CLK;
+       cmu.clk_regs = bus0_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(bus0_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_bus0, "samsung,exynos7-clock-bus0",
+               exynos7_clk_bus0_init);
+
+/* Register Offset definitions for CMU_BUS1 (0x14800000) */
+#define        MUX_SEL_BUS1                    0x0200
+#define        DIV_BUS1                        0x0600
+#define        ENABLE_ACLK_BUS1                0x0800
+#define        ENABLE_PCLK_BUS1                0x0900
+
+/* List of parent clocks for Muxes in CMU_BUS1 */
+PNAME(mout_aclk_bus1_532_p)    = { "fin_pll", "aclk_bus1_532" };
+PNAME(mout_aclk_bus1_200_p)    = { "fin_pll", "aclk_bus1_200" };
+
+static unsigned long bus1_clk_regs[] __initdata = {
+       MUX_SEL_BUS1,
+       DIV_BUS1,
+       ENABLE_PCLK_BUS1,
+};
+
+static struct samsung_mux_clock bus1_mux_clks[] __initdata = {
+       MUX(0, "mout_aclk_bus1_532_user",
+                       mout_aclk_bus1_532_p, MUX_SEL_BUS1, 0, 1),
+       MUX(0, "mout_aclk_bus1_200_user",
+                       mout_aclk_bus1_200_p, MUX_SEL_BUS1, 4, 1),
+};
+
+static struct samsung_div_clock bus1_div_clks[] __initdata = {
+       DIV(0, "dout_pclk_bus1_133", "mout_aclk_bus1_532_user", DIV_BUS1, 0, 3),
+};
+
+static struct samsung_gate_clock bus1_gate_clks[] __initdata = {
+       GATE(PCLK_GPIO_BUS1, "pclk_gpio_bus1", "dout_pclk_bus1_133",
+                       ENABLE_PCLK_BUS1, 27, 0, 0),
+};
+
+static void __init exynos7_clk_bus1_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.mux_clks = bus1_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(bus1_mux_clks);
+       cmu.div_clks = bus1_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(bus1_div_clks);
+       cmu.gate_clks = bus1_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(bus1_gate_clks);
+       cmu.nr_clk_ids = BUS1_NR_CLK;
+       cmu.clk_regs = bus1_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(bus1_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_bus1, "samsung,exynos7-clock-bus1",
+               exynos7_clk_bus1_init);
+
+/* Register Offset definitions for CMU_FSYS0 (0x10E90000) */
+#define        HSIC_PLL_LOCK                   0x0000
+#define        HSIC_PLL_CON0                   0x0100
+#define        HSIC_PLL_CON1                   0x0104
+#define        MUX_SEL_FSYS00                  0x0200
+#define        MUX_SEL_FSYS01                  0x0204
+#define        MUX_SEL_FSYS02                  0x0208
+#define        MUX_SEL_FSYS03                  0x020C
+#define        DIV_FSYS0                       0x0600
+#define        ENABLE_ACLK_FSYS00              0x0800
+#define        ENABLE_ACLK_FSYS01              0x0804
+#define        ENABLE_PCLK_FSYS0               0x0900
+#define        ENABLE_SCLK_FSYS01              0x0A04
+#define        ENABLE_SCLK_FSYS02              0x0A08
+#define        ENABLE_SCLK_FSYS03              0x0A0C
+#define        ENABLE_SCLK_FSYS04              0x0A10
+
+/*
+ * List of parent clocks for Muxes in CMU_FSYS0
+ */
+PNAME(mout_hsic_pll_ctrl_p) = { "fin_pll", "fout_hsic_pll" };
+
+PNAME(mout_aclk_fsys0_200_p)   = { "fin_pll", "aclk_fsys0_200" };
+PNAME(mout_fsys0_group_p)      = { "fin_pll", "fin_pll_26m",
+                               "sclk_phy_fsys0_26m" };
+
+PNAME(mout_sclk_usbdrd300_p)   = { "fin_pll", "sclk_usbdrd300" };
+PNAME(mout_sclk_mmc2_p)                = { "fin_pll", "sclk_mmc2" };
+PNAME(mout_sclk_ufsunipro11_p) = { "fin_pll", "sclk_ufsunipro11" };
+PNAME(mout_sclk_phy_fsys0_p)   = { "fin_pll", "sclk_phy_fsys0" };
+
+
+PNAME(mout_phyclk_usbdrd300_udrd30_phyclk_p)   = { "fin_pll",
+                               "phyclk_usbdrd300_udrd30_phyclock" };
+PNAME(mout_phyclk_usbdrd300_udrd30_pipe_pclk_p)        = { "fin_pll",
+                               "phyclk_usbdrd300_udrd30_pipe_pclk" };
+PNAME(mout_phyclk_usbhost20_phy_freeclk_hsic1_p) = { "fin_pll",
+                               "phyclk_usbhost20_phy_freeclk_hsic1" };
+PNAME(mout_phyclk_usbhost20_phy_phyclk_hsic1_p)        = { "fin_pll",
+                               "phyclk_usbhost20_phy_phyclk_hsic1" };
+
+PNAME(mout_phyclk_ufs_tx0_p) = { "fin_pll", "phyclk_ufs_tx0_symbol" };
+PNAME(mout_phyclk_ufs_rx0_p) = { "fin_pll", "phyclk_ufs_rx0_symbol" };
+PNAME(mout_phyclk_lli_tx0_p) = { "fin_pll", "phyclk_lli_tx0_symbol" };
+PNAME(mout_phyclk_lli_rx0_p) = { "fin_pll", "phyclk_lli_rx0_symbol" };
+PNAME(mout_phyclk_pcie_tx0_p) = { "fin_pll", "phyclk_pcie_tx0" };
+PNAME(mout_phyclk_pcie_rx0_p) = { "fin_pll", "phyclk_pcie_rx0" };
+
+/* fixed rate clocks used in the FSYS0 block */
+struct samsung_fixed_rate_clock fixed_rate_clks_fsys0[] __initdata = {
+       FRATE(0, "phyclk_lli_rx0_symbol", NULL, CLK_IS_ROOT, 150000000),
+       FRATE(0, "phyclk_lli_tx0_symbol", NULL, CLK_IS_ROOT, 150000000),
+       FRATE(0, "phyclk_usbhost20_phy_phyclk_hsic1",
+               NULL, CLK_IS_ROOT, 60000000),
+       FRATE(0, "phyclk_usbhost20_phy_freeclk_hsic1",
+               NULL, CLK_IS_ROOT, 60000000),
+       FRATE(0, "phyclk_usbdrd300_udrd30_pipe_pclk",
+               NULL, CLK_IS_ROOT, 125000000),
+       FRATE(0, "phyclk_usbdrd300_udrd30_phyclock",
+               NULL, CLK_IS_ROOT, 60000000),
+};
+
+static unsigned long fsys0_clk_regs[] __initdata = {
+       MUX_SEL_FSYS00,
+       MUX_SEL_FSYS01,
+       MUX_SEL_FSYS02,
+       MUX_SEL_FSYS03,
+       DIV_FSYS0,
+       ENABLE_ACLK_FSYS00,
+       ENABLE_ACLK_FSYS01,
+       ENABLE_PCLK_FSYS0,
+       ENABLE_SCLK_FSYS01,
+       ENABLE_SCLK_FSYS02,
+       ENABLE_SCLK_FSYS03,
+       ENABLE_SCLK_FSYS04,
+};
+
+static struct samsung_mux_clock fsys0_mux_clks[] __initdata = {
+       MUX(0, "mout_fsys0_phyclk_sel1", mout_fsys0_group_p,
+                       MUX_SEL_FSYS00, 16, 2),
+       MUX(0, "mout_fsys0_phyclk_sel0", mout_fsys0_group_p,
+                       MUX_SEL_FSYS00, 20, 2),
+       MUX(0, "mout_aclk_fsys0_200_user", mout_aclk_fsys0_200_p,
+                       MUX_SEL_FSYS00, 24, 1),
+       MUX(0, "mout_hsic_pll_ctrl", mout_hsic_pll_ctrl_p,
+                       MUX_SEL_FSYS00, 28, 1),
+
+       MUX(0, "mout_sclk_phy_fsys0_user", mout_sclk_phy_fsys0_p,
+                       MUX_SEL_FSYS01, 16, 1),
+       MUX(0, "mout_sclk_ufsunipro11_user", mout_sclk_ufsunipro11_p,
+                       MUX_SEL_FSYS01, 20, 1),
+       MUX(0, "mout_sclk_mmc2_user", mout_sclk_mmc2_p,
+                       MUX_SEL_FSYS01, 24, 1),
+       MUX(0, "mout_sclk_usbdrd300_user", mout_sclk_usbdrd300_p,
+                       MUX_SEL_FSYS01, 28, 1),
+
+       MUX(0, "mout_phyclk_usbhost20_phy_phyclk_hsic1_user",
+                       mout_phyclk_usbhost20_phy_phyclk_hsic1_p,
+                       MUX_SEL_FSYS02, 16, 1),
+       MUX(0, "mout_phyclk_usbhost20_phy_freeclk_hsic1_user",
+                       mout_phyclk_usbhost20_phy_freeclk_hsic1_p,
+                       MUX_SEL_FSYS02, 20, 1),
+       MUX(0, "mout_phyclk_usbdrd300_udrd30_pipe_pclk_user",
+                       mout_phyclk_usbdrd300_udrd30_pipe_pclk_p,
+                       MUX_SEL_FSYS02, 24, 1),
+       MUX(0, "mout_phyclk_usbdrd300_udrd30_phyclk_user",
+                       mout_phyclk_usbdrd300_udrd30_phyclk_p,
+                       MUX_SEL_FSYS02, 28, 1),
+
+       MUX(0, "mout_phyclk_pcie_rx0_user", mout_phyclk_pcie_rx0_p,
+                       MUX_SEL_FSYS03, 8, 1),
+       MUX(0, "mout_phyclk_pcie_tx0_user", mout_phyclk_pcie_tx0_p,
+                       MUX_SEL_FSYS03, 12, 1),
+       MUX(0, "mout_phyclk_lli_rx0_user", mout_phyclk_lli_rx0_p,
+                       MUX_SEL_FSYS03, 16, 1),
+       MUX(0, "mout_phyclk_lli_tx0_user", mout_phyclk_lli_tx0_p,
+                       MUX_SEL_FSYS03, 20, 1),
+       MUX(0, "mout_phyclk_ufs_rx0_user", mout_phyclk_ufs_rx0_p,
+                       MUX_SEL_FSYS03, 24, 1),
+       MUX(0, "mout_phyclk_ufs_tx0_user", mout_phyclk_ufs_tx0_p,
+                       MUX_SEL_FSYS03, 28, 1),
+};
+
+static struct samsung_div_clock fsys0_div_clks[] __initdata = {
+       DIV(0, "dout_pclk_fsys0", "mout_aclk_fsys0_200_user", DIV_FSYS0, 0, 2),
+       DIV(0, "dout_usb20", "mout_hsic_pll", DIV_FSYS0, 4, 4),
+};
+
+static struct samsung_gate_clock fsys0_gate_clks[] __initdata = {
+       GATE(ACLK_USBHOST20, "aclk_usbhost20", "mout_aclk_fsys0_200_user",
+                       ENABLE_ACLK_FSYS01, 28, 0, 0),
+       GATE(ACLK_USBDRD300, "aclk_usbdrd300", "mout_aclk_fsys0_200_user",
+                       ENABLE_ACLK_FSYS01, 29, 0, 0),
+       GATE(ACLK_UFS11_LINK, "aclk_ufs11_link", "dout_pclk_fsys0",
+                       ENABLE_ACLK_FSYS01, 30, 0, 0),
+       GATE(ACLK_MMC2, "aclk_mmc2", "mout_aclk_fsys0_200_user",
+                       ENABLE_ACLK_FSYS01, 31, 0, 0),
+
+       GATE(PCLK_GPIO_FSYS0, "pclk_gpio_fsys0", "mout_aclk_fsys0_200_user",
+                       ENABLE_PCLK_FSYS0, 24, 0, 0),
+
+       GATE(SCLK_MMC2, "sclk_mmc2_user", "mout_sclk_mmc2_user",
+                       ENABLE_SCLK_FSYS01, 24, 0, 0),
+};
+
+static struct samsung_pll_clock fsys0_pll_clks[] __initdata = {
+       PLL(pll_1452x, 0, "fout_hsic_pll", "fin_pll",
+                       HSIC_PLL_LOCK, HSIC_PLL_CON0, pll1452x_24mhz_tbl),
+};
+
+static void __init exynos7_clk_fsys0_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.pll_clks = fsys0_pll_clks;
+       cmu.nr_pll_clks = ARRAY_SIZE(fsys0_pll_clks);
+       cmu.fixed_clks = fixed_rate_clks_fsys0;
+       cmu.nr_fixed_clks = ARRAY_SIZE(fixed_rate_clks_fsys0);
+       cmu.mux_clks = fsys0_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(fsys0_mux_clks);
+       cmu.div_clks = fsys0_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(fsys0_div_clks);
+       cmu.gate_clks = fsys0_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(fsys0_gate_clks);
+       cmu.nr_clk_ids = FSYS0_NR_CLK;
+       cmu.clk_regs = fsys0_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(fsys0_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_fsys0, "samsung,exynos7-clock-fsys0",
+               exynos7_clk_fsys0_init);
+
+/* Register Offset definitions for CMU_FSYS1 (0x156E0000) */
+#define        MUX_SEL_FSYS10                  0x0200
+#define        MUX_SEL_FSYS11                  0x0204
+#define        MUX_SEL_FSYS12                  0x0208
+#define        DIV_FSYS1                       0x0600
+#define        ENABLE_ACLK_FSYS1               0x0800
+#define        ENABLE_PCLK_FSYS1               0x0900
+#define        ENABLE_SCLK_FSYS11              0x0A04
+#define        ENABLE_SCLK_FSYS12              0x0A08
+#define        ENABLE_SCLK_FSYS13              0x0A0C
+
+/*
+ * List of parent clocks for Muxes in CMU_FSYS1
+ */
+PNAME(mout_aclk_fsys1_200_p)   = { "fin_pll", "aclk_fsys1_200" };
+PNAME(mout_fsys1_group_p)      = { "fin_pll", "fin_pll_26m",
+                               "sclk_phy_fsys1_26m" };
+
+PNAME(mout_sclk_mmc0_p)                = { "fin_pll", "sclk_mmc0" };
+PNAME(mout_sclk_mmc1_p)                = { "fin_pll", "sclk_mmc1" };
+PNAME(mout_sclk_ufsunipro20_p) = { "fin_pll", "sclk_ufsunipro20" };
+PNAME(mout_sclk_phy_fsys1_p)   = { "fin_pll", "sclk_phy_fsys1" };
+PNAME(mout_sclk_tlx400_wifi1_p)        = { "fin_pll", "sclk_tlx400_wifi1" };
+
+PNAME(mout_phyclk_ufs20_tx0_p) = { "fin_pll", "phyclk_ufs20_tx0_symbol" };
+PNAME(mout_phyclk_ufs20_rx0_p) = { "fin_pll", "phyclk_ufs20_rx0_symbol" };
+PNAME(mout_phyclk_ufs20_rx1_p) = { "fin_pll", "phyclk_ufs20_rx1_symbol" };
+
+PNAME(mout_phyclk_pcie_wifi1_tx0_p) = { "fin_pll", "phyclk_pcie_wifi1_tx0" };
+PNAME(mout_phyclk_pcie_wifi1_rx0_p) = { "fin_pll", "phyclk_pcie_wifi1_rx0" };
+
+/* fixed rate clocks used in the FSYS1 block */
+struct samsung_fixed_rate_clock fixed_rate_clks_fsys1[] __initdata = {
+       FRATE(PHYCLK_UFS_TX0_SYMBOL, "phyclk_ufs_tx0_symbol",
+                       NULL, CLK_IS_ROOT, 300000000),
+       FRATE(PHYCLK_UFS_RX0_SYMBOL, "phyclk_ufs_rx0_symbol",
+                       NULL, CLK_IS_ROOT, 300000000),
+       FRATE(PHYCLK_UFS20_TX0_SYMBOL, "phyclk_ufs20_tx0_symbol",
+                       NULL, CLK_IS_ROOT, 300000000),
+       FRATE(PHYCLK_UFS20_RX0_SYMBOL, "phyclk_ufs20_rx0_symbol",
+                       NULL, CLK_IS_ROOT, 300000000),
+       FRATE(PHYCLK_UFS20_RX1_SYMBOL, "phyclk_ufs20_rx1_symbol",
+                       NULL, CLK_IS_ROOT, 300000000),
+};
+
+static unsigned long fsys1_clk_regs[] __initdata = {
+       MUX_SEL_FSYS10,
+       MUX_SEL_FSYS11,
+       MUX_SEL_FSYS12,
+       DIV_FSYS1,
+       ENABLE_ACLK_FSYS1,
+       ENABLE_PCLK_FSYS1,
+       ENABLE_SCLK_FSYS11,
+       ENABLE_SCLK_FSYS12,
+       ENABLE_SCLK_FSYS13,
+};
+
+static struct samsung_mux_clock fsys1_mux_clks[] __initdata = {
+       MUX(0, "mout_fsys1_phyclk_sel1", mout_fsys1_group_p,
+                       MUX_SEL_FSYS10, 16, 2),
+       MUX(0, "mout_fsys1_phyclk_sel0", mout_fsys1_group_p,
+                       MUX_SEL_FSYS10, 20, 2),
+       MUX(0, "mout_aclk_fsys1_200_user", mout_aclk_fsys1_200_p,
+                       MUX_SEL_FSYS10, 28, 1),
+
+       MUX(0, "mout_sclk_tlx400_wifi1_user",
+                       mout_sclk_tlx400_wifi1_p, MUX_SEL_FSYS11, 12, 1),
+       MUX(0, "mout_sclk_phy_fsys1_user",
+                       mout_sclk_phy_fsys1_p, MUX_SEL_FSYS11, 16, 1),
+       MUX(0, "mout_sclk_ufsunipro20_user",
+                       mout_sclk_ufsunipro20_p, MUX_SEL_FSYS11, 20, 1),
+       MUX(0, "mout_sclk_mmc1_user", mout_sclk_mmc1_p,
+                       MUX_SEL_FSYS11, 24, 1),
+       MUX(0, "mout_sclk_mmc0_user", mout_sclk_mmc0_p,
+                       MUX_SEL_FSYS11, 28, 1),
+
+       MUX(0, "mout_phyclk_pcie_wifi_rx0_user",
+                       mout_phyclk_pcie_wifi1_rx0_p, MUX_SEL_FSYS12, 8, 1),
+       MUX(0, "mout_phyclk_pcie_wifi_tx0_user",
+                       mout_phyclk_pcie_wifi1_tx0_p, MUX_SEL_FSYS12, 12, 1),
+       MUX(0, "mout_phyclk_ufs20_rx1_user",
+                       mout_phyclk_ufs20_rx1_p, MUX_SEL_FSYS12, 16, 1),
+       MUX(0, "mout_phyclk_ufs20_rx0_user",
+                       mout_phyclk_ufs20_rx0_p, MUX_SEL_FSYS12, 24, 1),
+       MUX(0, "mout_phyclk_ufs20_tx0_user",
+                       mout_phyclk_ufs20_tx0_p, MUX_SEL_FSYS12, 28, 1),
+};
+
+static struct samsung_div_clock fsys1_div_clks[] __initdata = {
+       DIV(0, "dout_pclk_fsys1", "mout_aclk_fsys1_200_user", DIV_FSYS1, 0, 2),
+};
+
+static struct samsung_gate_clock fsys1_gate_clks[] __initdata = {
+       GATE(ACLK_MMC1, "aclk_mmc1", "mout_phyclk_pcie_rx0_user",
+                       ENABLE_ACLK_FSYS1, 29, 0, 0),
+       GATE(ACLK_MMC0, "aclk_mmc0", "mout_phyclk_pcie_rx0_user",
+                       ENABLE_ACLK_FSYS1, 30, 0, 0),
+       GATE(PCLK_GPIO_FSYS1, "pclk_gpio_fsys1", "mout_phyclk_pcie_rx0_user",
+                       ENABLE_PCLK_FSYS1, 31, 0, 0),
+
+       GATE(SCLK_MMC1, "sclk_mmc1_user", "mout_sclk_mmc1_user",
+                       ENABLE_SCLK_FSYS11, 24, 0, 0),
+       GATE(SCLK_MMC0, "sclk_mmc0_user", "mout_sclk_mmc0_user",
+                       ENABLE_SCLK_FSYS11, 28, 0, 0),
+};
+
+static void __init exynos7_clk_fsys1_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.fixed_clks = fixed_rate_clks_fsys1;
+       cmu.nr_fixed_clks = ARRAY_SIZE(fixed_rate_clks_fsys1);
+       cmu.mux_clks = fsys1_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(fsys1_mux_clks);
+       cmu.div_clks = fsys1_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(fsys1_div_clks);
+       cmu.gate_clks = fsys1_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(fsys1_gate_clks);
+       cmu.nr_clk_ids = FSYS1_NR_CLK;
+       cmu.clk_regs = fsys1_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(fsys1_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_fsys1, "samsung,exynos7-clock-fsys1",
+               exynos7_clk_fsys1_init);
+
+/* Register Offset definitions for CMU_DISP (0x13AD0000) */
+#define        DISP_PLL_LOCK                   0x0000
+#define        DISP_PLL_CON0                   0x0100
+#define        DISP_PLL_CON1                   0x0104
+#define        DISP_PLL_CON2                   0x0108
+#define        MUX_SEL_DISP0                   0x0200
+#define        MUX_SEL_DISP1                   0x0204
+#define        MUX_SEL_DISP2                   0x0208
+#define        MUX_SEL_DISP3                   0x020C
+#define        DIV_DISP                        0x0600
+#define        ENABLE_ACLK_DISP                        0x0800
+#define        ENABLE_ACLK_DISP_SECURE_SMMU_RO_MMU     0x0804
+#define        ENABLE_ACLK_DISP_SECURE_SMMU_RW_MMU     0x0808
+#define        ENABLE_ACLK_DISP_SECURE_SMMU_RO_SFW     0x080C
+#define        ENABLE_ACLK_DISP_SECURE_SMMU_RW_SFW     0x0810
+#define        ENABLE_PCLK_DISP                        0x0900
+#define        ENABLE_PCLK_DISP_SECURE_SMMU_RO_MMU     0x0904
+#define        ENABLE_PCLK_DISP_SECURE_SMMU_RW_MMU     0x0908
+#define        ENABLE_PCLK_DISP_SECURE_SMMU_RO_SFW     0x090C
+#define        ENABLE_PCLK_DISP_SECURE_SMMU_RW_SFW     0x0910
+#define        ENABLE_SCLK_DISP1                       0x0A04
+#define        ENABLE_SCLK_DISP2                       0x0A08
+
+/*
+ * List of parent clocks for Muxes in CMU_DISP
+ */
+PNAME(mout_aclk_disp_400_p) = { "fin_pll", "aclk_disp_400" };
+PNAME(mout_disp_pll_ctrl_p) = { "fin_pll", "fout_disp_pll" };
+
+PNAME(mout_sclk_dsd_p) = { "fin_pll", "sclk_dsd" };
+
+PNAME(mout_sclk_decon_int_eclk_p) = { "fin_pll", "sclk_decon_int_eclk" };
+PNAME(mout_sclk_decon_ext_eclk_p) = { "fin_pll", "sclk_decon_ext_eclk" };
+PNAME(mout_sclk_decon_vclk_p) = { "fin_pll", "sclk_decon_vclk" };
+
+PNAME(mout_phyclk_hdmiphy_pixel_clko_p)        = { "fin_pll",
+                                       "phyclk_hdmiphy_clko" };
+PNAME(mout_phyclk_hdmiphy_tmds_clko_p) = { "fin_pll",
+                                       "phyclk_hdmiphy_tmds_clko" };
+PNAME(mout_phyclk_mipidphy0_rxclkesc0_p) = { "fin_pll",
+                                       "phyclk_mipidphy0_rxclkesc0" };
+PNAME(mout_phyclk_mipidphy0_bitclkdiv8_p) = { "fin_pll",
+                                       "phyclk_mipidphy0_bitclkdiv8" };
+PNAME(mout_phyclk_mipidphy1_rxclkesc0_p) = { "fin_pll",
+                                       "phyclk_mipidphy1_rxclkesc0" };
+PNAME(mout_phyclk_mipidphy1_bitclkdiv8_p) = { "fin_pll",
+                                       "phyclk_mipidphy1_bitclkdiv8" };
+
+PNAME(smout_sclk_decon_int_eclk_p) = { "mout_sclk_decon_int_eclk_user",
+                                       "mout_disp_pll_ctrl" };
+PNAME(smout_sclk_decon_ext_eclk_p) = { "mout_sclk_decon_ext_eclk_user",
+                                       "mout_disp_pll_ctrl" };
+PNAME(smout_sclk_decon_int_ext_pll_p) = { "mout_sclk_decon_vclk_user",
+                                       "mout_disp_pll_ctrl" };
+PNAME(smout_sclk_decon_ext_ext_pll_p) = { "mout_sclk_decon_vclk_user",
+                                       "mout_disp_pll_ctrl" };
+
+/* fixed rate clocks used in the DISP block */
+struct samsung_fixed_rate_clock fixed_rate_clks_disp[] __initdata = {
+       FRATE(0, "phyclk_mipidphy0_rxclkesc0", NULL, CLK_IS_ROOT, 20000000),
+       FRATE(0, "phyclk_mipidphy0_bitclkdiv8", NULL, CLK_IS_ROOT, 187500000),
+       FRATE(0, "phyclk_mipidphy1_rxclkesc0", NULL, CLK_IS_ROOT, 20000000),
+       FRATE(0, "phyclk_mipidphy1_bitclkdiv8", NULL, CLK_IS_ROOT, 187500000),
+       FRATE(0, "sclk_rgb_vclk_dsim0", NULL, CLK_IS_ROOT, 300000000),
+       FRATE(0, "sclk_rgb_vclk_dsim1", NULL, CLK_IS_ROOT, 300000000),
+       FRATE(0, "sclk_decon_ext_vclk", NULL, CLK_IS_ROOT, 300000000),
+       FRATE(0, "phyclk_dpphy_ch3_txd_clk", NULL, CLK_IS_ROOT, 270000000),
+       FRATE(0, "phyclk_dpphy_ch2_txd_clk", NULL, CLK_IS_ROOT, 270000000),
+       FRATE(0, "phyclk_dpphy_ch1_txd_clk", NULL, CLK_IS_ROOT, 270000000),
+       FRATE(0, "phyclk_dpphy_ch0_txd_clk", NULL, CLK_IS_ROOT, 270000000),
+       FRATE(0, "phyclk_hdmi_phy_tmds_clko", NULL, CLK_IS_ROOT, 300000000),
+       FRATE(0, "phyclk_hdmi_phy_pixel_clko", NULL, CLK_IS_ROOT, 300000000),
+};
+
+static unsigned long disp_clk_regs[] __initdata = {
+       MUX_SEL_DISP0,
+       MUX_SEL_DISP1,
+       MUX_SEL_DISP2,
+       MUX_SEL_DISP3,
+       DIV_DISP,
+       ENABLE_ACLK_DISP,
+       ENABLE_ACLK_DISP_SECURE_SMMU_RO_MMU,
+       ENABLE_ACLK_DISP_SECURE_SMMU_RW_MMU,
+       ENABLE_ACLK_DISP_SECURE_SMMU_RO_SFW,
+       ENABLE_ACLK_DISP_SECURE_SMMU_RW_SFW,
+       ENABLE_PCLK_DISP,
+       ENABLE_PCLK_DISP_SECURE_SMMU_RO_MMU,
+       ENABLE_PCLK_DISP_SECURE_SMMU_RW_MMU,
+       ENABLE_PCLK_DISP_SECURE_SMMU_RO_SFW,
+       ENABLE_PCLK_DISP_SECURE_SMMU_RW_SFW,
+       ENABLE_SCLK_DISP1,
+       ENABLE_SCLK_DISP2,
+};
+
+static struct samsung_mux_clock disp_mux_clks[] __initdata = {
+       MUX(0, "mout_disp_pll_ctrl", mout_disp_pll_ctrl_p,
+               MUX_SEL_DISP0, 28, 1),
+       MUX(0, "mout_aclk_disp_400_user", mout_aclk_disp_400_p,
+               MUX_SEL_DISP0, 24, 1),
+
+       MUX(0, "mout_sclk_dsd_user", mout_sclk_dsd_p, MUX_SEL_DISP1, 16, 1),
+       MUX(0, "mout_sclk_decon_vclk_user",
+               mout_sclk_decon_vclk_p, MUX_SEL_DISP1, 20, 1),
+       MUX(0, "mout_sclk_decon_ext_eclk_user",
+               mout_sclk_decon_ext_eclk_p, MUX_SEL_DISP1, 24, 1),
+       MUX(0, "mout_sclk_decon_int_eclk_user",
+               mout_sclk_decon_int_eclk_p, MUX_SEL_DISP1, 28, 1),
+
+       MUX(0, "mout_phyclk_mipidphy1_bitclkdiv8",
+               mout_phyclk_mipidphy1_bitclkdiv8_p, MUX_SEL_DISP2, 0, 1),
+       MUX(0, "mout_phyclk_mipidphy1_rxclkesc0",
+               mout_phyclk_mipidphy1_rxclkesc0_p, MUX_SEL_DISP2, 4, 1),
+       MUX(0, "mout_phyclk_mipidphy0_bitclkdiv8",
+               mout_phyclk_mipidphy0_bitclkdiv8_p, MUX_SEL_DISP2, 8, 1),
+       MUX(0, "mout_phyclk_mipidphy0_rxclkesc0",
+               mout_phyclk_mipidphy0_rxclkesc0_p, MUX_SEL_DISP2, 12, 1),
+       MUX(0, "mout_phyclk_hdmiphy_tmds_clko",
+               mout_phyclk_hdmiphy_tmds_clko_p, MUX_SEL_DISP2, 16, 1),
+       MUX(0, "mout_phyclk_hdmiphy_pixel_clko",
+               mout_phyclk_hdmiphy_pixel_clko_p, MUX_SEL_DISP2, 20, 1),
+
+       MUX(0, "smout_sclk_decon_ext_ext_pll",
+               smout_sclk_decon_ext_ext_pll_p, MUX_SEL_DISP3, 8, 1),
+       MUX(0, "smout_sclk_decon_int_ext_pll",
+               smout_sclk_decon_int_ext_pll_p, MUX_SEL_DISP3, 12, 1),
+       MUX(0, "smout_sclk_decon_ext_eclk",
+               smout_sclk_decon_ext_eclk_p, MUX_SEL_DISP3, 16, 1),
+       MUX(0, "smout_sclk_decon_int_eclk",
+               smout_sclk_decon_int_eclk_p, MUX_SEL_DISP3, 20, 1),
+};
+
+static struct samsung_div_clock disp_div_clks[] __initdata = {
+       DIV(0, "dout_pclk_disp", "mout_aclk_disp_400_user", DIV_DISP, 0, 2),
+       DIV(0, "sdout_sclk_decon_ext_extclkpll",
+               "smout_sclk_decon_ext_ext_pll", DIV_DISP, 8, 3),
+       DIV(0, "sdout_sclk_decon_int_extclkpll",
+               "smout_sclk_decon_int_ext_pll", DIV_DISP, 12, 3),
+       DIV(0, "sdout_sclk_decon_ext_eclk",
+               "smout_sclk_decon_ext_eclk", DIV_DISP, 16, 3),
+       DIV(0, "sdout_sclk_decon_int_eclk",
+               "smout_sclk_decon_int_eclk", DIV_DISP, 20, 3),
+};
+
+static struct samsung_gate_clock disp_gate_clks[] __initdata = {
+       GATE(ACLK_CP_DISP, "aclk_cp_disp", "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP, 21, 0, 0),
+       GATE(ACLK_DECON_EXT, "aclk_decon_ext", "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP, 30, 0, 0),
+       GATE(ACLK_DECON_INT, "aclk_decon_int", "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP, 31, 0, 0),
+
+       GATE(ACLK_SMMU_DISP_RO_MMU, "aclk_smmu_disp_ro_mmu",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP_SECURE_SMMU_RO_MMU, 0, 0, 0),
+       GATE(ACLK_SMMU_DISP_RW_MMU, "aclk_smmu_disp_rw_mmu",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP_SECURE_SMMU_RW_MMU, 0, 0, 0),
+       GATE(ACLK_SMMU_DISP_RO_SFW, "aclk_smmu_disp_ro_sfw",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP_SECURE_SMMU_RO_SFW, 0, 0, 0),
+       GATE(ACLK_SMMU_DISP_RW_SFW, "aclk_smmu_disp_rw_sfw",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_ACLK_DISP_SECURE_SMMU_RW_SFW, 0, 0, 0),
+
+       GATE(PCLK_CP_DISP, "pclk_cp_disp", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 18, 0, 0),
+       GATE(PCLK_HDMI_PHY, "pclk_hdmi_phy", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 26, 0, 0),
+       GATE(PCLK_HDMI, "pclk_hdmi", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 27, 0, 0),
+       GATE(PCLK_DSIM1, "pclk_dsim1", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 28, 0, 0),
+       GATE(PCLK_DSIM0, "pclk_dsim0", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 29, 0, 0),
+       GATE(PCLK_DECON_EXT, "pclk_decon_ext", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 30, 0, 0),
+       GATE(PCLK_DECON_INT, "pclk_decon_int", "dout_pclk_disp",
+                       ENABLE_PCLK_DISP, 31, 0, 0),
+
+       GATE(PCLK_SMMU_DISP_RO_MMU, "pclk_smmu_disp_ro_mmu",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_PCLK_DISP_SECURE_SMMU_RO_MMU, 0, 0, 0),
+       GATE(PCLK_SMMU_DISP_RW_MMU, "pclk_smmu_disp_rw_mmu",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_PCLK_DISP_SECURE_SMMU_RW_MMU, 0, 0, 0),
+       GATE(PCLK_SMMU_DISP_RO_SFW, "pclk_smmu_disp_ro_sfw",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_PCLK_DISP_SECURE_SMMU_RO_SFW, 0, 0, 0),
+       GATE(PCLK_SMMU_DISP_RW_SFW, "pclk_smmu_disp_rw_sfw",
+                       "mout_aclk_disp_400_user",
+                       ENABLE_PCLK_DISP_SECURE_SMMU_RW_SFW, 0, 0, 0),
+
+       GATE(SCLK_DECON_EXT_EXTCLKPLL, "sclk_decon_ext_extclkpll",
+                       "sdout_sclk_decon_ext_extclkpll",
+                       ENABLE_SCLK_DISP1, 4, 0, 0),
+       GATE(SCLK_DECON_INT_EXTCLKPLL, "sclk_decon_int_extclkpll",
+                       "sdout_sclk_decon_int_extclkpll",
+                       ENABLE_SCLK_DISP1, 8, 0, 0),
+       GATE(SCLK_HDMI_SPDIF, "sclk_hdmi_spdif_user", "sclk_hdmi_spdif",
+                       ENABLE_SCLK_DISP1, 12, 0, 0),
+       GATE(SCLK_DSD, "sclk_dsd_user", "mout_sclk_dsd_user",
+                       ENABLE_SCLK_DISP1, 16, 0, 0),
+       GATE(SCLK_DECON_EXT_ECLK, "sclk_decon_ext_eclk_user",
+                       "sdout_sclk_decon_ext_eclk",
+                       ENABLE_SCLK_DISP1, 24, 0, 0),
+       GATE(SCLK_DECON_INT_ECLK, "sclk_decon_int_eclk_user",
+                       "sdout_sclk_decon_int_eclk",
+                       ENABLE_SCLK_DISP1, 28, 0, 0),
+
+       GATE(SCLK_RGB_VCLK1, "sclk_rgb_vclk1_user", "sclk_rgb_vclk1",
+                       ENABLE_SCLK_DISP2, 24, 0, 0),
+       GATE(SCLK_RGB_VCLK0, "sclk_rgb_vclk0_user", "sclk_rgb_vclk0",
+                       ENABLE_SCLK_DISP2, 28, 0, 0),
+};
+
+static struct samsung_pll_clock disp_pll_clks[] __initdata = {
+       PLL(pll_1460x, 0, "fout_disp_pll", "fin_pll",
+               DISP_PLL_LOCK, DISP_PLL_CON0,
+               pll1460x_24mhz_tbl),
+};
+
+static void __init exynos7_clk_disp_init(struct device_node *np)
+{
+       struct exynos_cmu_info cmu = {0};
+
+       cmu.fixed_clks = fixed_rate_clks_disp;
+       cmu.nr_fixed_clks = ARRAY_SIZE(fixed_rate_clks_disp);
+       cmu.pll_clks = disp_pll_clks;
+       cmu.nr_pll_clks = ARRAY_SIZE(disp_pll_clks);
+       cmu.mux_clks = disp_mux_clks;
+       cmu.nr_mux_clks = ARRAY_SIZE(disp_mux_clks);
+       cmu.div_clks = disp_div_clks;
+       cmu.nr_div_clks = ARRAY_SIZE(disp_div_clks);
+       cmu.gate_clks = disp_gate_clks;
+       cmu.nr_gate_clks = ARRAY_SIZE(disp_gate_clks);
+       cmu.nr_clk_ids = DISP_NR_CLK;
+       cmu.clk_regs = disp_clk_regs;
+       cmu.nr_clk_regs = ARRAY_SIZE(disp_clk_regs);
+
+       exynos_cmu_register_one(np, &cmu);
+}
+
+CLK_OF_DECLARE(exynos7_clk_disp, "samsung,exynos7-clock-disp",
+               exynos7_clk_disp_init);
diff --git a/include/dt-bindings/clock/exynos7-clk.h 
b/include/dt-bindings/clock/exynos7-clk.h
new file mode 100644
index 0000000..15b504a
--- /dev/null
+++ b/include/dt-bindings/clock/exynos7-clk.h
@@ -0,0 +1,236 @@
+/*
+ * Copyright (c) 2014 Samsung Electronics Co., Ltd.
+ * Author: Naveen Krishna Chatradhi <ch.nav...@samsung.com>
+ *
+ * This program is free software; you can redistribute it and/or modify
+ * it under the terms of the GNU General Public License version 2 as
+ * published by the Free Software Foundation.
+ *
+ * Device Tree binding constants for blocks TOPC, TOP0 and TOP1,
+ * CCORE, PERIC0, PERIC1 and PERIS, BUS0, BUS1, FSYS0, FSYS1,
+ * Multi media subsystems such as G3D, AUD, DISP, MSCL and
+ * MFC blocks of the Exynos7 clock controller.
+*/
+
+#ifndef _DT_BINDINGS_CLOCK_EXYNOS7_H
+#define _DT_BINDINGS_CLOCK_EXYNOS7_H
+
+/* TOPC */
+#define ACLK_CCORE_532                 1
+#define ACLK_CCORE_133                 2
+#define ACLK_BUS0_532                  3
+#define ACLK_BUS1_532                  4
+#define ACLK_BUS1_200                  5
+#define ACLK_IMEM_266                  6
+#define ACLK_IMEM_200                  7
+#define ACLK_IMEM_100                  8
+#define ACLK_G2D_400                   9
+#define ACLK_G2D_266                   10
+#define ACLK_MFC_532                   11
+#define ACLK_HEVC_532                  12
+#define ACLK_MFC_BUS_532               13
+#define ACLK_MSCL_532                  14
+#define ACLK_PERIS_66                  15
+#define ACLK_MIF                       16
+#define SCLK_CMU_APBIF                 17
+#define SCLK_CC_PLL_A                  18
+#define SCLK_CC_PLL_B                  19
+#define SCLK_BUS0_PLL_A                        20
+#define SCLK_BUS0_PLL_B                        21
+#define SCLK_BUS0_PLL_MIF              22
+#define SCLK_BUS0_PLL_ATLAS            23
+#define SCLK_BUS_PLL_G3D               24
+#define SCLK_BUS1_PLL_A                        25
+#define SCLK_BUS1_PLL_B                        26
+#define SCLK_MFC_PLL_A                 27
+#define SCLK_MFC_PLL_B                 28
+#define SCLK_AUD_PLL                   29
+#define CCORE_133_532                  30
+#define BUS0_532                       31
+#define BUS1_200_532                   32
+#define IMEM_100_200_266               33
+#define PERIS_66                       34
+#define G2D_266_400                    35
+#define MFC_BUS_532                    36
+#define HEVC_532                       37
+#define MSCL_532                       38
+#define TOPC_NR_CLK                    39
+
+/* TOP0 */
+#define CLK_ACLK_MIF                   1
+#define CLK_ACLK_VPP1_400              2
+#define CLK_ACLK_VPP0_400              3
+#define CLK_ACLK_PERIC1_66             4
+#define CLK_ACLK_PERIC0_66             5
+#define CLK_ACLK_DISP_400              6
+#define CLK_SCLK_HDMI_SPDIF            7
+#define CLK_SCLK_DSD                   8
+#define CLK_SCLK_DECON_VCLK            9
+#define CLK_SCLK_DECON_EXT_ECLK                10
+#define CLK_SCLK_DECON_INT_ECLK                11
+#define CLK_SCLK_SPDIF                 12
+#define CLK_SCLK_PCM1                  13
+#define CLK_SCLK_I2S1                  14
+#define CLK_SCLK_SPI0                  15
+#define CLK_SCLK_SPI1                  16
+#define CLK_SCLK_SPI2                  17
+#define CLK_SCLK_SPI3                  18
+#define CLK_SCLK_SPI4                  19
+#define CLK_SCLK_UART0                 20
+#define CLK_SCLK_UART1                 21
+#define CLK_SCLK_UART2                 22
+#define CLK_SCLK_UART3                 23
+#define TOP_PERIC                      24
+#define TOP_DISP                       25
+#define TOP0_NR_CLK                    26
+
+/* TOP1 */
+#define CLK_ACLK_MIF3                  1
+#define CLK_ACLK_MIF2                  2
+#define ACLK_FSYS0_200                 3
+#define ACLK_FSYS1_200                 4
+#define CLK_SCLK_PHY_FSYS0_26M         5
+#define CLK_SCLK_PHY_FSYS0             6
+#define CLK_SCLK_UFSUNIPRO11           7
+#define CLK_SCLK_MMC2                  8
+#define CLK_SCLK_USBDRD300             9
+#define CLK_SCLK_PHY_FSYS1             10
+#define CLK_SCLK_TLX400_WIFI1          11
+#define CLK_SCLK_UFSUNIPRO20           12
+#define CLK_SCLK_MMC1                  13
+#define CLK_SCLK_MMC0                  14
+#define CLK_SCLK_PHY_FSYS1_26M         15
+#define CLK_FSYS1                      16
+#define CLK_FSYS0                      17
+#define TOP1_NR_CLK                    19
+
+/* CCORE */
+#define ACLK_CC                                1
+#define PCLK_RTC                       2
+#define CCORE_NR_CLK                   3
+
+/* PERIC0 */
+#define PCLK_HSI2C0                    1
+#define PCLK_HSI2C1                    2
+#define PCLK_HSI2C4                    3
+#define PCLK_HSI2C5                    4
+#define PCLK_HSI2C9                    5
+#define PCLK_HSI2C10                   6
+#define PCLK_HSI2C11                   7
+#define PCLK_UART0                     8
+#define PCLK_ADCIF                     9
+#define PCLK_PWM                       10
+#define SCLK_PWM                       11
+#define SCLK_UART0                     12
+#define PERIC0_NR_CLK                  13
+
+/* PERIC1 */
+#define PCLK_HSI2C2                    1
+#define PCLK_HSI2C3                    2
+#define PCLK_HSI2C6                    3
+#define PCLK_HSI2C7                    4
+#define PCLK_HSI2C8                    5
+#define PCLK_UART1                     6
+#define PCLK_UART2                     7
+#define PCLK_UART3                     8
+#define PCLK_SPI0                      9
+#define PCLK_SPI1                      10
+#define PCLK_SPI2                      11
+#define PCLK_SPI3                      12
+#define PCLK_SPI4                      13
+#define PCLK_I2S1                      14
+#define PCLK_PCM1                      15
+#define PCLK_SPDIF                     16
+#define SCLK_UART1                     17
+#define SCLK_UART2                     18
+#define SCLK_UART3                     19
+#define SCLK_SPI0                      20
+#define SCLK_SPI1                      21
+#define SCLK_SPI2                      22
+#define SCLK_SPI3                      23
+#define SCLK_SPI4                      24
+#define SCLK_I2S1                      25
+#define SCLK_PCM1                      27
+#define SCLK_SPDIF                     28
+#define IOCLK_I2S1_BCLK                        29
+#define IOCLK_SPI0_CLK                 30
+#define IOCLK_SPI1_CLK                 31
+#define IOCLK_SPI2_CLK                 32
+#define IOCLK_SPI3_CLK                 33
+#define IOCLK_SPI4_CLK                 34
+#define PERIC1_NR_CLK                  35
+
+/* PERIS */
+#define PCLK_MCT                       1
+#define PCLK_WDT_ATLAS                 2
+#define PCLK_SYSREG                    3
+#define PCLK_TMU                       4
+#define PCLK_CHIPID                    5
+#define SCLK_TMU                       6
+#define SCLK_CHIPID                    7
+#define PERIS_NR_CLK                   8
+
+/* BUS0 */
+#define PCLK_GPIO_BUS0                 1
+#define ACLK_LH_DISP0                  2
+#define ACLK_LH_DISP1                  3
+#define BUS0_NR_CLK                    4
+
+/* BUS1 */
+#define PCLK_GPIO_BUS1                 1
+#define BUS1_NR_CLK                    2
+
+/* FSYS0 */
+#define CLK_PDMA1              1
+#define CLK_PDMA0              2
+#define ACLK_USBHOST20         3
+#define ACLK_USBDRD300         4
+#define ACLK_UFS11_LINK                5
+#define ACLK_MMC2              6
+#define PCLK_GPIO_FSYS0                7
+#define SCLK_MMC2              8
+#define FSYS0_NR_CLK           9
+
+/* FSYS1 */
+#define ACLK_MMC1                      1
+#define ACLK_MMC0                      2
+#define PCLK_GPIO_FSYS1                        3
+#define SCLK_MMC1                      4
+#define SCLK_MMC0                      5
+#define PHYCLK_UFS_TX0_SYMBOL          6
+#define PHYCLK_UFS_RX0_SYMBOL          7
+#define PHYCLK_UFS20_TX0_SYMBOL                8
+#define PHYCLK_UFS20_RX0_SYMBOL                9
+#define PHYCLK_UFS20_RX1_SYMBOL                10
+#define FSYS1_NR_CLK                   11
+
+/* DISP */
+#define ACLK_CP_DISP                   1
+#define ACLK_DECON_EXT                 2
+#define ACLK_DECON_INT                 3
+#define ACLK_SMMU_DISP_RO_MMU          4
+#define ACLK_SMMU_DISP_RW_MMU          5
+#define ACLK_SMMU_DISP_RO_SFW          6
+#define ACLK_SMMU_DISP_RW_SFW          7
+#define PCLK_SMMU_DISP_RO_MMU          8
+#define PCLK_SMMU_DISP_RW_MMU          9
+#define PCLK_SMMU_DISP_RO_SFW          10
+#define PCLK_SMMU_DISP_RW_SFW          11
+#define PCLK_CP_DISP                   12
+#define PCLK_HDMI_PHY                  13
+#define PCLK_HDMI                      14
+#define PCLK_DSIM1                     15
+#define PCLK_DSIM0                     16
+#define PCLK_DECON_EXT                 17
+#define PCLK_DECON_INT                 18
+#define SCLK_DECON_EXT_EXTCLKPLL       19
+#define SCLK_DECON_INT_EXTCLKPLL       20
+#define SCLK_HDMI_SPDIF                        21
+#define SCLK_DSD                       22
+#define SCLK_DECON_EXT_ECLK            23
+#define SCLK_DECON_INT_ECLK            24
+#define SCLK_RGB_VCLK1                 25
+#define SCLK_RGB_VCLK0                 26
+#define DISP_NR_CLK                    27
+
+#endif /* _DT_BINDINGS_CLOCK_EXYNOS7_H */
-- 
1.7.9.5

--
To unsubscribe from this list: send the line "unsubscribe linux-samsung-soc" in
the body of a message to majord...@vger.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html

Reply via email to