From b3a6e2c5448b7d340ff6bea9e99f79989453b1f7 Mon Sep 17 00:00:00 2001 From: MyungJoo Ham Date: Thu, 20 Mar 2014 15:29:15 +0900 Subject: add Tizen ARM reference patches - Imported 20140319.065243: author Jonghwa Lee Wed, 19 Mar 2014 00:55:10 +0900 (00:55 +0900) committer Jonghwa Lee Wed, 19 Mar 2014 01:13:40 +0900 (01:13 +0900) commit 7464f7e4fed02c10aa619746890bdd96b1b43fc3 Based on Linux 3.10.19 LTS. Change-Id: I17572de4952319a6815c18379bdbe35b1db0a88c Signed-off-by: MyungJoo Ham --- ...-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch | 128 +++++++++++++++++++++ 1 file changed, 128 insertions(+) create mode 100644 patches.tizen/0257-clk-exynos4-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch (limited to 'patches.tizen/0257-clk-exynos4-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch') diff --git a/patches.tizen/0257-clk-exynos4-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch b/patches.tizen/0257-clk-exynos4-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch new file mode 100644 index 00000000000..ad15c506cfa --- /dev/null +++ b/patches.tizen/0257-clk-exynos4-Add-CLK_GET_RATE_NOCACHE-flag-for-the-Ex.patch @@ -0,0 +1,128 @@ +From ce0efcf11eba1ee93ece8a376a69cbc89e70f93b Mon Sep 17 00:00:00 2001 +From: Sylwester Nawrocki +Date: Fri, 14 Jun 2013 17:16:18 +0200 +Subject: [PATCH 0257/1302] clk: exynos4: Add CLK_GET_RATE_NOCACHE flag for the + Exynos4x12 ISP clocks + +The ISP clock registers belong to the ISP power domain and may change +their values if this power domain is switched off/on. Add +CLK_GET_RATE_NOCACHE flags to ensure clk_set_rate() and clk_get_rate() +work properly and do not use invalid cached values. + +Signed-off-by: Sylwester Nawrocki +Signed-off-by: MyungJoo Ham +--- + drivers/clk/samsung/clk-exynos4.c | 64 +++++++++++++++++++++------------------ + 1 file changed, 34 insertions(+), 30 deletions(-) + +diff --git a/drivers/clk/samsung/clk-exynos4.c b/drivers/clk/samsung/clk-exynos4.c +index be86c98..9994b8d 100644 +--- a/drivers/clk/samsung/clk-exynos4.c ++++ b/drivers/clk/samsung/clk-exynos4.c +@@ -582,11 +582,15 @@ struct samsung_div_clock exynos4x12_div_clks[] __initdata = { + DIV(none, "div_spi1_isp", "mout_spi1_isp", E4X12_DIV_ISP, 16, 4), + DIV(none, "div_spi1_isp_pre", "div_spi1_isp", E4X12_DIV_ISP, 20, 8), + DIV(none, "div_uart_isp", "mout_uart_isp", E4X12_DIV_ISP, 28, 4), +- DIV(div_isp0, "div_isp0", "aclk200", E4X12_DIV_ISP0, 0, 3), +- DIV(div_isp1, "div_isp1", "aclk200", E4X12_DIV_ISP0, 4, 3), ++ DIV_F(div_isp0, "div_isp0", "aclk200", E4X12_DIV_ISP0, 0, 3, ++ CLK_GET_RATE_NOCACHE, 0), ++ DIV_F(div_isp1, "div_isp1", "aclk200", E4X12_DIV_ISP0, 4, 3, ++ CLK_GET_RATE_NOCACHE, 0), + DIV(none, "div_mpwm", "div_isp1", E4X12_DIV_ISP1, 0, 3), +- DIV(div_mcuisp0, "div_mcuisp0", "aclk400_mcuisp", E4X12_DIV_ISP1, 4, 3), +- DIV(div_mcuisp1, "div_mcuisp1", "div_mcuisp0", E4X12_DIV_ISP1, 8, 3), ++ DIV_F(div_mcuisp0, "div_mcuisp0", "aclk400_mcuisp", E4X12_DIV_ISP1, ++ 4, 3, CLK_GET_RATE_NOCACHE, 0), ++ DIV_F(div_mcuisp1, "div_mcuisp1", "div_mcuisp0", E4X12_DIV_ISP1, ++ 8, 3, CLK_GET_RATE_NOCACHE, 0), + }; + + /* list of gate clocks supported in all exynos4 soc's */ +@@ -861,57 +865,57 @@ struct samsung_gate_clock exynos4x12_gate_clks[] __initdata = { + GATE_A(wdt, "watchdog", "aclk100", + E4X12_GATE_IP_PERIR, 14, 0, 0, "watchdog"), + GATE(fimc_isp, "isp", "aclk200", E4X12_GATE_ISP0, 0, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(fimc_drc, "drc", "aclk200", E4X12_GATE_ISP0, 1, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(fimc_fd, "fd", "aclk200", E4X12_GATE_ISP0, 2, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(fimc_lite0, "lite0", "aclk200", E4X12_GATE_ISP0, 3, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(fimc_lite1, "lite1", "aclk200", E4X12_GATE_ISP0, 4, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(mcuisp, "mcuisp", "aclk200", E4X12_GATE_ISP0, 5, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(gicisp, "gicisp", "aclk200", E4X12_GATE_ISP0, 7, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_isp, "smmu_isp", "aclk200", E4X12_GATE_ISP0, 8, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_drc, "smmu_drc", "aclk200", E4X12_GATE_ISP0, 9, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_fd, "smmu_fd", "aclk200", E4X12_GATE_ISP0, 10, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_lite0, "smmu_lite0", "aclk200", E4X12_GATE_ISP0, 11, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_lite1, "smmu_lite1", "aclk200", E4X12_GATE_ISP0, 12, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(ppmuispmx, "ppmuispmx", "aclk200", E4X12_GATE_ISP0, 20, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(ppmuispx, "ppmuispx", "aclk200", E4X12_GATE_ISP0, 21, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(mcuctl_isp, "mcuctl_isp", "aclk200", E4X12_GATE_ISP0, 23, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(mpwm_isp, "mpwm_isp", "aclk200", E4X12_GATE_ISP0, 24, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(i2c0_isp, "i2c0_isp", "aclk200", E4X12_GATE_ISP0, 25, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(i2c1_isp, "i2c1_isp", "aclk200", E4X12_GATE_ISP0, 26, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(mtcadc_isp, "mtcadc_isp", "aclk200", E4X12_GATE_ISP0, 27, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(pwm_isp, "pwm_isp", "aclk200", E4X12_GATE_ISP0, 28, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(wdt_isp, "wdt_isp", "aclk200", E4X12_GATE_ISP0, 30, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(uart_isp, "uart_isp", "aclk200", E4X12_GATE_ISP0, 31, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(asyncaxim, "asyncaxim", "aclk200", E4X12_GATE_ISP1, 0, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(smmu_ispcx, "smmu_ispcx", "aclk200", E4X12_GATE_ISP1, 4, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(spi0_isp, "spi0_isp", "aclk200", E4X12_GATE_ISP1, 12, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + GATE(spi1_isp, "spi1_isp", "aclk200", E4X12_GATE_ISP1, 13, +- CLK_IGNORE_UNUSED, 0), ++ CLK_IGNORE_UNUSED | CLK_GET_RATE_NOCACHE, 0), + }; + + static struct of_device_id exynos4_clkout_ids[] __initdata = { +-- +1.8.3.2 + -- cgit v1.2.3