From: Arnd Bergmann <arnd@arndb.de> To: Daniel Mack <daniel@zonque.org>, Haojian Zhuang <haojian.zhuang@gmail.com>, Robert Jarzmik <robert.jarzmik@free.fr> Cc: linux-arm-kernel@lists.infradead.org, linux-kernel@vger.kernel.org, Linus Walleij <linus.walleij@linaro.org>, Arnd Bergmann <arnd@arndb.de>, Michael Turquette <mturquette@baylibre.com>, Stephen Boyd <sboyd@kernel.org>, linux-clk@vger.kernel.org Subject: [PATCH 36/46] ARM: pxa: move smemc register access from clk to platform Date: Fri, 18 Oct 2019 17:41:51 +0200 [thread overview] Message-ID: <20191018154201.1276638-36-arnd@arndb.de> (raw) In-Reply-To: <20191018154052.1276506-1-arnd@arndb.de> The get_sdram_rows() and get_memclkdiv() helpers need smemc register that are separate from the clk registers, move them out of the clk driver, and use an extern declaration instead. Cc: Michael Turquette <mturquette@baylibre.com> Cc: Stephen Boyd <sboyd@kernel.org> Cc: linux-clk@vger.kernel.org Signed-off-by: Arnd Bergmann <arnd@arndb.de> --- arch/arm/mach-pxa/generic.c | 30 ++++++++++++++++++++++++++++++ arch/arm/mach-pxa/pxa3xx.c | 4 ++++ arch/arm/mach-pxa/smemc.c | 9 +++++++++ drivers/clk/pxa/clk-pxa.c | 4 +++- drivers/clk/pxa/clk-pxa.h | 5 +++-- drivers/clk/pxa/clk-pxa25x.c | 30 +++--------------------------- drivers/clk/pxa/clk-pxa27x.c | 31 +++---------------------------- drivers/clk/pxa/clk-pxa3xx.c | 8 +++----- include/linux/soc/pxa/smemc.h | 3 +++ 9 files changed, 61 insertions(+), 63 deletions(-) diff --git a/arch/arm/mach-pxa/generic.c b/arch/arm/mach-pxa/generic.c index 2c2c82fcf9cb..942af8946a73 100644 --- a/arch/arm/mach-pxa/generic.c +++ b/arch/arm/mach-pxa/generic.c @@ -18,6 +18,7 @@ #include <linux/kernel.h> #include <linux/init.h> #include <linux/soc/pxa/cpu.h> +#include <linux/soc/pxa/smemc.h> #include <asm/mach/map.h> #include <asm/mach-types.h> @@ -84,6 +85,35 @@ void pxa_smemc_set_pcmcia_socket(int nr) } EXPORT_SYMBOL_GPL(pxa_smemc_set_pcmcia_socket); +#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) +#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) + +int pxa_smemc_get_sdram_rows(void) +{ + static int sdram_rows; + unsigned int drac2 = 0, drac0 = 0; + u32 mdcnfg; + + if (sdram_rows) + return sdram_rows; + + mdcnfg = readl_relaxed(MDCNFG); + + if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) + drac2 = MDCNFG_DRAC2(mdcnfg); + + if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) + drac0 = MDCNFG_DRAC0(mdcnfg); + + sdram_rows = 1 << (11 + max(drac0, drac2)); + return sdram_rows; +} + +void __iomem *pxa_smemc_get_mdrefr(void) +{ + return MDREFR; +} + /* * Intel PXA2xx internal register mapping. * diff --git a/arch/arm/mach-pxa/pxa3xx.c b/arch/arm/mach-pxa/pxa3xx.c index f4657f4edb3b..d486efb79dcd 100644 --- a/arch/arm/mach-pxa/pxa3xx.c +++ b/arch/arm/mach-pxa/pxa3xx.c @@ -52,6 +52,10 @@ extern void __init pxa_dt_irq_init(int (*fn)(struct irq_data *, unsigned int)); #define NDCR_ND_ARB_EN (1 << 12) #define NDCR_ND_ARB_CNTL (1 << 19) +#define CKEN_BOOT 11 /* < Boot rom clock enable */ +#define CKEN_TPM 19 /* < TPM clock enable */ +#define CKEN_HSIO2 41 /* < HSIO2 clock enable */ + #ifdef CONFIG_PM #define ISRAM_START 0x5c000000 diff --git a/arch/arm/mach-pxa/smemc.c b/arch/arm/mach-pxa/smemc.c index 47b99549d616..da0eeafdb5a0 100644 --- a/arch/arm/mach-pxa/smemc.c +++ b/arch/arm/mach-pxa/smemc.c @@ -69,4 +69,13 @@ static int __init smemc_init(void) return 0; } subsys_initcall(smemc_init); + #endif + +static const unsigned int df_clkdiv[4] = { 1, 2, 4, 1 }; +unsigned int pxa3xx_smemc_get_memclkdiv(void) +{ + unsigned long memclkcfg = __raw_readl(MEMCLKCFG); + + return df_clkdiv[(memclkcfg >> 16) & 0x3]; +} diff --git a/drivers/clk/pxa/clk-pxa.c b/drivers/clk/pxa/clk-pxa.c index cfc79f942b07..831180360069 100644 --- a/drivers/clk/pxa/clk-pxa.c +++ b/drivers/clk/pxa/clk-pxa.c @@ -11,6 +11,7 @@ #include <linux/clkdev.h> #include <linux/io.h> #include <linux/of.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -150,12 +151,13 @@ void pxa2xx_core_turbo_switch(bool on) } void pxa2xx_cpll_change(struct pxa2xx_freq *freq, - u32 (*mdrefr_dri)(unsigned int), void __iomem *mdrefr, + u32 (*mdrefr_dri)(unsigned int), void __iomem *cccr) { unsigned int clkcfg = freq->clkcfg; unsigned int unused, preset_mdrefr, postset_mdrefr; unsigned long flags; + void __iomem *mdrefr = pxa_smemc_get_mdrefr(); local_irq_save(flags); diff --git a/drivers/clk/pxa/clk-pxa.h b/drivers/clk/pxa/clk-pxa.h index f131d2834af4..d81fbec42004 100644 --- a/drivers/clk/pxa/clk-pxa.h +++ b/drivers/clk/pxa/clk-pxa.h @@ -146,12 +146,13 @@ static inline int dummy_clk_set_parent(struct clk_hw *hw, u8 index) extern void clkdev_pxa_register(int ckid, const char *con_id, const char *dev_id, struct clk *clk); -extern int clk_pxa_cken_init(const struct desc_clk_cken *clks, int nb_clks); +extern int clk_pxa_cken_init(const struct desc_clk_cken *clks, + int nb_clks); void clk_pxa_dt_common_init(struct device_node *np); void pxa2xx_core_turbo_switch(bool on); void pxa2xx_cpll_change(struct pxa2xx_freq *freq, - u32 (*mdrefr_dri)(unsigned int), void __iomem *mdrefr, + u32 (*mdrefr_dri)(unsigned int), void __iomem *cccr); int pxa2xx_determine_rate(struct clk_rate_request *req, struct pxa2xx_freq *freqs, int nb_freqs); diff --git a/drivers/clk/pxa/clk-pxa25x.c b/drivers/clk/pxa/clk-pxa25x.c index d0f957996acb..65807f000c6a 100644 --- a/drivers/clk/pxa/clk-pxa25x.c +++ b/drivers/clk/pxa/clk-pxa25x.c @@ -15,7 +15,7 @@ #include <linux/io.h> #include <linux/of.h> #include <mach/pxa2xx-regs.h> -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -33,9 +33,6 @@ enum { ((T) ? CLKCFG_TURBO : 0)) #define PXA25x_CCCR(N2, M, L) (N2 << 7 | M << 5 | L) -#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) -#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) - /* Define the refresh period in mSec for the SDRAM and the number of rows */ #define SDRAM_TREF 64 /* standard 64ms SDRAM */ @@ -57,30 +54,9 @@ static const char * const get_freq_khz[] = { "core", "run", "cpll", "memory" }; -static int get_sdram_rows(void) -{ - static int sdram_rows; - unsigned int drac2 = 0, drac0 = 0; - u32 mdcnfg; - - if (sdram_rows) - return sdram_rows; - - mdcnfg = readl_relaxed(MDCNFG); - - if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) - drac2 = MDCNFG_DRAC2(mdcnfg); - - if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) - drac0 = MDCNFG_DRAC0(mdcnfg); - - sdram_rows = 1 << (11 + max(drac0, drac2)); - return sdram_rows; -} - static u32 mdrefr_dri(unsigned int freq_khz) { - u32 interval = freq_khz * SDRAM_TREF / get_sdram_rows(); + u32 interval = freq_khz * SDRAM_TREF / pxa_smemc_get_sdram_rows(); return interval / 32; } @@ -268,7 +244,7 @@ static int clk_pxa25x_cpll_set_rate(struct clk_hw *hw, unsigned long rate, if (i >= ARRAY_SIZE(pxa25x_freqs)) return -EINVAL; - pxa2xx_cpll_change(&pxa25x_freqs[i], mdrefr_dri, MDREFR, CCCR); + pxa2xx_cpll_change(&pxa25x_freqs[i], mdrefr_dri, CCCR); return 0; } diff --git a/drivers/clk/pxa/clk-pxa27x.c b/drivers/clk/pxa/clk-pxa27x.c index 287fdeae7c7c..eac67d425bee 100644 --- a/drivers/clk/pxa/clk-pxa27x.c +++ b/drivers/clk/pxa/clk-pxa27x.c @@ -12,8 +12,7 @@ #include <linux/clk.h> #include <linux/clkdev.h> #include <linux/of.h> - -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -50,9 +49,6 @@ enum { ((T) ? CLKCFG_TURBO : 0)) #define PXA27x_CCCR(A, L, N2) (A << 25 | N2 << 7 | L) -#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) -#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) - /* Define the refresh period in mSec for the SDRAM and the number of rows */ #define SDRAM_TREF 64 /* standard 64ms SDRAM */ @@ -61,30 +57,9 @@ static const char * const get_freq_khz[] = { "system_bus" }; -static int get_sdram_rows(void) -{ - static int sdram_rows; - unsigned int drac2 = 0, drac0 = 0; - u32 mdcnfg; - - if (sdram_rows) - return sdram_rows; - - mdcnfg = readl_relaxed(MDCNFG); - - if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) - drac2 = MDCNFG_DRAC2(mdcnfg); - - if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) - drac0 = MDCNFG_DRAC0(mdcnfg); - - sdram_rows = 1 << (11 + max(drac0, drac2)); - return sdram_rows; -} - static u32 mdrefr_dri(unsigned int freq_khz) { - u32 interval = freq_khz * SDRAM_TREF / get_sdram_rows(); + u32 interval = freq_khz * SDRAM_TREF / pxa_smemc_get_sdram_rows(); return (interval - 31) / 32; } @@ -260,7 +235,7 @@ static int clk_pxa27x_cpll_set_rate(struct clk_hw *hw, unsigned long rate, if (i >= ARRAY_SIZE(pxa27x_freqs)) return -EINVAL; - pxa2xx_cpll_change(&pxa27x_freqs[i], mdrefr_dri, MDREFR, CCCR); + pxa2xx_cpll_change(&pxa27x_freqs[i], mdrefr_dri, CCCR); return 0; } diff --git a/drivers/clk/pxa/clk-pxa3xx.c b/drivers/clk/pxa/clk-pxa3xx.c index 60a0db4f3790..08594fc899e2 100644 --- a/drivers/clk/pxa/clk-pxa3xx.c +++ b/drivers/clk/pxa/clk-pxa3xx.c @@ -15,7 +15,7 @@ #include <linux/clkdev.h> #include <linux/of.h> #include <linux/soc/pxa/cpu.h> -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <linux/clk/pxa.h> #include <mach/pxa3xx-regs.h> @@ -41,8 +41,6 @@ static unsigned char hss_mult[4] = { 8, 12, 16, 24 }; /* crystal frequency to static memory controller multiplier (SMCFS) */ static unsigned int smcfs_mult[8] = { 6, 0, 8, 0, 0, 16, }; -static unsigned int df_clkdiv[4] = { 1, 2, 4, 1 }; - static const char * const get_freq_khz[] = { "core", "ring_osc_60mhz", "run", "cpll", "system_bus" }; @@ -118,10 +116,10 @@ static unsigned long clk_pxa3xx_smemc_get_rate(struct clk_hw *hw, unsigned long parent_rate) { unsigned long acsr = ACSR; - unsigned long memclkcfg = __raw_readl(MEMCLKCFG); return (parent_rate / 48) * smcfs_mult[(acsr >> 23) & 0x7] / - df_clkdiv[(memclkcfg >> 16) & 0x3]; + pxa3xx_smemc_get_memclkdiv(); + } PARENTS(clk_pxa3xx_smemc) = { "spll_624mhz" }; RATE_RO_OPS(clk_pxa3xx_smemc, "smemc"); diff --git a/include/linux/soc/pxa/smemc.h b/include/linux/soc/pxa/smemc.h index cbf1a2d8af29..9283e5642b19 100644 --- a/include/linux/soc/pxa/smemc.h +++ b/include/linux/soc/pxa/smemc.h @@ -6,5 +6,8 @@ void pxa_smemc_set_pcmcia_timing(int sock, u32 mcmem, u32 mcatt, u32 mcio); void pxa_smemc_set_pcmcia_socket(int nr); +int pxa_smemc_get_sdram_rows(void); +unsigned int pxa3xx_smemc_get_memclkdiv(void); +void __iomem *pxa_smemc_get_mdrefr(void); #endif -- 2.20.0
WARNING: multiple messages have this Message-ID (diff)
From: Arnd Bergmann <arnd@arndb.de> To: Daniel Mack <daniel@zonque.org>, Haojian Zhuang <haojian.zhuang@gmail.com>, Robert Jarzmik <robert.jarzmik@free.fr> Cc: Arnd Bergmann <arnd@arndb.de>, Stephen Boyd <sboyd@kernel.org>, Michael Turquette <mturquette@baylibre.com>, linux-kernel@vger.kernel.org, linux-clk@vger.kernel.org, Linus Walleij <linus.walleij@linaro.org>, linux-arm-kernel@lists.infradead.org Subject: [PATCH 36/46] ARM: pxa: move smemc register access from clk to platform Date: Fri, 18 Oct 2019 17:41:51 +0200 [thread overview] Message-ID: <20191018154201.1276638-36-arnd@arndb.de> (raw) In-Reply-To: <20191018154052.1276506-1-arnd@arndb.de> The get_sdram_rows() and get_memclkdiv() helpers need smemc register that are separate from the clk registers, move them out of the clk driver, and use an extern declaration instead. Cc: Michael Turquette <mturquette@baylibre.com> Cc: Stephen Boyd <sboyd@kernel.org> Cc: linux-clk@vger.kernel.org Signed-off-by: Arnd Bergmann <arnd@arndb.de> --- arch/arm/mach-pxa/generic.c | 30 ++++++++++++++++++++++++++++++ arch/arm/mach-pxa/pxa3xx.c | 4 ++++ arch/arm/mach-pxa/smemc.c | 9 +++++++++ drivers/clk/pxa/clk-pxa.c | 4 +++- drivers/clk/pxa/clk-pxa.h | 5 +++-- drivers/clk/pxa/clk-pxa25x.c | 30 +++--------------------------- drivers/clk/pxa/clk-pxa27x.c | 31 +++---------------------------- drivers/clk/pxa/clk-pxa3xx.c | 8 +++----- include/linux/soc/pxa/smemc.h | 3 +++ 9 files changed, 61 insertions(+), 63 deletions(-) diff --git a/arch/arm/mach-pxa/generic.c b/arch/arm/mach-pxa/generic.c index 2c2c82fcf9cb..942af8946a73 100644 --- a/arch/arm/mach-pxa/generic.c +++ b/arch/arm/mach-pxa/generic.c @@ -18,6 +18,7 @@ #include <linux/kernel.h> #include <linux/init.h> #include <linux/soc/pxa/cpu.h> +#include <linux/soc/pxa/smemc.h> #include <asm/mach/map.h> #include <asm/mach-types.h> @@ -84,6 +85,35 @@ void pxa_smemc_set_pcmcia_socket(int nr) } EXPORT_SYMBOL_GPL(pxa_smemc_set_pcmcia_socket); +#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) +#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) + +int pxa_smemc_get_sdram_rows(void) +{ + static int sdram_rows; + unsigned int drac2 = 0, drac0 = 0; + u32 mdcnfg; + + if (sdram_rows) + return sdram_rows; + + mdcnfg = readl_relaxed(MDCNFG); + + if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) + drac2 = MDCNFG_DRAC2(mdcnfg); + + if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) + drac0 = MDCNFG_DRAC0(mdcnfg); + + sdram_rows = 1 << (11 + max(drac0, drac2)); + return sdram_rows; +} + +void __iomem *pxa_smemc_get_mdrefr(void) +{ + return MDREFR; +} + /* * Intel PXA2xx internal register mapping. * diff --git a/arch/arm/mach-pxa/pxa3xx.c b/arch/arm/mach-pxa/pxa3xx.c index f4657f4edb3b..d486efb79dcd 100644 --- a/arch/arm/mach-pxa/pxa3xx.c +++ b/arch/arm/mach-pxa/pxa3xx.c @@ -52,6 +52,10 @@ extern void __init pxa_dt_irq_init(int (*fn)(struct irq_data *, unsigned int)); #define NDCR_ND_ARB_EN (1 << 12) #define NDCR_ND_ARB_CNTL (1 << 19) +#define CKEN_BOOT 11 /* < Boot rom clock enable */ +#define CKEN_TPM 19 /* < TPM clock enable */ +#define CKEN_HSIO2 41 /* < HSIO2 clock enable */ + #ifdef CONFIG_PM #define ISRAM_START 0x5c000000 diff --git a/arch/arm/mach-pxa/smemc.c b/arch/arm/mach-pxa/smemc.c index 47b99549d616..da0eeafdb5a0 100644 --- a/arch/arm/mach-pxa/smemc.c +++ b/arch/arm/mach-pxa/smemc.c @@ -69,4 +69,13 @@ static int __init smemc_init(void) return 0; } subsys_initcall(smemc_init); + #endif + +static const unsigned int df_clkdiv[4] = { 1, 2, 4, 1 }; +unsigned int pxa3xx_smemc_get_memclkdiv(void) +{ + unsigned long memclkcfg = __raw_readl(MEMCLKCFG); + + return df_clkdiv[(memclkcfg >> 16) & 0x3]; +} diff --git a/drivers/clk/pxa/clk-pxa.c b/drivers/clk/pxa/clk-pxa.c index cfc79f942b07..831180360069 100644 --- a/drivers/clk/pxa/clk-pxa.c +++ b/drivers/clk/pxa/clk-pxa.c @@ -11,6 +11,7 @@ #include <linux/clkdev.h> #include <linux/io.h> #include <linux/of.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -150,12 +151,13 @@ void pxa2xx_core_turbo_switch(bool on) } void pxa2xx_cpll_change(struct pxa2xx_freq *freq, - u32 (*mdrefr_dri)(unsigned int), void __iomem *mdrefr, + u32 (*mdrefr_dri)(unsigned int), void __iomem *cccr) { unsigned int clkcfg = freq->clkcfg; unsigned int unused, preset_mdrefr, postset_mdrefr; unsigned long flags; + void __iomem *mdrefr = pxa_smemc_get_mdrefr(); local_irq_save(flags); diff --git a/drivers/clk/pxa/clk-pxa.h b/drivers/clk/pxa/clk-pxa.h index f131d2834af4..d81fbec42004 100644 --- a/drivers/clk/pxa/clk-pxa.h +++ b/drivers/clk/pxa/clk-pxa.h @@ -146,12 +146,13 @@ static inline int dummy_clk_set_parent(struct clk_hw *hw, u8 index) extern void clkdev_pxa_register(int ckid, const char *con_id, const char *dev_id, struct clk *clk); -extern int clk_pxa_cken_init(const struct desc_clk_cken *clks, int nb_clks); +extern int clk_pxa_cken_init(const struct desc_clk_cken *clks, + int nb_clks); void clk_pxa_dt_common_init(struct device_node *np); void pxa2xx_core_turbo_switch(bool on); void pxa2xx_cpll_change(struct pxa2xx_freq *freq, - u32 (*mdrefr_dri)(unsigned int), void __iomem *mdrefr, + u32 (*mdrefr_dri)(unsigned int), void __iomem *cccr); int pxa2xx_determine_rate(struct clk_rate_request *req, struct pxa2xx_freq *freqs, int nb_freqs); diff --git a/drivers/clk/pxa/clk-pxa25x.c b/drivers/clk/pxa/clk-pxa25x.c index d0f957996acb..65807f000c6a 100644 --- a/drivers/clk/pxa/clk-pxa25x.c +++ b/drivers/clk/pxa/clk-pxa25x.c @@ -15,7 +15,7 @@ #include <linux/io.h> #include <linux/of.h> #include <mach/pxa2xx-regs.h> -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -33,9 +33,6 @@ enum { ((T) ? CLKCFG_TURBO : 0)) #define PXA25x_CCCR(N2, M, L) (N2 << 7 | M << 5 | L) -#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) -#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) - /* Define the refresh period in mSec for the SDRAM and the number of rows */ #define SDRAM_TREF 64 /* standard 64ms SDRAM */ @@ -57,30 +54,9 @@ static const char * const get_freq_khz[] = { "core", "run", "cpll", "memory" }; -static int get_sdram_rows(void) -{ - static int sdram_rows; - unsigned int drac2 = 0, drac0 = 0; - u32 mdcnfg; - - if (sdram_rows) - return sdram_rows; - - mdcnfg = readl_relaxed(MDCNFG); - - if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) - drac2 = MDCNFG_DRAC2(mdcnfg); - - if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) - drac0 = MDCNFG_DRAC0(mdcnfg); - - sdram_rows = 1 << (11 + max(drac0, drac2)); - return sdram_rows; -} - static u32 mdrefr_dri(unsigned int freq_khz) { - u32 interval = freq_khz * SDRAM_TREF / get_sdram_rows(); + u32 interval = freq_khz * SDRAM_TREF / pxa_smemc_get_sdram_rows(); return interval / 32; } @@ -268,7 +244,7 @@ static int clk_pxa25x_cpll_set_rate(struct clk_hw *hw, unsigned long rate, if (i >= ARRAY_SIZE(pxa25x_freqs)) return -EINVAL; - pxa2xx_cpll_change(&pxa25x_freqs[i], mdrefr_dri, MDREFR, CCCR); + pxa2xx_cpll_change(&pxa25x_freqs[i], mdrefr_dri, CCCR); return 0; } diff --git a/drivers/clk/pxa/clk-pxa27x.c b/drivers/clk/pxa/clk-pxa27x.c index 287fdeae7c7c..eac67d425bee 100644 --- a/drivers/clk/pxa/clk-pxa27x.c +++ b/drivers/clk/pxa/clk-pxa27x.c @@ -12,8 +12,7 @@ #include <linux/clk.h> #include <linux/clkdev.h> #include <linux/of.h> - -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <dt-bindings/clock/pxa-clock.h> #include "clk-pxa.h" @@ -50,9 +49,6 @@ enum { ((T) ? CLKCFG_TURBO : 0)) #define PXA27x_CCCR(A, L, N2) (A << 25 | N2 << 7 | L) -#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3) -#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3) - /* Define the refresh period in mSec for the SDRAM and the number of rows */ #define SDRAM_TREF 64 /* standard 64ms SDRAM */ @@ -61,30 +57,9 @@ static const char * const get_freq_khz[] = { "system_bus" }; -static int get_sdram_rows(void) -{ - static int sdram_rows; - unsigned int drac2 = 0, drac0 = 0; - u32 mdcnfg; - - if (sdram_rows) - return sdram_rows; - - mdcnfg = readl_relaxed(MDCNFG); - - if (mdcnfg & (MDCNFG_DE2 | MDCNFG_DE3)) - drac2 = MDCNFG_DRAC2(mdcnfg); - - if (mdcnfg & (MDCNFG_DE0 | MDCNFG_DE1)) - drac0 = MDCNFG_DRAC0(mdcnfg); - - sdram_rows = 1 << (11 + max(drac0, drac2)); - return sdram_rows; -} - static u32 mdrefr_dri(unsigned int freq_khz) { - u32 interval = freq_khz * SDRAM_TREF / get_sdram_rows(); + u32 interval = freq_khz * SDRAM_TREF / pxa_smemc_get_sdram_rows(); return (interval - 31) / 32; } @@ -260,7 +235,7 @@ static int clk_pxa27x_cpll_set_rate(struct clk_hw *hw, unsigned long rate, if (i >= ARRAY_SIZE(pxa27x_freqs)) return -EINVAL; - pxa2xx_cpll_change(&pxa27x_freqs[i], mdrefr_dri, MDREFR, CCCR); + pxa2xx_cpll_change(&pxa27x_freqs[i], mdrefr_dri, CCCR); return 0; } diff --git a/drivers/clk/pxa/clk-pxa3xx.c b/drivers/clk/pxa/clk-pxa3xx.c index 60a0db4f3790..08594fc899e2 100644 --- a/drivers/clk/pxa/clk-pxa3xx.c +++ b/drivers/clk/pxa/clk-pxa3xx.c @@ -15,7 +15,7 @@ #include <linux/clkdev.h> #include <linux/of.h> #include <linux/soc/pxa/cpu.h> -#include <mach/smemc.h> +#include <linux/soc/pxa/smemc.h> #include <linux/clk/pxa.h> #include <mach/pxa3xx-regs.h> @@ -41,8 +41,6 @@ static unsigned char hss_mult[4] = { 8, 12, 16, 24 }; /* crystal frequency to static memory controller multiplier (SMCFS) */ static unsigned int smcfs_mult[8] = { 6, 0, 8, 0, 0, 16, }; -static unsigned int df_clkdiv[4] = { 1, 2, 4, 1 }; - static const char * const get_freq_khz[] = { "core", "ring_osc_60mhz", "run", "cpll", "system_bus" }; @@ -118,10 +116,10 @@ static unsigned long clk_pxa3xx_smemc_get_rate(struct clk_hw *hw, unsigned long parent_rate) { unsigned long acsr = ACSR; - unsigned long memclkcfg = __raw_readl(MEMCLKCFG); return (parent_rate / 48) * smcfs_mult[(acsr >> 23) & 0x7] / - df_clkdiv[(memclkcfg >> 16) & 0x3]; + pxa3xx_smemc_get_memclkdiv(); + } PARENTS(clk_pxa3xx_smemc) = { "spll_624mhz" }; RATE_RO_OPS(clk_pxa3xx_smemc, "smemc"); diff --git a/include/linux/soc/pxa/smemc.h b/include/linux/soc/pxa/smemc.h index cbf1a2d8af29..9283e5642b19 100644 --- a/include/linux/soc/pxa/smemc.h +++ b/include/linux/soc/pxa/smemc.h @@ -6,5 +6,8 @@ void pxa_smemc_set_pcmcia_timing(int sock, u32 mcmem, u32 mcatt, u32 mcio); void pxa_smemc_set_pcmcia_socket(int nr); +int pxa_smemc_get_sdram_rows(void); +unsigned int pxa3xx_smemc_get_memclkdiv(void); +void __iomem *pxa_smemc_get_mdrefr(void); #endif -- 2.20.0 _______________________________________________ linux-arm-kernel mailing list linux-arm-kernel@lists.infradead.org http://lists.infradead.org/mailman/listinfo/linux-arm-kernel
next prev parent reply other threads:[~2019-10-18 15:44 UTC|newest] Thread overview: 424+ messages / expand[flat|nested] mbox.gz Atom feed top 2019-10-18 15:40 [PATCH 00/46] ARM: pxa: towards multiplatform support Arnd Bergmann 2019-10-18 15:40 ` Arnd Bergmann 2019-10-18 15:40 ` Arnd Bergmann 2019-10-18 15:40 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 01/46] ARM: pxa: split mach/generic.h Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 18:06 ` Robert Jarzmik 2019-10-28 18:06 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 02/46] ARM: pxa: make mainstone.h private Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 18:08 ` Robert Jarzmik 2019-10-28 18:08 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 03/46] ARM: pxa: make mach/regs-uart.h private Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 18:14 ` Robert Jarzmik 2019-10-28 18:14 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 04/46] ARM: pxa: remove mach/dma.h Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 18:15 ` Robert Jarzmik 2019-10-28 18:15 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 05/46] ARM: pxa: split up mach/hardware.h Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 18:37 ` Dmitry Torokhov 2019-10-18 18:37 ` Dmitry Torokhov 2019-10-18 18:37 ` Dmitry Torokhov 2019-10-18 18:37 ` [alsa-devel] " Dmitry Torokhov 2019-10-18 18:37 ` Dmitry Torokhov 2019-10-18 18:37 ` Dmitry Torokhov 2019-10-19 21:22 ` Alexandre Belloni 2019-10-19 21:22 ` Alexandre Belloni 2019-10-19 21:22 ` Alexandre Belloni 2019-10-19 21:22 ` [alsa-devel] " Alexandre Belloni 2019-10-19 21:22 ` Alexandre Belloni 2019-10-19 21:22 ` Alexandre Belloni 2019-10-21 2:27 ` Viresh Kumar 2019-10-21 2:39 ` Viresh Kumar 2019-10-21 2:27 ` Viresh Kumar 2019-10-21 2:27 ` Viresh Kumar 2019-10-21 2:27 ` [alsa-devel] " Viresh Kumar 2019-10-21 2:27 ` Viresh Kumar 2019-10-21 9:58 ` Ulf Hansson 2019-10-21 9:58 ` Ulf Hansson 2019-10-21 9:58 ` Ulf Hansson 2019-10-21 9:58 ` [alsa-devel] " Ulf Hansson 2019-10-21 9:58 ` Ulf Hansson 2019-10-21 9:58 ` Ulf Hansson 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` [alsa-devel] " Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 9:18 ` [alsa-devel] " Stephen Boyd 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 9:18 ` Stephen Boyd 2019-10-28 19:14 ` Robert Jarzmik 2019-10-28 19:14 ` Robert Jarzmik 2019-10-28 19:14 ` Robert Jarzmik 2019-10-28 19:14 ` [alsa-devel] " Robert Jarzmik 2019-10-28 19:14 ` Robert Jarzmik 2019-10-28 19:14 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 06/46] ARM: pxa: stop using mach/bitfield.h Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 19:20 ` Robert Jarzmik 2019-10-28 19:20 ` Robert Jarzmik 2019-10-28 19:20 ` Robert Jarzmik 2019-11-08 14:39 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:39 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:39 ` Bartlomiej Zolnierkiewicz 2019-10-18 15:41 ` [PATCH 07/46] ARM: pxa: move mach/sound.h to linux/platform_data/ Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` [alsa-devel] " Mark Brown 2019-10-28 19:21 ` Robert Jarzmik 2019-10-28 19:21 ` Robert Jarzmik 2019-10-28 19:21 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 08/46] ARM: pxa: move regs-lcd.h into driver Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 19:24 ` Robert Jarzmik 2019-10-28 19:24 ` Robert Jarzmik 2019-10-28 19:24 ` Robert Jarzmik 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-10-18 15:41 ` [PATCH 09/46] watchdog: sa1100: use platform device registration Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-19 14:06 ` Guenter Roeck 2019-10-19 14:06 ` Guenter Roeck 2019-10-22 9:44 ` Arnd Bergmann 2019-10-22 9:44 ` Arnd Bergmann 2019-10-22 13:38 ` Guenter Roeck 2019-10-22 13:38 ` Guenter Roeck 2019-10-18 15:41 ` [PATCH 10/46] ARM: pxa: pxa2xx-ac97-lib: use IRQ resource Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-28 20:19 ` Robert Jarzmik 2019-10-28 20:19 ` Robert Jarzmik 2019-10-28 20:19 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 11/46] ARM: pxa: cmx270: use platform device for nand Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-19 9:44 ` Miquel Raynal 2019-10-19 9:44 ` Miquel Raynal 2019-10-19 9:44 ` Miquel Raynal 2019-10-22 10:00 ` Arnd Bergmann 2019-10-22 10:00 ` Arnd Bergmann 2019-10-22 10:00 ` Arnd Bergmann 2019-10-28 20:25 ` Robert Jarzmik 2019-10-28 20:25 ` Robert Jarzmik 2019-10-28 20:25 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 12/46] ARM: pxa: make addr-map.h header local Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 20:27 ` Robert Jarzmik 2019-10-28 20:27 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 13/46] ARM: pxa: move pcmcia board data into mach-pxa Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 14/46] ARM: pxa: use pdev resource for palmld mmio Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 20:34 ` Robert Jarzmik 2019-10-28 20:34 ` Robert Jarzmik 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-11-08 14:40 ` Bartlomiej Zolnierkiewicz 2019-10-18 15:41 ` [PATCH 15/46] ARM: pxa: maybe fix gpio lookup tables Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 20:48 ` Robert Jarzmik 2019-10-28 20:48 ` Robert Jarzmik 2019-11-04 15:45 ` Linus Walleij 2019-11-04 15:45 ` Linus Walleij 2019-10-18 15:41 ` [PATCH 16/46] ARM: pxa: tosa: use gpio descriptor for audio Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` Mark Brown 2019-10-22 16:36 ` [alsa-devel] " Mark Brown 2019-10-28 20:49 ` Robert Jarzmik 2019-10-28 20:49 ` Robert Jarzmik 2019-10-28 20:49 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 17/46] ARM: pxa: poodle: use platform data for poodle asoc driver Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` [alsa-devel] " Mark Brown 2019-10-28 20:53 ` Robert Jarzmik 2019-10-28 20:53 ` Robert Jarzmik 2019-10-28 20:53 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 18/46] ARM: pxa: corgi: use gpio descriptors for audio Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` [alsa-devel] " Mark Brown 2019-10-28 20:56 ` Robert Jarzmik 2019-10-28 20:56 ` Robert Jarzmik 2019-10-28 20:56 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 19/46] ARM: pxa: hx4700: " Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` Mark Brown 2019-10-22 16:37 ` [alsa-devel] " Mark Brown 2019-10-28 20:59 ` Robert Jarzmik 2019-10-28 20:59 ` Robert Jarzmik 2019-10-28 20:59 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 20/46] ARM: pxa: lubbock: pass udc irqs as resource Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 21:05 ` Robert Jarzmik 2019-10-28 21:05 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 21/46] ARM: pxa: spitz: use gpio descriptors for audio Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` [alsa-devel] " Mark Brown 2019-10-28 21:08 ` Robert Jarzmik 2019-10-28 21:08 ` Robert Jarzmik 2019-10-28 21:08 ` [alsa-devel] " Robert Jarzmik 2022-04-19 15:40 ` Arnd Bergmann 2022-04-19 15:40 ` Arnd Bergmann 2022-04-19 15:40 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 22/46] ARM: pxa: eseries: use gpio lookup " Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` [alsa-devel] " Mark Brown 2019-10-28 21:13 ` Robert Jarzmik 2019-10-28 21:13 ` Robert Jarzmik 2019-10-28 21:13 ` [alsa-devel] " Robert Jarzmik 2019-11-05 9:21 ` Linus Walleij 2019-11-05 9:21 ` Linus Walleij 2019-11-05 9:21 ` [alsa-devel] " Linus Walleij 2019-10-18 15:41 ` [PATCH 23/46] ARM: pxa: z2: use gpio lookup for audio device Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` [alsa-devel] " Mark Brown 2019-10-28 21:17 ` Robert Jarzmik 2019-10-28 21:17 ` Robert Jarzmik 2019-10-28 21:17 ` [alsa-devel] " Robert Jarzmik 2019-11-05 9:22 ` Linus Walleij 2019-11-05 9:22 ` Linus Walleij 2019-11-05 9:22 ` [alsa-devel] " Linus Walleij 2019-10-18 15:41 ` [PATCH 24/46] ARM: pxa: magician: use platform driver for audio Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` Mark Brown 2019-10-22 16:38 ` [alsa-devel] " Mark Brown 2019-10-28 21:19 ` Robert Jarzmik 2019-10-28 21:19 ` Robert Jarzmik 2019-10-28 21:19 ` [alsa-devel] " Robert Jarzmik 2019-11-05 9:22 ` Linus Walleij 2019-11-05 9:22 ` Linus Walleij 2019-11-05 9:22 ` [alsa-devel] " Linus Walleij 2019-10-18 15:41 ` [PATCH 25/46] ARM: pxa: mainstone-wm97xx: use gpio lookup table Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 18:39 ` Dmitry Torokhov 2019-10-18 18:39 ` Dmitry Torokhov [not found] ` <CAK8P3a1Fc=ogknDRGJ3Sn8bZ8tsR_ebE8_bDtF_kZ4AZ5YG_+g@mail.gmail.com> 2019-10-18 19:37 ` Arnd Bergmann 2019-10-18 19:37 ` Arnd Bergmann 2019-10-18 20:39 ` Dmitry Torokhov 2019-10-18 20:39 ` Dmitry Torokhov 2019-10-28 21:24 ` Robert Jarzmik 2019-10-28 21:24 ` Robert Jarzmik 2019-11-05 9:25 ` Linus Walleij 2019-11-05 9:25 ` Linus Walleij 2019-10-18 15:41 ` [PATCH 26/46] ARM: pxa: zylonite: use gpio lookup instead mfp header Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 21:31 ` Robert Jarzmik 2019-10-28 21:31 ` Robert Jarzmik 2019-11-05 9:28 ` Linus Walleij 2019-11-05 9:28 ` Linus Walleij 2019-10-18 15:41 ` [PATCH 27/46] input: touchscreen: mainstone: fix pxa2xx+pxa3xx configuration Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 18:40 ` Dmitry Torokhov 2019-10-18 18:40 ` Dmitry Torokhov 2019-10-28 21:33 ` Robert Jarzmik 2019-10-28 21:33 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 28/46] input: touchscreen: mainstone: sync with zylonite driver Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 18:41 ` Dmitry Torokhov 2019-10-18 18:41 ` Dmitry Torokhov 2019-10-28 21:40 ` Robert Jarzmik 2019-10-28 21:40 ` Robert Jarzmik 2022-04-19 15:51 ` Arnd Bergmann 2022-04-19 15:51 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 29/46] Input: touchscreen: use wrapper for pxa2xx ac97 registers Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-18 18:48 ` Dmitry Torokhov 2019-10-18 18:48 ` Dmitry Torokhov 2019-10-18 18:48 ` [alsa-devel] " Dmitry Torokhov [not found] ` <CAK8P3a27==9TeS-RWEvrpnxh+6McqRF-xeb8WPj9pHOn+0zbOQ@mail.gmail.com> 2019-10-18 19:39 ` Fwd: " Arnd Bergmann 2019-10-18 19:39 ` Arnd Bergmann 2019-10-18 19:39 ` [alsa-devel] " Arnd Bergmann 2019-10-18 20:39 ` Dmitry Torokhov 2019-10-18 20:39 ` Dmitry Torokhov 2019-10-18 20:39 ` [alsa-devel] " Dmitry Torokhov 2019-10-30 20:33 ` Robert Jarzmik 2019-10-30 20:33 ` Robert Jarzmik 2019-10-30 20:33 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 30/46] SoC: pxa: use pdev resource for FIFO regs Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:39 ` Mark Brown 2019-10-22 16:39 ` Mark Brown 2019-10-22 16:39 ` [alsa-devel] " Mark Brown 2019-10-22 20:13 ` Arnd Bergmann 2019-10-22 20:13 ` Arnd Bergmann 2019-10-22 20:13 ` [alsa-devel] " Arnd Bergmann 2019-10-28 21:45 ` Robert Jarzmik 2019-10-28 21:45 ` Robert Jarzmik 2019-10-28 21:45 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 31/46] ASoC: pxa: ac97: use normal MMIO accessors Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-28 21:47 ` Robert Jarzmik 2019-10-28 21:47 ` Robert Jarzmik 2019-10-28 21:47 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 32/46] ASoC: pxa: i2s: " Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [alsa-devel] " Arnd Bergmann 2019-10-22 16:39 ` Mark Brown 2019-10-22 16:39 ` Mark Brown 2019-10-22 16:39 ` [alsa-devel] " Mark Brown 2019-10-28 21:50 ` Robert Jarzmik 2019-10-28 21:50 ` Robert Jarzmik 2019-10-28 21:50 ` [alsa-devel] " Robert Jarzmik 2019-10-18 15:41 ` [PATCH 33/46] ARM: pxa: pcmcia: move smemc configuration back to arch Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 21:57 ` Robert Jarzmik 2019-10-28 21:57 ` Robert Jarzmik 2022-04-19 15:55 ` Arnd Bergmann 2022-04-19 15:55 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 34/46] ARM: pxa: remove get_clk_frequency_khz() Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-21 2:26 ` Viresh Kumar 2019-10-21 2:26 ` Viresh Kumar 2019-10-28 21:58 ` Robert Jarzmik 2019-10-28 21:58 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 35/46] cpufreq: pxa3: move clk register access to clk driver Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-21 2:26 ` Viresh Kumar 2019-10-21 2:26 ` Viresh Kumar 2019-10-28 9:23 ` Stephen Boyd 2019-10-30 20:42 ` Robert Jarzmik 2019-11-08 21:59 ` Stephen Boyd 2019-11-08 22:02 ` Stephen Boyd 2019-10-18 15:41 ` Arnd Bergmann [this message] 2019-10-18 15:41 ` [PATCH 36/46] ARM: pxa: move smemc register access from clk to platform Arnd Bergmann 2019-10-28 9:34 ` Stephen Boyd 2019-10-28 9:34 ` Stephen Boyd 2019-10-30 20:57 ` Robert Jarzmik 2019-10-30 20:57 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 37/46] ARM: pxa: move clk register definitions to driver Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-28 9:34 ` Stephen Boyd 2019-10-28 9:34 ` Stephen Boyd 2019-10-30 21:00 ` Robert Jarzmik 2019-10-30 21:00 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 38/46] video: backlight: tosa: use gpio lookup table Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-30 21:10 ` Robert Jarzmik 2019-10-30 21:10 ` Robert Jarzmik 2019-10-30 21:10 ` Robert Jarzmik 2019-10-30 21:10 ` Robert Jarzmik 2019-10-30 21:10 ` Robert Jarzmik 2019-11-05 10:04 ` Linus Walleij 2019-11-05 10:04 ` Linus Walleij 2019-11-05 10:04 ` Linus Walleij 2019-11-05 10:04 ` Linus Walleij 2019-11-05 10:17 ` Daniel Thompson 2019-11-05 10:17 ` Daniel Thompson 2019-11-05 10:17 ` Daniel Thompson 2019-11-05 10:17 ` Daniel Thompson 2019-11-11 9:30 ` Lee Jones 2019-11-11 9:30 ` Lee Jones 2019-11-11 9:30 ` Lee Jones 2019-11-11 9:30 ` Lee Jones 2019-10-18 15:41 ` [PATCH 39/46] power: tosa: simplify probe function Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-19 9:07 ` Sebastian Reichel 2019-10-19 9:07 ` Sebastian Reichel 2019-10-30 21:12 ` Robert Jarzmik 2019-10-30 21:12 ` Robert Jarzmik 2019-10-30 21:21 ` Robert Jarzmik 2019-10-30 21:21 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 40/46] ARM: pxa: tosa: use gpio lookup for battery Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-19 9:09 ` Sebastian Reichel 2019-10-19 9:09 ` Sebastian Reichel 2019-10-18 15:41 ` [PATCH 41/46] ARM: pxa: move it8152 PCI support into machine Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 42/46] ARM: pxa: remove unused mach/bitfield.h Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-30 21:33 ` Robert Jarzmik 2019-10-30 21:33 ` Robert Jarzmik 2019-10-18 15:41 ` [PATCH 43/46] ARM: pxa: pci-it8152: add platform checks Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-18 15:41 ` [PATCH 44/46] ARM: mmp: remove tavorevb board support Arnd Bergmann 2019-10-18 15:41 ` Arnd Bergmann 2019-10-19 14:20 ` Lubomir Rintel 2019-10-19 14:20 ` Lubomir Rintel 2019-10-19 19:34 ` Arnd Bergmann 2019-10-19 19:34 ` Arnd Bergmann 2019-10-18 15:42 ` [PATCH 45/46] ARM: mmp: rename pxa_register_device Arnd Bergmann 2019-10-18 15:42 ` Arnd Bergmann 2019-10-31 8:53 ` Lubomir Rintel 2019-10-31 8:53 ` Lubomir Rintel 2019-10-18 15:42 ` [PATCH 46/46] ARM: pxa: move plat-pxa to drivers/soc/ Arnd Bergmann 2019-10-18 15:42 ` Arnd Bergmann 2019-10-30 21:40 ` Robert Jarzmik 2019-10-30 21:40 ` Robert Jarzmik 2019-10-31 8:53 ` Lubomir Rintel 2019-10-31 8:53 ` Lubomir Rintel 2019-10-18 19:03 ` [PATCH 00/46] ARM: pxa: towards multiplatform support Robert Jarzmik 2019-10-18 19:03 ` Robert Jarzmik 2019-10-18 19:03 ` Robert Jarzmik 2019-10-18 19:03 ` Robert Jarzmik [not found] ` <CAK8P3a1JDtHsOW=iaxEycbJ4TBkR9MHUyDMeJnwxCtb=tefnBQ@mail.gmail.com> 2019-10-18 19:32 ` Arnd Bergmann 2019-10-18 19:32 ` Arnd Bergmann 2019-10-18 19:32 ` Arnd Bergmann 2019-10-18 19:32 ` Arnd Bergmann 2019-10-19 10:35 ` Robert Jarzmik 2019-10-19 10:35 ` Robert Jarzmik 2019-10-19 10:35 ` Robert Jarzmik 2019-10-19 10:35 ` Robert Jarzmik 2019-10-19 10:35 ` Robert Jarzmik 2019-10-24 20:49 ` Robert Jarzmik 2019-10-24 20:49 ` Robert Jarzmik 2019-10-24 20:49 ` Robert Jarzmik 2019-10-24 20:49 ` Robert Jarzmik 2019-10-24 20:49 ` Robert Jarzmik 2019-10-25 10:50 ` Arnd Bergmann 2019-10-25 10:50 ` Arnd Bergmann 2019-10-25 10:50 ` Arnd Bergmann 2019-10-25 10:50 ` Arnd Bergmann 2019-10-19 1:02 ` Guenter Roeck 2019-10-19 1:02 ` Guenter Roeck 2019-10-19 1:02 ` Guenter Roeck 2019-10-19 1:02 ` Guenter Roeck 2019-10-19 10:08 ` Arnd Bergmann 2019-10-19 10:08 ` Arnd Bergmann 2019-10-19 10:08 ` Arnd Bergmann 2019-10-19 10:08 ` Arnd Bergmann 2019-10-19 10:09 ` Arnd Bergmann 2019-10-19 10:09 ` Arnd Bergmann 2019-10-19 10:09 ` Arnd Bergmann 2019-10-19 10:09 ` Arnd Bergmann
Reply instructions: You may reply publicly to this message via plain-text email using any one of the following methods: * Save the following mbox file, import it into your mail client, and reply-to-all from there: mbox Avoid top-posting and favor interleaved quoting: https://en.wikipedia.org/wiki/Posting_style#Interleaved_style * Reply using the --to, --cc, and --in-reply-to switches of git-send-email(1): git send-email \ --in-reply-to=20191018154201.1276638-36-arnd@arndb.de \ --to=arnd@arndb.de \ --cc=daniel@zonque.org \ --cc=haojian.zhuang@gmail.com \ --cc=linus.walleij@linaro.org \ --cc=linux-arm-kernel@lists.infradead.org \ --cc=linux-clk@vger.kernel.org \ --cc=linux-kernel@vger.kernel.org \ --cc=mturquette@baylibre.com \ --cc=robert.jarzmik@free.fr \ --cc=sboyd@kernel.org \ /path/to/YOUR_REPLY https://kernel.org/pub/software/scm/git/docs/git-send-email.html * If your mail client supports setting the In-Reply-To header via mailto: links, try the mailto: linkBe sure your reply has a Subject: header at the top and a blank line before the message body.
This is an external index of several public inboxes, see mirroring instructions on how to clone and mirror all data and code used by this external index.