diff options
-rw-r--r-- | arch/arm/mach-omap2/Makefile | 6 | ||||
-rw-r--r-- | arch/arm/mach-omap2/clock24xx.c | 23 | ||||
-rw-r--r-- | arch/arm/mach-omap2/io.c | 2 | ||||
-rw-r--r-- | arch/arm/mach-omap2/sdrc.c | 57 | ||||
-rw-r--r-- | arch/arm/mach-omap2/sdrc2xxx.c | 67 | ||||
-rw-r--r-- | arch/arm/plat-omap/common.c | 2 | ||||
-rw-r--r-- | arch/arm/plat-omap/include/mach/common.h | 2 | ||||
-rw-r--r-- | arch/arm/plat-omap/include/mach/sdrc.h | 37 |
8 files changed, 115 insertions, 81 deletions
diff --git a/arch/arm/mach-omap2/Makefile b/arch/arm/mach-omap2/Makefile index bb47d43af396..9717afcdbda7 100644 --- a/arch/arm/mach-omap2/Makefile +++ b/arch/arm/mach-omap2/Makefile | |||
@@ -3,7 +3,7 @@ | |||
3 | # | 3 | # |
4 | 4 | ||
5 | # Common support | 5 | # Common support |
6 | obj-y := irq.o id.o io.o sdrc2xxx.o control.o prcm.o clock.o mux.o \ | 6 | obj-y := irq.o id.o io.o sdrc.o control.o prcm.o clock.o mux.o \ |
7 | devices.o serial.o gpmc.o timer-gp.o powerdomain.o \ | 7 | devices.o serial.o gpmc.o timer-gp.o powerdomain.o \ |
8 | clockdomain.o | 8 | clockdomain.o |
9 | 9 | ||
@@ -14,6 +14,10 @@ obj-$(CONFIG_ARCH_OMAP2420) += sram242x.o | |||
14 | obj-$(CONFIG_ARCH_OMAP2430) += sram243x.o | 14 | obj-$(CONFIG_ARCH_OMAP2430) += sram243x.o |
15 | obj-$(CONFIG_ARCH_OMAP3) += sram34xx.o | 15 | obj-$(CONFIG_ARCH_OMAP3) += sram34xx.o |
16 | 16 | ||
17 | # SMS/SDRC | ||
18 | obj-$(CONFIG_ARCH_OMAP2) += sdrc2xxx.o | ||
19 | # obj-$(CONFIG_ARCH_OMAP3) += sdrc3xxx.o | ||
20 | |||
17 | # Power Management | 21 | # Power Management |
18 | ifeq ($(CONFIG_PM),y) | 22 | ifeq ($(CONFIG_PM),y) |
19 | obj-y += pm.o | 23 | obj-y += pm.o |
diff --git a/arch/arm/mach-omap2/clock24xx.c b/arch/arm/mach-omap2/clock24xx.c index 83911ad48733..a11e7c71177c 100644 --- a/arch/arm/mach-omap2/clock24xx.c +++ b/arch/arm/mach-omap2/clock24xx.c | |||
@@ -389,9 +389,9 @@ static int omap2_reprogram_dpllcore(struct clk *clk, unsigned long rate) | |||
389 | mult &= OMAP24XX_CORE_CLK_SRC_MASK; | 389 | mult &= OMAP24XX_CORE_CLK_SRC_MASK; |
390 | 390 | ||
391 | if ((rate == (cur_rate / 2)) && (mult == 2)) { | 391 | if ((rate == (cur_rate / 2)) && (mult == 2)) { |
392 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL, 1); | 392 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL, 1); |
393 | } else if ((rate == (cur_rate * 2)) && (mult == 1)) { | 393 | } else if ((rate == (cur_rate * 2)) && (mult == 1)) { |
394 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL_X2, 1); | 394 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL_X2, 1); |
395 | } else if (rate != cur_rate) { | 395 | } else if (rate != cur_rate) { |
396 | valid_rate = omap2_dpllcore_round_rate(rate); | 396 | valid_rate = omap2_dpllcore_round_rate(rate); |
397 | if (valid_rate != rate) | 397 | if (valid_rate != rate) |
@@ -430,15 +430,16 @@ static int omap2_reprogram_dpllcore(struct clk *clk, unsigned long rate) | |||
430 | if (rate == curr_prcm_set->xtal_speed) /* If asking for 1-1 */ | 430 | if (rate == curr_prcm_set->xtal_speed) /* If asking for 1-1 */ |
431 | bypass = 1; | 431 | bypass = 1; |
432 | 432 | ||
433 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL_X2, 1); /* For init_mem */ | 433 | /* For omap2xxx_sdrc_init_params() */ |
434 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL_X2, 1); | ||
434 | 435 | ||
435 | /* Force dll lock mode */ | 436 | /* Force dll lock mode */ |
436 | omap2_set_prcm(tmpset.cm_clksel1_pll, tmpset.base_sdrc_rfr, | 437 | omap2_set_prcm(tmpset.cm_clksel1_pll, tmpset.base_sdrc_rfr, |
437 | bypass); | 438 | bypass); |
438 | 439 | ||
439 | /* Errata: ret dll entry state */ | 440 | /* Errata: ret dll entry state */ |
440 | omap2_init_memory_params(omap2_dll_force_needed()); | 441 | omap2xxx_sdrc_init_params(omap2xxx_sdrc_dll_is_unlocked()); |
441 | omap2_reprogram_sdrc(done_rate, 0); | 442 | omap2xxx_sdrc_reprogram(done_rate, 0); |
442 | } | 443 | } |
443 | omap2_dpllcore_recalc(&dpll_ck); | 444 | omap2_dpllcore_recalc(&dpll_ck); |
444 | ret = 0; | 445 | ret = 0; |
@@ -525,9 +526,9 @@ static int omap2_select_table_rate(struct clk *clk, unsigned long rate) | |||
525 | cur_rate = omap2_get_dpll_rate_24xx(&dpll_ck); | 526 | cur_rate = omap2_get_dpll_rate_24xx(&dpll_ck); |
526 | 527 | ||
527 | if (prcm->dpll_speed == cur_rate / 2) { | 528 | if (prcm->dpll_speed == cur_rate / 2) { |
528 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL, 1); | 529 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL, 1); |
529 | } else if (prcm->dpll_speed == cur_rate * 2) { | 530 | } else if (prcm->dpll_speed == cur_rate * 2) { |
530 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL_X2, 1); | 531 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL_X2, 1); |
531 | } else if (prcm->dpll_speed != cur_rate) { | 532 | } else if (prcm->dpll_speed != cur_rate) { |
532 | local_irq_save(flags); | 533 | local_irq_save(flags); |
533 | 534 | ||
@@ -558,14 +559,14 @@ static int omap2_select_table_rate(struct clk *clk, unsigned long rate) | |||
558 | cm_write_mod_reg(prcm->cm_clksel_mdm, | 559 | cm_write_mod_reg(prcm->cm_clksel_mdm, |
559 | OMAP2430_MDM_MOD, CM_CLKSEL); | 560 | OMAP2430_MDM_MOD, CM_CLKSEL); |
560 | 561 | ||
561 | /* x2 to enter init_mem */ | 562 | /* x2 to enter omap2xxx_sdrc_init_params() */ |
562 | omap2_reprogram_sdrc(CORE_CLK_SRC_DPLL_X2, 1); | 563 | omap2xxx_sdrc_reprogram(CORE_CLK_SRC_DPLL_X2, 1); |
563 | 564 | ||
564 | omap2_set_prcm(prcm->cm_clksel1_pll, prcm->base_sdrc_rfr, | 565 | omap2_set_prcm(prcm->cm_clksel1_pll, prcm->base_sdrc_rfr, |
565 | bypass); | 566 | bypass); |
566 | 567 | ||
567 | omap2_init_memory_params(omap2_dll_force_needed()); | 568 | omap2xxx_sdrc_init_params(omap2xxx_sdrc_dll_is_unlocked()); |
568 | omap2_reprogram_sdrc(done_rate, 0); | 569 | omap2xxx_sdrc_reprogram(done_rate, 0); |
569 | 570 | ||
570 | local_irq_restore(flags); | 571 | local_irq_restore(flags); |
571 | } | 572 | } |
diff --git a/arch/arm/mach-omap2/io.c b/arch/arm/mach-omap2/io.c index 2b5f28a3c4b4..3c1de3615eb8 100644 --- a/arch/arm/mach-omap2/io.c +++ b/arch/arm/mach-omap2/io.c | |||
@@ -201,6 +201,6 @@ void __init omap2_init_common_hw(void) | |||
201 | pwrdm_init(powerdomains_omap); | 201 | pwrdm_init(powerdomains_omap); |
202 | clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps); | 202 | clkdm_init(clockdomains_omap, clkdm_pwrdm_autodeps); |
203 | omap2_clk_init(); | 203 | omap2_clk_init(); |
204 | omap2_init_memory(); | 204 | omap2_sdrc_init(); |
205 | gpmc_init(); | 205 | gpmc_init(); |
206 | } | 206 | } |
diff --git a/arch/arm/mach-omap2/sdrc.c b/arch/arm/mach-omap2/sdrc.c new file mode 100644 index 000000000000..24b54d50b893 --- /dev/null +++ b/arch/arm/mach-omap2/sdrc.c | |||
@@ -0,0 +1,57 @@ | |||
1 | /* | ||
2 | * SMS/SDRC (SDRAM controller) common code for OMAP2/3 | ||
3 | * | ||
4 | * Copyright (C) 2005, 2008 Texas Instruments Inc. | ||
5 | * Copyright (C) 2005, 2008 Nokia Corporation | ||
6 | * | ||
7 | * Tony Lindgren <tony@atomide.com> | ||
8 | * Paul Walmsley | ||
9 | * Richard Woodruff <r-woodruff2@ti.com> | ||
10 | * | ||
11 | * This program is free software; you can redistribute it and/or modify | ||
12 | * it under the terms of the GNU General Public License version 2 as | ||
13 | * published by the Free Software Foundation. | ||
14 | */ | ||
15 | |||
16 | #include <linux/module.h> | ||
17 | #include <linux/kernel.h> | ||
18 | #include <linux/device.h> | ||
19 | #include <linux/list.h> | ||
20 | #include <linux/errno.h> | ||
21 | #include <linux/delay.h> | ||
22 | #include <linux/clk.h> | ||
23 | #include <linux/io.h> | ||
24 | |||
25 | #include <mach/common.h> | ||
26 | #include <mach/clock.h> | ||
27 | #include <mach/sram.h> | ||
28 | |||
29 | #include "prm.h" | ||
30 | |||
31 | #include <mach/sdrc.h> | ||
32 | #include "sdrc.h" | ||
33 | |||
34 | void __iomem *omap2_sdrc_base; | ||
35 | void __iomem *omap2_sms_base; | ||
36 | |||
37 | void __init omap2_set_globals_sdrc(struct omap_globals *omap2_globals) | ||
38 | { | ||
39 | omap2_sdrc_base = omap2_globals->sdrc; | ||
40 | omap2_sms_base = omap2_globals->sms; | ||
41 | } | ||
42 | |||
43 | /* turn on smart idle modes for SDRAM scheduler and controller */ | ||
44 | void __init omap2_sdrc_init(void) | ||
45 | { | ||
46 | u32 l; | ||
47 | |||
48 | l = sms_read_reg(SMS_SYSCONFIG); | ||
49 | l &= ~(0x3 << 3); | ||
50 | l |= (0x2 << 3); | ||
51 | sms_write_reg(l, SMS_SYSCONFIG); | ||
52 | |||
53 | l = sdrc_read_reg(SDRC_SYSCONFIG); | ||
54 | l &= ~(0x3 << 3); | ||
55 | l |= (0x2 << 3); | ||
56 | sdrc_write_reg(l, SDRC_SYSCONFIG); | ||
57 | } | ||
diff --git a/arch/arm/mach-omap2/sdrc2xxx.c b/arch/arm/mach-omap2/sdrc2xxx.c index 3e38aa4ea458..3a47aba29031 100644 --- a/arch/arm/mach-omap2/sdrc2xxx.c +++ b/arch/arm/mach-omap2/sdrc2xxx.c | |||
@@ -3,11 +3,12 @@ | |||
3 | * | 3 | * |
4 | * SDRAM timing related functions for OMAP2xxx | 4 | * SDRAM timing related functions for OMAP2xxx |
5 | * | 5 | * |
6 | * Copyright (C) 2005 Texas Instruments Inc. | 6 | * Copyright (C) 2005, 2008 Texas Instruments Inc. |
7 | * Richard Woodruff <r-woodruff2@ti.com> | 7 | * Copyright (C) 2005, 2008 Nokia Corporation |
8 | * | 8 | * |
9 | * Copyright (C) 2005 Nokia Corporation | ||
10 | * Tony Lindgren <tony@atomide.com> | 9 | * Tony Lindgren <tony@atomide.com> |
10 | * Paul Walmsley | ||
11 | * Richard Woodruff <r-woodruff2@ti.com> | ||
11 | * | 12 | * |
12 | * This program is free software; you can redistribute it and/or modify | 13 | * This program is free software; you can redistribute it and/or modify |
13 | * it under the terms of the GNU General Public License version 2 as | 14 | * it under the terms of the GNU General Public License version 2 as |
@@ -39,23 +40,20 @@ | |||
39 | #define M_LOCK 1 | 40 | #define M_LOCK 1 |
40 | 41 | ||
41 | 42 | ||
42 | void __iomem *omap2_sdrc_base; | ||
43 | void __iomem *omap2_sms_base; | ||
44 | |||
45 | static struct memory_timings mem_timings; | 43 | static struct memory_timings mem_timings; |
46 | static u32 curr_perf_level = CORE_CLK_SRC_DPLL_X2; | 44 | static u32 curr_perf_level = CORE_CLK_SRC_DPLL_X2; |
47 | 45 | ||
48 | u32 omap2_memory_get_slow_dll_ctrl(void) | 46 | static u32 omap2xxx_sdrc_get_slow_dll_ctrl(void) |
49 | { | 47 | { |
50 | return mem_timings.slow_dll_ctrl; | 48 | return mem_timings.slow_dll_ctrl; |
51 | } | 49 | } |
52 | 50 | ||
53 | u32 omap2_memory_get_fast_dll_ctrl(void) | 51 | static u32 omap2xxx_sdrc_get_fast_dll_ctrl(void) |
54 | { | 52 | { |
55 | return mem_timings.fast_dll_ctrl; | 53 | return mem_timings.fast_dll_ctrl; |
56 | } | 54 | } |
57 | 55 | ||
58 | u32 omap2_memory_get_type(void) | 56 | static u32 omap2xxx_sdrc_get_type(void) |
59 | { | 57 | { |
60 | return mem_timings.m_type; | 58 | return mem_timings.m_type; |
61 | } | 59 | } |
@@ -64,7 +62,7 @@ u32 omap2_memory_get_type(void) | |||
64 | * Check the DLL lock state, and return tue if running in unlock mode. | 62 | * Check the DLL lock state, and return tue if running in unlock mode. |
65 | * This is needed to compensate for the shifted DLL value in unlock mode. | 63 | * This is needed to compensate for the shifted DLL value in unlock mode. |
66 | */ | 64 | */ |
67 | u32 omap2_dll_force_needed(void) | 65 | u32 omap2xxx_sdrc_dll_is_unlocked(void) |
68 | { | 66 | { |
69 | /* dlla and dllb are a set */ | 67 | /* dlla and dllb are a set */ |
70 | u32 dll_state = sdrc_read_reg(SDRC_DLLA_CTRL); | 68 | u32 dll_state = sdrc_read_reg(SDRC_DLLA_CTRL); |
@@ -79,8 +77,10 @@ u32 omap2_dll_force_needed(void) | |||
79 | * 'level' is the value to store to CM_CLKSEL2_PLL.CORE_CLK_SRC. | 77 | * 'level' is the value to store to CM_CLKSEL2_PLL.CORE_CLK_SRC. |
80 | * Practical values are CORE_CLK_SRC_DPLL (for CORE_CLK = DPLL_CLK) or | 78 | * Practical values are CORE_CLK_SRC_DPLL (for CORE_CLK = DPLL_CLK) or |
81 | * CORE_CLK_SRC_DPLL_X2 (for CORE_CLK = * DPLL_CLK * 2) | 79 | * CORE_CLK_SRC_DPLL_X2 (for CORE_CLK = * DPLL_CLK * 2) |
80 | * | ||
81 | * Used by the clock framework during CORE DPLL changes | ||
82 | */ | 82 | */ |
83 | u32 omap2_reprogram_sdrc(u32 level, u32 force) | 83 | u32 omap2xxx_sdrc_reprogram(u32 level, u32 force) |
84 | { | 84 | { |
85 | u32 dll_ctrl, m_type; | 85 | u32 dll_ctrl, m_type; |
86 | u32 prev = curr_perf_level; | 86 | u32 prev = curr_perf_level; |
@@ -90,13 +90,13 @@ u32 omap2_reprogram_sdrc(u32 level, u32 force) | |||
90 | return prev; | 90 | return prev; |
91 | 91 | ||
92 | if (level == CORE_CLK_SRC_DPLL) | 92 | if (level == CORE_CLK_SRC_DPLL) |
93 | dll_ctrl = omap2_memory_get_slow_dll_ctrl(); | 93 | dll_ctrl = omap2xxx_sdrc_get_slow_dll_ctrl(); |
94 | else if (level == CORE_CLK_SRC_DPLL_X2) | 94 | else if (level == CORE_CLK_SRC_DPLL_X2) |
95 | dll_ctrl = omap2_memory_get_fast_dll_ctrl(); | 95 | dll_ctrl = omap2xxx_sdrc_get_fast_dll_ctrl(); |
96 | else | 96 | else |
97 | return prev; | 97 | return prev; |
98 | 98 | ||
99 | m_type = omap2_memory_get_type(); | 99 | m_type = omap2xxx_sdrc_get_type(); |
100 | 100 | ||
101 | local_irq_save(flags); | 101 | local_irq_save(flags); |
102 | __raw_writel(0xffff, OMAP24XX_PRCM_VOLTSETUP); | 102 | __raw_writel(0xffff, OMAP24XX_PRCM_VOLTSETUP); |
@@ -107,18 +107,8 @@ u32 omap2_reprogram_sdrc(u32 level, u32 force) | |||
107 | return prev; | 107 | return prev; |
108 | } | 108 | } |
109 | 109 | ||
110 | #if !defined(CONFIG_ARCH_OMAP2) | 110 | /* Used by the clock framework during CORE DPLL changes */ |
111 | void omap2_sram_ddr_init(u32 *slow_dll_ctrl, u32 fast_dll_ctrl, | 111 | void omap2xxx_sdrc_init_params(u32 force_lock_to_unlock_mode) |
112 | u32 base_cs, u32 force_unlock) | ||
113 | { | ||
114 | } | ||
115 | void omap2_sram_reprogram_sdrc(u32 perf_level, u32 dll_val, | ||
116 | u32 mem_type) | ||
117 | { | ||
118 | } | ||
119 | #endif | ||
120 | |||
121 | void omap2_init_memory_params(u32 force_lock_to_unlock_mode) | ||
122 | { | 112 | { |
123 | unsigned long dll_cnt; | 113 | unsigned long dll_cnt; |
124 | u32 fast_dll = 0; | 114 | u32 fast_dll = 0; |
@@ -171,28 +161,3 @@ void omap2_init_memory_params(u32 force_lock_to_unlock_mode) | |||
171 | /* 90 degree phase for anything below 133Mhz + disable DLL filter */ | 161 | /* 90 degree phase for anything below 133Mhz + disable DLL filter */ |
172 | mem_timings.slow_dll_ctrl |= ((1 << 1) | (3 << 8)); | 162 | mem_timings.slow_dll_ctrl |= ((1 << 1) | (3 << 8)); |
173 | } | 163 | } |
174 | |||
175 | void __init omap2_set_globals_memory(struct omap_globals *omap2_globals) | ||
176 | { | ||
177 | omap2_sdrc_base = omap2_globals->sdrc; | ||
178 | omap2_sms_base = omap2_globals->sms; | ||
179 | } | ||
180 | |||
181 | /* turn on smart idle modes for SDRAM scheduler and controller */ | ||
182 | void __init omap2_init_memory(void) | ||
183 | { | ||
184 | u32 l; | ||
185 | |||
186 | if (!cpu_is_omap2420()) | ||
187 | return; | ||
188 | |||
189 | l = sms_read_reg(SMS_SYSCONFIG); | ||
190 | l &= ~(0x3 << 3); | ||
191 | l |= (0x2 << 3); | ||
192 | sms_write_reg(l, SMS_SYSCONFIG); | ||
193 | |||
194 | l = sdrc_read_reg(SDRC_SYSCONFIG); | ||
195 | l &= ~(0x3 << 3); | ||
196 | l |= (0x2 << 3); | ||
197 | sdrc_write_reg(l, SDRC_SYSCONFIG); | ||
198 | } | ||
diff --git a/arch/arm/plat-omap/common.c b/arch/arm/plat-omap/common.c index 0843b8882f93..187239c054c9 100644 --- a/arch/arm/plat-omap/common.c +++ b/arch/arm/plat-omap/common.c | |||
@@ -249,7 +249,7 @@ static struct omap_globals *omap2_globals; | |||
249 | static void __init __omap2_set_globals(void) | 249 | static void __init __omap2_set_globals(void) |
250 | { | 250 | { |
251 | omap2_set_globals_tap(omap2_globals); | 251 | omap2_set_globals_tap(omap2_globals); |
252 | omap2_set_globals_memory(omap2_globals); | 252 | omap2_set_globals_sdrc(omap2_globals); |
253 | omap2_set_globals_control(omap2_globals); | 253 | omap2_set_globals_control(omap2_globals); |
254 | omap2_set_globals_prcm(omap2_globals); | 254 | omap2_set_globals_prcm(omap2_globals); |
255 | } | 255 | } |
diff --git a/arch/arm/plat-omap/include/mach/common.h b/arch/arm/plat-omap/include/mach/common.h index ef70e2b0f054..f3444a66a57e 100644 --- a/arch/arm/plat-omap/include/mach/common.h +++ b/arch/arm/plat-omap/include/mach/common.h | |||
@@ -65,7 +65,7 @@ void omap2_set_globals_343x(void); | |||
65 | 65 | ||
66 | /* These get called from omap2_set_globals_xxxx(), do not call these */ | 66 | /* These get called from omap2_set_globals_xxxx(), do not call these */ |
67 | void omap2_set_globals_tap(struct omap_globals *); | 67 | void omap2_set_globals_tap(struct omap_globals *); |
68 | void omap2_set_globals_memory(struct omap_globals *); | 68 | void omap2_set_globals_sdrc(struct omap_globals *); |
69 | void omap2_set_globals_control(struct omap_globals *); | 69 | void omap2_set_globals_control(struct omap_globals *); |
70 | void omap2_set_globals_prcm(struct omap_globals *); | 70 | void omap2_set_globals_prcm(struct omap_globals *); |
71 | 71 | ||
diff --git a/arch/arm/plat-omap/include/mach/sdrc.h b/arch/arm/plat-omap/include/mach/sdrc.h index c905b5268e56..8e0740eb83fb 100644 --- a/arch/arm/plat-omap/include/mach/sdrc.h +++ b/arch/arm/plat-omap/include/mach/sdrc.h | |||
@@ -4,10 +4,12 @@ | |||
4 | /* | 4 | /* |
5 | * OMAP2/3 SDRC/SMS register definitions | 5 | * OMAP2/3 SDRC/SMS register definitions |
6 | * | 6 | * |
7 | * Copyright (C) 2007 Texas Instruments, Inc. | 7 | * Copyright (C) 2007-2008 Texas Instruments, Inc. |
8 | * Copyright (C) 2007 Nokia Corporation | 8 | * Copyright (C) 2007-2008 Nokia Corporation |
9 | * | 9 | * |
10 | * Written by Paul Walmsley | 10 | * Tony Lindgren |
11 | * Paul Walmsley | ||
12 | * Richard Woodruff | ||
11 | * | 13 | * |
12 | * This program is free software; you can redistribute it and/or modify | 14 | * This program is free software; you can redistribute it and/or modify |
13 | * it under the terms of the GNU General Public License version 2 as | 15 | * it under the terms of the GNU General Public License version 2 as |
@@ -64,18 +66,25 @@ | |||
64 | * SMS register access | 66 | * SMS register access |
65 | */ | 67 | */ |
66 | 68 | ||
67 | 69 | #define OMAP242X_SMS_REGADDR(reg) \ | |
68 | #define OMAP242X_SMS_REGADDR(reg) IO_ADDRESS(OMAP2420_SMS_BASE + reg) | 70 | (void __iomem *)IO_ADDRESS(OMAP2420_SMS_BASE + reg) |
69 | #define OMAP243X_SMS_REGADDR(reg) IO_ADDRESS(OMAP243X_SMS_BASE + reg) | 71 | #define OMAP243X_SMS_REGADDR(reg) \ |
70 | #define OMAP343X_SMS_REGADDR(reg) IO_ADDRESS(OMAP343X_SMS_BASE + reg) | 72 | (void __iomem *)IO_ADDRESS(OMAP243X_SMS_BASE + reg) |
73 | #define OMAP343X_SMS_REGADDR(reg) \ | ||
74 | (void __iomem *)IO_ADDRESS(OMAP343X_SMS_BASE + reg) | ||
71 | 75 | ||
72 | /* SMS register offsets - read/write with sms_{read,write}_reg() */ | 76 | /* SMS register offsets - read/write with sms_{read,write}_reg() */ |
73 | 77 | ||
74 | #define SMS_SYSCONFIG 0x010 | 78 | #define SMS_SYSCONFIG 0x010 |
75 | /* REVISIT: fill in other SMS registers here */ | 79 | /* REVISIT: fill in other SMS registers here */ |
76 | 80 | ||
81 | |||
77 | #ifndef __ASSEMBLER__ | 82 | #ifndef __ASSEMBLER__ |
78 | 83 | ||
84 | void __init omap2_sdrc_init(void); | ||
85 | |||
86 | #ifdef CONFIG_ARCH_OMAP2 | ||
87 | |||
79 | struct memory_timings { | 88 | struct memory_timings { |
80 | u32 m_type; /* ddr = 1, sdr = 0 */ | 89 | u32 m_type; /* ddr = 1, sdr = 0 */ |
81 | u32 dll_mode; /* use lock mode = 1, unlock mode = 0 */ | 90 | u32 dll_mode; /* use lock mode = 1, unlock mode = 0 */ |
@@ -84,15 +93,13 @@ struct memory_timings { | |||
84 | u32 base_cs; /* base chip select to use for calculations */ | 93 | u32 base_cs; /* base chip select to use for calculations */ |
85 | }; | 94 | }; |
86 | 95 | ||
87 | extern void omap2_init_memory_params(u32 force_lock_to_unlock_mode); | 96 | extern void omap2xxx_sdrc_init_params(u32 force_lock_to_unlock_mode); |
88 | extern u32 omap2_memory_get_slow_dll_ctrl(void); | ||
89 | extern u32 omap2_memory_get_fast_dll_ctrl(void); | ||
90 | extern u32 omap2_memory_get_type(void); | ||
91 | u32 omap2_dll_force_needed(void); | ||
92 | u32 omap2_reprogram_sdrc(u32 level, u32 force); | ||
93 | void __init omap2_init_memory(void); | ||
94 | 97 | ||
95 | #endif | 98 | u32 omap2xxx_sdrc_dll_is_unlocked(void); |
99 | u32 omap2xxx_sdrc_reprogram(u32 level, u32 force); | ||
100 | |||
101 | #endif /* CONFIG_ARCH_OMAP2 */ | ||
96 | 102 | ||
103 | #endif /* __ASSEMBLER__ */ | ||
97 | 104 | ||
98 | #endif | 105 | #endif |