Commit 668b52da authored by Paul Walmsley's avatar Paul Walmsley Committed by Tony Lindgren

SRAM patcher: convert sram_reprogram_sdrc to use runtime SRAM patcher

Use the runtime SRAM patcher to set register addresses in
sram_reprogram_sdrc.  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 67852731
...@@ -29,7 +29,7 @@ ...@@ -29,7 +29,7 @@
#define SDRC_DLLB_STATUS 0x06C #define SDRC_DLLB_STATUS 0x06C
#define SDRC_POWER 0x070 #define SDRC_POWER 0x070
#define SDRC_MR_0 0x084 #define SDRC_MR_0 0x084
#define SDRC_RFR_CTRL_0 0x0a4
/* SDRC global register get/set */ /* SDRC global register get/set */
......
...@@ -28,10 +28,6 @@ ...@@ -28,10 +28,6 @@
#include <asm/hardware.h> #include <asm/hardware.h>
#include <linux/poison.h> #include <linux/poison.h>
#define TIMER_32KSYNCT_CR_V IO_ADDRESS(OMAP2_32KSYNCT_BASE + 0x010)
#define CM_CLKSEL2_PLL_V IO_ADDRESS(OMAP2_CM_BASE + 0x544)
#define PRCM_VOLTCTRL_V IO_ADDRESS(OMAP2_PRM_BASE + 0x050)
#define PRCM_CLKCFG_CTRL_V IO_ADDRESS(OMAP2_PRM_BASE + 0x080) #define PRCM_CLKCFG_CTRL_V IO_ADDRESS(OMAP2_PRM_BASE + 0x080)
#define CM_CLKEN_PLL_V IO_ADDRESS(OMAP2_CM_BASE + 0x500) #define CM_CLKEN_PLL_V IO_ADDRESS(OMAP2_CM_BASE + 0x500)
#define CM_IDLEST_CKGEN_V IO_ADDRESS(OMAP2_CM_BASE + 0x520) #define CM_IDLEST_CKGEN_V IO_ADDRESS(OMAP2_CM_BASE + 0x520)
...@@ -158,7 +154,7 @@ ENTRY(sram_reprogram_sdrc) ...@@ -158,7 +154,7 @@ ENTRY(sram_reprogram_sdrc)
mcr p15, 0, r3, c7, c10, 4 @ memory barrier, finish ARM SDR/DDR mcr p15, 0, r3, c7, c10, 4 @ memory barrier, finish ARM SDR/DDR
nop nop
nop nop
ldr r6, ddr_sdrc_rfr_ctrl @ get addr of refresh reg ldr r6, omap2_srs_sdrc_rfr_ctrl @ get addr of refresh reg
ldr r5, [r6] @ get value ldr r5, [r6] @ get value
mov r5, r5, lsr #8 @ isolate rfr field and drop burst mov r5, r5, lsr #8 @ isolate rfr field and drop burst
...@@ -172,7 +168,7 @@ ENTRY(sram_reprogram_sdrc) ...@@ -172,7 +168,7 @@ ENTRY(sram_reprogram_sdrc)
movne r5, r5, lsl #1 @ mult by 2 if to full movne r5, r5, lsl #1 @ mult by 2 if to full
mov r5, r5, lsl #8 @ put rfr field back into place mov r5, r5, lsl #8 @ put rfr field back into place
add r5, r5, #0x1 @ turn on burst of 1 add r5, r5, #0x1 @ turn on burst of 1
ldr r4, ddr_cm_clksel2_pll @ get address of out reg ldr r4, omap2_srs_cm_clksel2_pll @ get address of out reg
ldr r3, [r4] @ get curr value ldr r3, [r4] @ get curr value
orr r3, r3, #0x3 orr r3, r3, #0x3
bic r3, r3, #0x3 @ clear lower bits bic r3, r3, #0x3 @ clear lower bits
...@@ -193,7 +189,7 @@ ENTRY(sram_reprogram_sdrc) ...@@ -193,7 +189,7 @@ ENTRY(sram_reprogram_sdrc)
bne freq_out @ leave if SDR, no DLL function bne freq_out @ leave if SDR, no DLL function
/* With DDR, we need to take care of the DLL for the frequency change */ /* With DDR, we need to take care of the DLL for the frequency change */
ldr r2, ddr_sdrc_dlla_ctrl @ addr of dlla ctrl ldr r2, omap2_srs_sdrc_dlla_ctrl @ addr of dlla ctrl
str r1, [r2] @ write out new SDRC_DLLA_CTRL str r1, [r2] @ write out new SDRC_DLLA_CTRL
add r2, r2, #0x8 @ addr to SDRC_DLLB_CTRL add r2, r2, #0x8 @ addr to SDRC_DLLB_CTRL
str r1, [r2] @ commit to SDRC_DLLB_CTRL str r1, [r2] @ commit to SDRC_DLLB_CTRL
...@@ -209,7 +205,7 @@ freq_out: ...@@ -209,7 +205,7 @@ freq_out:
* wait for it to finish, use 32k sync counter, 1tick=31uS. * wait for it to finish, use 32k sync counter, 1tick=31uS.
*/ */
voltage_shift_c: voltage_shift_c:
ldr r10, ddr_prcm_voltctrl @ get addr of volt ctrl ldr r10, omap2_srs_prcm_voltctrl @ get addr of volt ctrl
ldr r8, [r10] @ get value ldr r8, [r10] @ get value
ldr r7, ddr_prcm_mask_val @ get value of mask ldr r7, ddr_prcm_mask_val @ get value of mask
and r8, r8, r7 @ apply mask to clear bits and r8, r8, r7 @ apply mask to clear bits
...@@ -219,7 +215,7 @@ voltage_shift_c: ...@@ -219,7 +215,7 @@ voltage_shift_c:
orr r8, r8, r7 @ build value for force orr r8, r8, r7 @ build value for force
str r8, [r10] @ Force transition to L1 str r8, [r10] @ Force transition to L1
ldr r10, ddr_timer_32ksynct @ get addr of counter ldr r10, omap2_srs_timer_32ksynct @ get addr of counter
ldr r8, [r10] @ get value ldr r8, [r10] @ get value
add r8, r8, #0x2 @ give it at most 62uS (min 31+) add r8, r8, #0x2 @ give it at most 62uS (min 31+)
volt_delay_c: volt_delay_c:
...@@ -228,18 +224,24 @@ volt_delay_c: ...@@ -228,18 +224,24 @@ volt_delay_c:
bhi volt_delay_c @ not yet->branch bhi volt_delay_c @ not yet->branch
mov pc, lr @ back to caller mov pc, lr @ back to caller
ddr_cm_clksel2_pll: .globl omap2_srs_cm_clksel2_pll
.word CM_CLKSEL2_PLL_V .globl omap2_srs_sdrc_dlla_ctrl
ddr_sdrc_dlla_ctrl: .globl omap2_srs_sdrc_rfr_ctrl
.word SDRC_DLLA_CTRL_V .globl omap2_srs_prcm_voltctrl
ddr_sdrc_rfr_ctrl: .globl omap2_srs_timer_32ksynct
.word SDRC_RFR_CTRL_V
ddr_prcm_voltctrl: omap2_srs_cm_clksel2_pll:
.word PRCM_VOLTCTRL_V .word SRAM_VA_MAGIC
omap2_srs_sdrc_dlla_ctrl:
.word SRAM_VA_MAGIC
omap2_srs_sdrc_rfr_ctrl:
.word SRAM_VA_MAGIC
omap2_srs_prcm_voltctrl:
.word SRAM_VA_MAGIC
ddr_prcm_mask_val: ddr_prcm_mask_val:
.word 0xFFFF3FFC .word 0xFFFF3FFC
ddr_timer_32ksynct: omap2_srs_timer_32ksynct:
.word TIMER_32KSYNCT_CR_V .word SRAM_VA_MAGIC
ENTRY(sram_reprogram_sdrc_sz) ENTRY(sram_reprogram_sdrc_sz)
.word . - sram_reprogram_sdrc .word . - sram_reprogram_sdrc
......
...@@ -69,6 +69,11 @@ extern void *omap2_sdi_cm_clksel2_pll; ...@@ -69,6 +69,11 @@ extern void *omap2_sdi_cm_clksel2_pll;
extern void *omap2_sdi_sdrc_dlla_ctrl; extern void *omap2_sdi_sdrc_dlla_ctrl;
extern void *omap2_sdi_prcm_voltctrl; extern void *omap2_sdi_prcm_voltctrl;
extern void *omap2_sdi_timer_32ksynct_cr; extern void *omap2_sdi_timer_32ksynct_cr;
extern void *omap2_srs_cm_clksel2_pll;
extern void *omap2_srs_sdrc_dlla_ctrl;
extern void *omap2_srs_sdrc_rfr_ctrl;
extern void *omap2_srs_prcm_voltctrl;
extern void *omap2_srs_timer_32ksynct;
/* /*
...@@ -353,6 +358,23 @@ int __init omap2_sram_init(void) ...@@ -353,6 +358,23 @@ int __init omap2_sram_init(void)
_omap2_sram_reprogram_sdrc = omap_sram_push(sram_reprogram_sdrc, _omap2_sram_reprogram_sdrc = omap_sram_push(sram_reprogram_sdrc,
sram_reprogram_sdrc_sz); sram_reprogram_sdrc_sz);
omap_sram_patch_va(sram_reprogram_sdrc, &omap2_srs_cm_clksel2_pll,
_omap2_sram_reprogram_sdrc,
OMAP_CM_REGADDR(PLL_MOD, CM_CLKSEL2));
omap_sram_patch_va(sram_reprogram_sdrc, &omap2_srs_sdrc_dlla_ctrl,
_omap2_sram_reprogram_sdrc,
OMAP_SDRC_REGADDR(SDRC_DLLA_CTRL));
omap_sram_patch_va(sram_reprogram_sdrc, &omap2_srs_sdrc_rfr_ctrl,
_omap2_sram_reprogram_sdrc,
OMAP_SDRC_REGADDR(SDRC_RFR_CTRL_0));
omap_sram_patch_va(sram_reprogram_sdrc, &omap2_srs_prcm_voltctrl,
_omap2_sram_reprogram_sdrc,
OMAP24XX_PRCM_VOLTCTRL);
omap_sram_patch_va(sram_reprogram_sdrc, &omap2_srs_timer_32ksynct,
_omap2_sram_reprogram_sdrc,
(void __iomem *)IO_ADDRESS(OMAP2_32KSYNCT_BASE + 0x010));
_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);
return 0; return 0;
......
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