Commit 19a62998 authored by Paul Walmsley's avatar Paul Walmsley Committed by Tony Lindgren

OMAP3 SRAM: remove unused functions; rename remainder

The only SRAM function currently used on OMAP3 is the CORE DPLL M2 divider
reprogramming function; remove the rest of the stubs.
Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 2a1ce26e
...@@ -18,7 +18,7 @@ ...@@ -18,7 +18,7 @@
/* Micron MT46H32M32LF-6 */ /* Micron MT46H32M32LF-6 */
/* XXX Using ARE = 0x1 (no autorefresh burst) -- can this be changed? */ /* XXX Using ARE = 0x1 (no autorefresh burst) -- can this be changed? */
static struct omap_sdrc_params mt46h32m32lf_sdrc_params[] = { static struct omap_sdrc_params mt46h32m32lf6_sdrc_params[] = {
[0] = { [0] = {
.rate = 165941176, .rate = 165941176,
.actim_ctrla = 0x9a9db4c6, .actim_ctrla = 0x9a9db4c6,
......
...@@ -37,31 +37,11 @@ ...@@ -37,31 +37,11 @@
.text .text
ENTRY(omap34xx_sram_ddr_init)
stmfd sp!, {r0 - r12, lr} @ save registers on stack
ldmfd sp!, {r0 - r12, pc} @ restore regs and return
ENTRY(omap34xx_sram_ddr_init_sz)
.word . - omap34xx_sram_ddr_init
ENTRY(omap34xx_sram_reprogram_sdrc)
stmfd sp!, {r0 - r10, lr} @ save registers on stack
ldmfd sp!, {r0 - r10, pc} @ restore regs and return
ENTRY(omap34xx_sram_reprogram_sdrc_sz)
.word . - omap34xx_sram_reprogram_sdrc
/*
* Set dividers and pll. Also recalculate DLL value for DDR and unlock mode.
*/
ENTRY(omap34xx_sram_set_prcm)
stmfd sp!, {r0-r12, lr} @ regs to stack
ENTRY(omap34xx_sram_set_prcm_sz)
.word . - omap34xx_sram_set_prcm
/* /*
* Change frequency of core dpll * Change frequency of core dpll
* r0 = sdrc_rfr_ctrl r1 = sdrc_actim_ctrla r2 = sdrc_actim_ctrlb r3 = M2 * r0 = sdrc_rfr_ctrl r1 = sdrc_actim_ctrla r2 = sdrc_actim_ctrlb r3 = M2
*/ */
ENTRY(omap34xx_sram_configure_core_dpll) ENTRY(omap3_sram_configure_core_dpll)
stmfd sp!, {r1-r12, lr} @ store regs to stack stmfd sp!, {r1-r12, lr} @ store regs to stack
cmp r3, #0x2 cmp r3, #0x2
blne configure_sdrc blne configure_sdrc
...@@ -81,13 +61,13 @@ ENTRY(omap34xx_sram_configure_core_dpll) ...@@ -81,13 +61,13 @@ ENTRY(omap34xx_sram_configure_core_dpll)
mov r0, #0 @ return value mov r0, #0 @ return value
ldmfd sp!, {r1-r12, pc} @ restore regs and return ldmfd sp!, {r1-r12, pc} @ restore regs and return
unlock_dll: unlock_dll:
ldr r4, omap34xx_sdrc_dlla_ctrl ldr r4, omap3_sdrc_dlla_ctrl
ldr r5, [r4] ldr r5, [r4]
orr r5, r5, #0x4 orr r5, r5, #0x4
str r5, [r4] str r5, [r4]
bx lr bx lr
lock_dll: lock_dll:
ldr r4, omap34xx_sdrc_dlla_ctrl ldr r4, omap3_sdrc_dlla_ctrl
ldr r5, [r4] ldr r5, [r4]
bic r5, r5, #0x4 bic r5, r5, #0x4
str r5, [r4] str r5, [r4]
...@@ -95,23 +75,23 @@ lock_dll: ...@@ -95,23 +75,23 @@ lock_dll:
sdram_in_selfrefresh: sdram_in_selfrefresh:
mov r5, #0x0 @ Move 0 to R5 mov r5, #0x0 @ Move 0 to R5
mcr p15, 0, r5, c7, c10, 5 @ memory barrier mcr p15, 0, r5, c7, c10, 5 @ memory barrier
ldr r4, omap34xx_sdrc_power @ read the SDRC_POWER register ldr r4, omap3_sdrc_power @ read the SDRC_POWER register
ldr r5, [r4] @ read the contents of SDRC_POWER ldr r5, [r4] @ read the contents of SDRC_POWER
orr r5, r5, #0x40 @ enable self refresh on idle req orr r5, r5, #0x40 @ enable self refresh on idle req
str r5, [r4] @ write back to SDRC_POWER register str r5, [r4] @ write back to SDRC_POWER register
ldr r4, omap34xx_cm_iclken1_core @ read the CM_ICLKEN1_CORE reg ldr r4, omap3_cm_iclken1_core @ read the CM_ICLKEN1_CORE reg
ldr r5, [r4] ldr r5, [r4]
bic r5, r5, #0x2 @ disable iclk bit for SRDC bic r5, r5, #0x2 @ disable iclk bit for SRDC
str r5, [r4] str r5, [r4]
wait_sdrc_idle: wait_sdrc_idle:
ldr r4, omap34xx_cm_idlest1_core ldr r4, omap3_cm_idlest1_core
ldr r5, [r4] ldr r5, [r4]
and r5, r5, #0x2 @ check for SDRC idle and r5, r5, #0x2 @ check for SDRC idle
cmp r5, #2 cmp r5, #2
bne wait_sdrc_idle bne wait_sdrc_idle
bx lr bx lr
configure_core_dpll: configure_core_dpll:
ldr r4, omap34xx_cm_clksel1_pll ldr r4, omap3_cm_clksel1_pll
ldr r5, [r4] ldr r5, [r4]
ldr r6, core_m2_mask_val @ modify m2 for core dpll ldr r6, core_m2_mask_val @ modify m2 for core dpll
and r5, r5, r6 and r5, r5, r6
...@@ -136,74 +116,64 @@ wait_clk_stable: ...@@ -136,74 +116,64 @@ wait_clk_stable:
nop nop
bx lr bx lr
enable_sdrc: enable_sdrc:
ldr r4, omap34xx_cm_iclken1_core ldr r4, omap3_cm_iclken1_core
ldr r5, [r4] ldr r5, [r4]
orr r5, r5, #0x2 @ enable iclk bit for SDRC orr r5, r5, #0x2 @ enable iclk bit for SDRC
str r5, [r4] str r5, [r4]
wait_sdrc_idle1: wait_sdrc_idle1:
ldr r4, omap34xx_cm_idlest1_core ldr r4, omap3_cm_idlest1_core
ldr r5, [r4] ldr r5, [r4]
and r5, r5, #0x2 and r5, r5, #0x2
cmp r5, #0 cmp r5, #0
bne wait_sdrc_idle1 bne wait_sdrc_idle1
ldr r4, omap34xx_sdrc_power ldr r4, omap3_sdrc_power
ldr r5, [r4] ldr r5, [r4]
bic r5, r5, #0x40 bic r5, r5, #0x40
str r5, [r4] str r5, [r4]
bx lr bx lr
wait_dll_lock: wait_dll_lock:
ldr r4, omap34xx_sdrc_dlla_status ldr r4, omap3_sdrc_dlla_status
ldr r5, [r4] ldr r5, [r4]
and r5, r5, #0x4 and r5, r5, #0x4
cmp r5, #0x4 cmp r5, #0x4
bne wait_dll_lock bne wait_dll_lock
bx lr bx lr
wait_dll_unlock: wait_dll_unlock:
ldr r4, omap34xx_sdrc_dlla_status ldr r4, omap3_sdrc_dlla_status
ldr r5, [r4] ldr r5, [r4]
and r5, r5, #0x4 and r5, r5, #0x4
cmp r5, #0x0 cmp r5, #0x0
bne wait_dll_unlock bne wait_dll_unlock
bx lr bx lr
configure_sdrc: configure_sdrc:
ldr r4, omap34xx_sdrc_rfr_ctrl ldr r4, omap3_sdrc_rfr_ctrl
str r0, [r4] str r0, [r4]
ldr r4, omap34xx_sdrc_actim_ctrla ldr r4, omap3_sdrc_actim_ctrla
str r1, [r4] str r1, [r4]
ldr r4, omap34xx_sdrc_actim_ctrlb ldr r4, omap3_sdrc_actim_ctrlb
str r2, [r4] str r2, [r4]
bx lr bx lr
omap34xx_sdrc_power: omap3_sdrc_power:
.word OMAP34XX_SDRC_REGADDR(SDRC_POWER) .word OMAP34XX_SDRC_REGADDR(SDRC_POWER)
omap34xx_cm_clksel1_pll: omap3_cm_clksel1_pll:
.word OMAP34XX_CM_REGADDR(PLL_MOD, CM_CLKSEL1) .word OMAP34XX_CM_REGADDR(PLL_MOD, CM_CLKSEL1)
omap34xx_cm_idlest1_core: omap3_cm_idlest1_core:
.word OMAP34XX_CM_REGADDR(CORE_MOD, CM_IDLEST) .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_IDLEST)
omap34xx_cm_iclken1_core: omap3_cm_iclken1_core:
.word OMAP34XX_CM_REGADDR(CORE_MOD, CM_ICLKEN1) .word OMAP34XX_CM_REGADDR(CORE_MOD, CM_ICLKEN1)
omap34xx_sdrc_rfr_ctrl: omap3_sdrc_rfr_ctrl:
.word OMAP34XX_SDRC_REGADDR(SDRC_RFR_CTRL_0) .word OMAP34XX_SDRC_REGADDR(SDRC_RFR_CTRL_0)
omap34xx_sdrc_actim_ctrla: omap3_sdrc_actim_ctrla:
.word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_A) .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_A)
omap34xx_sdrc_actim_ctrlb: omap3_sdrc_actim_ctrlb:
.word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_B) .word OMAP34XX_SDRC_REGADDR(SDRC_ACTIM_CTRL_B)
omap34xx_sdrc_dlla_status: omap3_sdrc_dlla_status:
.word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_STATUS) .word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_STATUS)
omap34xx_sdrc_dlla_ctrl: omap3_sdrc_dlla_ctrl:
.word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_CTRL) .word OMAP34XX_SDRC_REGADDR(SDRC_DLLA_CTRL)
core_m2_mask_val: core_m2_mask_val:
.word 0xE7FFFFFF .word 0xE7FFFFFF
ENTRY(omap34xx_sram_configure_core_dpll_sz) ENTRY(omap3_sram_configure_core_dpll_sz)
.word . - omap34xx_sram_configure_core_dpll .word . - omap3_sram_configure_core_dpll
/*
* Reprogram GPMC
*/
ENTRY(omap34xx_sram_reprogram_gpmc)
stmfd sp!, {r0-r12, lr} @ regs to stack
ldmfd sp!, {r0-r12, pc} @ restore regs and return
ENTRY(omap34xx_sram_reprogram_gpmc_sz)
.word . - omap34xx_sram_reprogram_gpmc
...@@ -271,7 +271,7 @@ int __init omap1_sram_init(void) ...@@ -271,7 +271,7 @@ int __init omap1_sram_init(void)
#define omap1_sram_init() do {} while (0) #define omap1_sram_init() do {} while (0)
#endif #endif
#if defined(CONFIG_ARCH_OMAP2) || defined(CONFIG_ARCH_OMAP3) #if defined(CONFIG_ARCH_OMAP2)
static void (*_omap2_sram_ddr_init)(u32 *slow_dll_ctrl, u32 fast_dll_ctrl, static void (*_omap2_sram_ddr_init)(u32 *slow_dll_ctrl, u32 fast_dll_ctrl,
u32 base_cs, u32 force_unlock); u32 base_cs, u32 force_unlock);
...@@ -352,60 +352,41 @@ static inline int omap243x_sram_init(void) ...@@ -352,60 +352,41 @@ static inline int omap243x_sram_init(void)
#ifdef CONFIG_ARCH_OMAP3 #ifdef CONFIG_ARCH_OMAP3
static u32 (*_omap2_sram_reprogram_gpmc)(u32 perf_level); static u32 (*_omap3_sram_configure_core_dpll)(u32 sdrc_rfr_ctrl,
u32 omap2_sram_reprogram_gpmc(u32 perf_level) u32 sdrc_actim_ctrla,
{ u32 sdrc_actim_ctrlb,
if (!_omap2_sram_reprogram_gpmc) u32 m2);
u32 omap3_configure_core_dpll(u32 sdrc_rfr_ctrl, u32 sdrc_actim_ctrla,
u32 sdrc_actim_ctrlb, u32 m2)
{
if (!_omap3_sram_configure_core_dpll)
omap_sram_error(); omap_sram_error();
return _omap2_sram_reprogram_gpmc(perf_level); return _omap3_sram_configure_core_dpll(sdrc_rfr_ctrl,
} sdrc_actim_ctrla,
sdrc_actim_ctrlb, m2);
static u32 (*_omap2_sram_configure_core_dpll)(u32 m, u32 n, }
u32 freqsel, u32 m2);
u32 omap2_sram_configure_core_dpll(u32 m, u32 n, u32 freqsel, u32 m2)
{
if (!_omap2_sram_configure_core_dpll)
omap_sram_error();
return _omap2_sram_configure_core_dpll(m, n, freqsel, m2);
}
/* REVISIT: Should this be same as omap34xx_sram_init() after off-idle? */ /* REVISIT: Should this be same as omap34xx_sram_init() after off-idle? */
void restore_sram_functions(void) void restore_sram_functions(void)
{ {
omap_sram_ceil = omap_sram_base + omap_sram_size; omap_sram_ceil = omap_sram_base + omap_sram_size;
_omap2_sram_reprogram_gpmc = omap_sram_push(omap34xx_sram_reprogram_gpmc, _omap3_sram_configure_core_dpll =
omap34xx_sram_reprogram_gpmc_sz); omap_sram_push(omap3_sram_configure_core_dpll,
omap3_sram_configure_core_dpll_sz);
_omap2_sram_configure_core_dpll =
omap_sram_push(omap34xx_sram_configure_core_dpll,
omap34xx_sram_configure_core_dpll_sz);
} }
int __init omap34xx_sram_init(void) int __init omap3_sram_init(void)
{ {
_omap2_sram_ddr_init = omap_sram_push(omap34xx_sram_ddr_init, _omap3_sram_configure_core_dpll =
omap34xx_sram_ddr_init_sz); omap_sram_push(omap3_sram_configure_core_dpll,
omap3_sram_configure_core_dpll_sz);
_omap2_sram_reprogram_sdrc = omap_sram_push(omap34xx_sram_reprogram_sdrc,
omap34xx_sram_reprogram_sdrc_sz);
_omap2_set_prcm = omap_sram_push(omap34xx_sram_set_prcm,
omap34xx_sram_set_prcm_sz);
_omap2_sram_reprogram_gpmc = omap_sram_push(omap34xx_sram_reprogram_gpmc,
omap34xx_sram_reprogram_gpmc_sz);
_omap2_sram_configure_core_dpll =
omap_sram_push(omap34xx_sram_configure_core_dpll,
omap34xx_sram_configure_core_dpll_sz);
return 0; return 0;
} }
#else #else
static inline int omap34xx_sram_init(void) static inline int omap3_sram_init(void)
{ {
return 0; return 0;
} }
...@@ -423,7 +404,7 @@ int __init omap_sram_init(void) ...@@ -423,7 +404,7 @@ int __init omap_sram_init(void)
else if (cpu_is_omap2430()) else if (cpu_is_omap2430())
omap243x_sram_init(); omap243x_sram_init();
else if (cpu_is_omap34xx()) else if (cpu_is_omap34xx())
omap34xx_sram_init(); omap3_sram_init();
return 0; return 0;
} }
...@@ -21,6 +21,10 @@ extern void omap2_sram_reprogram_sdrc(u32 perf_level, u32 dll_val, ...@@ -21,6 +21,10 @@ extern void omap2_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
u32 mem_type); u32 mem_type);
extern u32 omap2_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val, int bypass); extern u32 omap2_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val, int bypass);
extern u32 omap3_configure_core_dpll(u32 sdrc_rfr_ctrl,
u32 sdrc_actim_ctrla,
u32 sdrc_actim_ctrlb, u32 m2);
/* Do not use these */ /* Do not use these */
extern void omap1_sram_reprogram_clock(u32 ckctl, u32 dpllctl); extern void omap1_sram_reprogram_clock(u32 ckctl, u32 dpllctl);
extern unsigned long omap1_sram_reprogram_clock_sz; extern unsigned long omap1_sram_reprogram_clock_sz;
...@@ -54,22 +58,9 @@ extern void omap243x_sram_reprogram_sdrc(u32 perf_level, u32 dll_val, ...@@ -54,22 +58,9 @@ extern void omap243x_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
extern unsigned long omap243x_sram_reprogram_sdrc_sz; extern unsigned long omap243x_sram_reprogram_sdrc_sz;
extern void omap34xx_sram_ddr_init(u32 *slow_dll_ctrl, u32 fast_dll_ctrl, extern u32 omap3_sram_configure_core_dpll(u32 sdrc_rfr_ctrl,
u32 base_cs, u32 force_unlock); u32 sdrc_actim_ctrla,
extern unsigned long omap34xx_sram_ddr_init_sz; u32 sdrc_actim_ctrlb, u32 m2);
extern unsigned long omap3_sram_configure_core_dpll_sz;
extern void omap34xx_sram_reprogram_sdrc(u32 perf_level, u32 dll_val,
u32 mem_type);
extern unsigned long omap34xx_sram_reprogram_sdrc_sz;
extern u32 omap34xx_sram_set_prcm(u32 dpll_ctrl_val, u32 sdrc_rfr_val,
int bypass);
extern unsigned long omap34xx_sram_set_prcm_sz;
extern u32 omap34xx_sram_reprogram_gpmc(u32 perf_level);
extern unsigned long omap34xx_sram_reprogram_gpmc_sz;
extern u32 omap34xx_sram_configure_core_dpll(u32 m, u32 n, u32 freqsel, u32 m2);
extern unsigned long omap34xx_sram_configure_core_dpll_sz;
#endif #endif
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment