Commit fa8966ba authored by Paul Walmsley's avatar Paul Walmsley Committed by Tony Lindgren

SRAM patcher: convert omap2_set_prcm to use runtime SRAM patcher

Use the runtime SRAM patcher to set register addresses in
omap2_set_prcm.  The long symbol names are intended to help
disambiguate the symbols, now that they are global.
Signed-off-by: default avatarPaul Walmsley <paul@pwsan.com>
Signed-off-by: default avatarTony Lindgren <tony@atomide.com>
parent 668b52da
...@@ -28,14 +28,6 @@ ...@@ -28,14 +28,6 @@
#include <asm/hardware.h> #include <asm/hardware.h>
#include <linux/poison.h> #include <linux/poison.h>
#define PRCM_CLKCFG_CTRL_V IO_ADDRESS(OMAP2_PRM_BASE + 0x080)
#define CM_CLKEN_PLL_V IO_ADDRESS(OMAP2_CM_BASE + 0x500)
#define CM_IDLEST_CKGEN_V IO_ADDRESS(OMAP2_CM_BASE + 0x520)
#define CM_CLKSEL1_PLL_V IO_ADDRESS(OMAP2_CM_BASE + 0x540)
#define SDRC_DLLA_CTRL_V IO_ADDRESS(OMAP2_SDRC_BASE + 0x060)
#define SDRC_RFR_CTRL_V IO_ADDRESS(OMAP2_SDRC_BASE + 0x0a4)
.text .text
ENTRY(sram_ddr_init) ENTRY(sram_ddr_init)
...@@ -256,13 +248,13 @@ ENTRY(sram_set_prcm) ...@@ -256,13 +248,13 @@ ENTRY(sram_set_prcm)
mcrr p15, 1, r8, r4, c12 @ preload into icache mcrr p15, 1, r8, r4, c12 @ preload into icache
pbegin: pbegin:
/* move into fast relock bypass */ /* move into fast relock bypass */
ldr r8, pll_ctl @ get addr ldr r8, omap2_ssp_pll_ctl @ get addr
ldr r5, [r8] @ get val ldr r5, [r8] @ get val
mvn r6, #0x3 @ clear mask mvn r6, #0x3 @ clear mask
and r5, r5, r6 @ clear field and r5, r5, r6 @ clear field
orr r7, r5, #0x2 @ fast relock val orr r7, r5, #0x2 @ fast relock val
str r7, [r8] @ go to fast relock str r7, [r8] @ go to fast relock
ldr r4, pll_stat @ addr of stat ldr r4, omap2_ssp_pll_stat @ addr of stat
block: block:
/* wait for bypass */ /* wait for bypass */
ldr r8, [r4] @ stat value ldr r8, [r4] @ stat value
...@@ -271,10 +263,10 @@ block: ...@@ -271,10 +263,10 @@ block:
bne block @ loop if not bne block @ loop if not
/* set new dpll dividers _after_ in bypass */ /* set new dpll dividers _after_ in bypass */
ldr r4, pll_div @ get addr ldr r4, omap2_ssp_pll_div @ get addr
str r0, [r4] @ set dpll ctrl val str r0, [r4] @ set dpll ctrl val
ldr r4, set_config @ get addr ldr r4, omap2_ssp_set_config @ get addr
mov r8, #1 @ valid cfg msk mov r8, #1 @ valid cfg msk
str r8, [r4] @ make dividers take str r8, [r4] @ make dividers take
...@@ -288,8 +280,8 @@ wait_a_bit: ...@@ -288,8 +280,8 @@ wait_a_bit:
beq pend @ jump over dpll relock beq pend @ jump over dpll relock
/* relock DPLL with new vals */ /* relock DPLL with new vals */
ldr r5, pll_stat @ get addr ldr r5, omap2_ssp_pll_stat @ get addr
ldr r4, pll_ctl @ get addr ldr r4, omap2_ssp_pll_ctl @ get addr
orr r8, r7, #0x3 @ val for lock dpll orr r8, r7, #0x3 @ val for lock dpll
str r8, [r4] @ set val str r8, [r4] @ set val
mov r0, #1000 @ dead spin a bit mov r0, #1000 @ dead spin a bit
...@@ -303,9 +295,9 @@ wait_lock: ...@@ -303,9 +295,9 @@ wait_lock:
bne wait_lock @ wait if not bne wait_lock @ wait if not
pend: pend:
/* update memory timings & briefly lock dll */ /* update memory timings & briefly lock dll */
ldr r4, sdrc_rfr @ get addr ldr r4, omap2_ssp_sdrc_rfr @ get addr
str r1, [r4] @ update refresh timing str r1, [r4] @ update refresh timing
ldr r11, dlla_ctrl @ get addr of DLLA ctrl ldr r11, omap2_ssp_dlla_ctrl @ get addr of DLLA ctrl
ldr r10, [r11] @ get current val ldr r10, [r11] @ get current val
mvn r9, #0x4 @ mask to get clear bit2 mvn r9, #0x4 @ mask to get clear bit2
and r10, r10, r9 @ clear bit2 for lock mode and r10, r10, r9 @ clear bit2 for lock mode
...@@ -321,18 +313,25 @@ wait_dll_lock: ...@@ -321,18 +313,25 @@ wait_dll_lock:
nop nop
ldmfd sp!, {r0-r12, pc} @ restore regs and return ldmfd sp!, {r0-r12, pc} @ restore regs and return
set_config: .globl omap2_ssp_set_config
.word PRCM_CLKCFG_CTRL_V .globl omap2_ssp_pll_ctl
pll_ctl: .globl omap2_ssp_pll_stat
.word CM_CLKEN_PLL_V .globl omap2_ssp_pll_div
pll_stat: .globl omap2_ssp_sdrc_rfr
.word CM_IDLEST_CKGEN_V .globl omap2_ssp_dlla_ctrl
pll_div:
.word CM_CLKSEL1_PLL_V omap2_ssp_set_config:
sdrc_rfr: .word SRAM_VA_MAGIC
.word SDRC_RFR_CTRL_V omap2_ssp_pll_ctl:
dlla_ctrl: .word SRAM_VA_MAGIC
.word SDRC_DLLA_CTRL_V omap2_ssp_pll_stat:
.word SRAM_VA_MAGIC
omap2_ssp_pll_div:
.word SRAM_VA_MAGIC
omap2_ssp_sdrc_rfr:
.word SRAM_VA_MAGIC
omap2_ssp_dlla_ctrl:
.word SRAM_VA_MAGIC
ENTRY(sram_set_prcm_sz) ENTRY(sram_set_prcm_sz)
.word . - sram_set_prcm .word . - sram_set_prcm
...@@ -74,6 +74,12 @@ extern void *omap2_srs_sdrc_dlla_ctrl; ...@@ -74,6 +74,12 @@ extern void *omap2_srs_sdrc_dlla_ctrl;
extern void *omap2_srs_sdrc_rfr_ctrl; extern void *omap2_srs_sdrc_rfr_ctrl;
extern void *omap2_srs_prcm_voltctrl; extern void *omap2_srs_prcm_voltctrl;
extern void *omap2_srs_timer_32ksynct; extern void *omap2_srs_timer_32ksynct;
extern void *omap2_ssp_set_config;
extern void *omap2_ssp_pll_ctl;
extern void *omap2_ssp_pll_stat;
extern void *omap2_ssp_pll_div;
extern void *omap2_ssp_sdrc_rfr;
extern void *omap2_ssp_dlla_ctrl;
/* /*
...@@ -377,6 +383,26 @@ int __init omap2_sram_init(void) ...@@ -377,6 +383,26 @@ int __init omap2_sram_init(void)
_omap2_set_prcm = omap_sram_push(sram_set_prcm, sram_set_prcm_sz); _omap2_set_prcm = omap_sram_push(sram_set_prcm, sram_set_prcm_sz);
/* REVISIT: prefix all these symbols with omap2_sram_ */
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_set_config,
_omap2_set_prcm,
OMAP24XX_PRCM_CLKCFG_CTRL);
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_pll_ctl,
_omap2_set_prcm,
OMAP_CM_REGADDR(PLL_MOD, CM_CLKEN));
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_pll_stat,
_omap2_set_prcm,
OMAP_CM_REGADDR(PLL_MOD, CM_IDLEST));
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_pll_div,
_omap2_set_prcm,
OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL1));
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_sdrc_rfr,
_omap2_set_prcm,
OMAP_SDRC_REGADDR(SDRC_RFR_CTRL_0));
omap_sram_patch_va(sram_set_prcm, &omap2_ssp_dlla_ctrl,
_omap2_set_prcm,
OMAP_SDRC_REGADDR(SDRC_DLLA_CTRL));
return 0; return 0;
} }
#else #else
......
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