|
@@ -1242,40 +1242,67 @@ static struct clksrc_clk exynos4_clk_sclk_mmc3 = {
|
|
|
.reg_div = { .reg = EXYNOS4_CLKDIV_FSYS2, .shift = 24, .size = 8 },
|
|
|
};
|
|
|
|
|
|
+static struct clksrc_clk exynos4_clk_mdout_spi0 = {
|
|
|
+ .clk = {
|
|
|
+ .name = "mdout_spi",
|
|
|
+ .devname = "exynos4210-spi.0",
|
|
|
+ },
|
|
|
+ .sources = &exynos4_clkset_group,
|
|
|
+ .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 16, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 0, .size = 4 },
|
|
|
+};
|
|
|
+
|
|
|
+static struct clksrc_clk exynos4_clk_mdout_spi1 = {
|
|
|
+ .clk = {
|
|
|
+ .name = "mdout_spi",
|
|
|
+ .devname = "exynos4210-spi.1",
|
|
|
+ },
|
|
|
+ .sources = &exynos4_clkset_group,
|
|
|
+ .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 20, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 16, .size = 4 },
|
|
|
+};
|
|
|
+
|
|
|
+static struct clksrc_clk exynos4_clk_mdout_spi2 = {
|
|
|
+ .clk = {
|
|
|
+ .name = "mdout_spi",
|
|
|
+ .devname = "exynos4210-spi.2",
|
|
|
+ },
|
|
|
+ .sources = &exynos4_clkset_group,
|
|
|
+ .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 24, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL2, .shift = 0, .size = 4 },
|
|
|
+};
|
|
|
+
|
|
|
static struct clksrc_clk exynos4_clk_sclk_spi0 = {
|
|
|
.clk = {
|
|
|
.name = "sclk_spi",
|
|
|
.devname = "exynos4210-spi.0",
|
|
|
+ .parent = &exynos4_clk_mdout_spi0.clk,
|
|
|
.enable = exynos4_clksrc_mask_peril1_ctrl,
|
|
|
.ctrlbit = (1 << 16),
|
|
|
},
|
|
|
- .sources = &exynos4_clkset_group,
|
|
|
- .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 16, .size = 4 },
|
|
|
- .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 0, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 8, .size = 8 },
|
|
|
};
|
|
|
|
|
|
static struct clksrc_clk exynos4_clk_sclk_spi1 = {
|
|
|
.clk = {
|
|
|
.name = "sclk_spi",
|
|
|
.devname = "exynos4210-spi.1",
|
|
|
+ .parent = &exynos4_clk_mdout_spi1.clk,
|
|
|
.enable = exynos4_clksrc_mask_peril1_ctrl,
|
|
|
.ctrlbit = (1 << 20),
|
|
|
},
|
|
|
- .sources = &exynos4_clkset_group,
|
|
|
- .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 20, .size = 4 },
|
|
|
- .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 16, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL1, .shift = 24, .size = 8 },
|
|
|
};
|
|
|
|
|
|
static struct clksrc_clk exynos4_clk_sclk_spi2 = {
|
|
|
.clk = {
|
|
|
.name = "sclk_spi",
|
|
|
.devname = "exynos4210-spi.2",
|
|
|
+ .parent = &exynos4_clk_mdout_spi2.clk,
|
|
|
.enable = exynos4_clksrc_mask_peril1_ctrl,
|
|
|
.ctrlbit = (1 << 24),
|
|
|
},
|
|
|
- .sources = &exynos4_clkset_group,
|
|
|
- .reg_src = { .reg = EXYNOS4_CLKSRC_PERIL1, .shift = 24, .size = 4 },
|
|
|
- .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL2, .shift = 0, .size = 4 },
|
|
|
+ .reg_div = { .reg = EXYNOS4_CLKDIV_PERIL2, .shift = 8, .size = 8 },
|
|
|
};
|
|
|
|
|
|
/* Clock initialization code */
|
|
@@ -1331,7 +1358,9 @@ static struct clksrc_clk *exynos4_clksrc_cdev[] = {
|
|
|
&exynos4_clk_sclk_spi0,
|
|
|
&exynos4_clk_sclk_spi1,
|
|
|
&exynos4_clk_sclk_spi2,
|
|
|
-
|
|
|
+ &exynos4_clk_mdout_spi0,
|
|
|
+ &exynos4_clk_mdout_spi1,
|
|
|
+ &exynos4_clk_mdout_spi2,
|
|
|
};
|
|
|
|
|
|
static struct clk_lookup exynos4_clk_lookup[] = {
|