ARM: pxa: move smemc register access from clk to platform
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 Link: https://lore.kernel.org/lkml/87pnielzo4.fsf@belgarion.home/ Signed-off-by: Arnd Bergmann <arnd@arndb.de>
This commit is contained in:
parent
5c6603e741
commit
fd13f8117f
|
@ -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,11 @@ void pxa_smemc_set_pcmcia_socket(int nr)
|
|||
}
|
||||
EXPORT_SYMBOL_GPL(pxa_smemc_set_pcmcia_socket);
|
||||
|
||||
void __iomem *pxa_smemc_get_mdrefr(void)
|
||||
{
|
||||
return MDREFR;
|
||||
}
|
||||
|
||||
/*
|
||||
* Intel PXA2xx internal register mapping.
|
||||
*
|
||||
|
|
|
@ -14,7 +14,10 @@
|
|||
|
||||
#include <mach/pxa2xx-regs.h>
|
||||
#include "mfp-pxa25x.h"
|
||||
#include "generic.h"
|
||||
#include <mach/reset.h>
|
||||
#include <mach/smemc.h>
|
||||
#include <linux/soc/pxa/smemc.h>
|
||||
#include <linux/platform_data/irda-pxaficp.h>
|
||||
|
||||
void pxa2xx_clear_reset_status(unsigned int mask)
|
||||
|
@ -50,3 +53,27 @@ void pxa2xx_transceiver_mode(struct device *dev, int mode)
|
|||
BUG();
|
||||
}
|
||||
EXPORT_SYMBOL_GPL(pxa2xx_transceiver_mode);
|
||||
|
||||
#define MDCNFG_DRAC2(mdcnfg) (((mdcnfg) >> 21) & 0x3)
|
||||
#define MDCNFG_DRAC0(mdcnfg) (((mdcnfg) >> 5) & 0x3)
|
||||
|
||||
int pxa2xx_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;
|
||||
}
|
||||
|
|
|
@ -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
|
||||
|
|
|
@ -11,6 +11,7 @@
|
|||
#include <linux/soc/pxa/cpu.h>
|
||||
|
||||
#include <mach/smemc.h>
|
||||
#include <linux/soc/pxa/smemc.h>
|
||||
|
||||
#ifdef CONFIG_PM
|
||||
static unsigned long msc[2];
|
||||
|
@ -70,3 +71,11 @@ static int __init smemc_init(void)
|
|||
}
|
||||
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];
|
||||
}
|
||||
|
|
|
@ -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);
|
||||
|
||||
|
|
|
@ -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);
|
||||
|
|
|
@ -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 / pxa2xx_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;
|
||||
}
|
||||
|
|
|
@ -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 / pxa2xx_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;
|
||||
}
|
||||
|
||||
|
|
|
@ -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");
|
||||
|
|
|
@ -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 pxa2xx_smemc_get_sdram_rows(void);
|
||||
unsigned int pxa3xx_smemc_get_memclkdiv(void);
|
||||
void __iomem *pxa_smemc_get_mdrefr(void);
|
||||
|
||||
#endif
|
||||
|
|
Loading…
Reference in New Issue