summaryrefslogtreecommitdiff
path: root/arch/arm/mach-mx6/mx6_mmdc.c
diff options
context:
space:
mode:
Diffstat (limited to 'arch/arm/mach-mx6/mx6_mmdc.c')
-rw-r--r--arch/arm/mach-mx6/mx6_mmdc.c46
1 files changed, 32 insertions, 14 deletions
diff --git a/arch/arm/mach-mx6/mx6_mmdc.c b/arch/arm/mach-mx6/mx6_mmdc.c
index 71d6ede4b49a..c970defca5d0 100644
--- a/arch/arm/mach-mx6/mx6_mmdc.c
+++ b/arch/arm/mach-mx6/mx6_mmdc.c
@@ -58,7 +58,6 @@ void (*mx6sl_lpddr2_change_freq)(u32 freq, int low_bus_freq_mode,
void *ddr_settings) = NULL;
void (*mx6sl_ddr3_change_freq)(u32 freq, void *ddr_settings, bool dll_mode, void* iomux_offsets, int low_bus_freq_mode) = NULL;
-void (*wfe_change_ddr_freq)(u32 cpuid, u32 *ddr_freq_change_done);
extern unsigned int ddr_low_rate;
extern unsigned int ddr_med_rate;
@@ -71,7 +70,6 @@ extern void __iomem *ccm_base;
extern void mx6_ddr_freq_change(u32 freq, void *ddr_settings, bool dll_mode, void *iomux_offsets);
extern void mx6sl_ddr_iram(int ddr_freq, int low_bus_freq_mode, void *ddr_settings);
extern void mx6sl_ddr3_freq_change(u32 freq, void *ddr_settings, bool dll_mode, void *iomux_offsets, int low_bus_freq_mode);
-extern void wfe_ddr3_freq_change(u32 cpuid, u32 *ddr_freq_change_done);
extern unsigned long save_ttbr1(void);
extern void restore_ttbr1(u32 ttbr1);
@@ -81,20 +79,23 @@ extern unsigned long mx6sl_lpddr2_iram_end asm("mx6sl_lpddr2_iram_end");
extern unsigned long mx6sl_lpddr2_iram_start asm("mx6sl_lpddr2_iram_start");
extern unsigned long mx6sl_ddr3_iram_end asm("mx6sl_ddr3_iram_end");
extern unsigned long mx6sl_ddr3_iram_start asm("mx6sl_ddr3_iram_start");
+#ifdef CONFIG_SMP
extern unsigned long wfe_ddr3_freq_change_start asm("wfe_ddr3_freq_change_start");
extern unsigned long wfe_ddr3_freq_change_end asm("wfe_ddr3_freq_change_end");
-
+void (*wfe_change_ddr_freq)(u32 cpuid, u32 *ddr_freq_change_done);
+extern void wfe_ddr3_freq_change(u32 cpuid, u32 *ddr_freq_change_done);
+u32 *wait_for_ddr_freq_update;
+static unsigned long wfe_freq_change_iram_base;
+static volatile unsigned int cpus_in_wfe;
+#endif
unsigned long ddr_freq_change_iram_phys_addr;
-u32 *wait_for_ddr_freq_update;
static void *ddr_freq_change_iram_base;
static int ddr_settings_size;
static int iomux_settings_size;
-static volatile unsigned int cpus_in_wfe;
static int curr_ddr_rate;
static unsigned int ddr_type;
-static unsigned long wfe_freq_change_iram_base;
#define MIN_DLL_ON_FREQ 333000000
#define MAX_DLL_OFF_FREQ 125000000
@@ -236,6 +237,7 @@ int can_change_ddr_freq(void)
}
+#ifdef CONFIG_SMP
/* Each active core apart from the one changing the DDR frequency will execute
* this function. The rest of the cores have to remain in WFE state until the frequency
* is changed.
@@ -258,18 +260,20 @@ irqreturn_t wait_in_wfe_irq(int irq, void *dev_id)
return IRQ_HANDLED;
}
+#endif
/* Change the DDR frequency. */
int update_ddr_freq(int ddr_rate)
{
int i, j;
- unsigned int reg;
bool dll_off = false;
+ int me = 0;
+ u32 ttbr1;
+#ifdef CONFIG_SMP
unsigned int online_cpus = 0;
+ unsigned int reg;
int cpu = 0;
- int me;
- u32 ttbr1;
-
+#endif
if (!can_change_ddr_freq())
return -1;
@@ -347,6 +351,7 @@ int update_ddr_freq(int ddr_rate)
/* Ensure that all Cores are in WFE. */
local_irq_disable();
+#ifdef CONFIG_SMP
me = smp_processor_id();
/* Make sure all the online cores are active */
@@ -382,6 +387,7 @@ int update_ddr_freq(int ddr_rate)
if (reg == online_cpus)
break;
}
+#endif
/* Ensure iram_tlb_phys_addr is flushed to DDR. */
__cpuc_flush_dcache_area(&iram_tlb_phys_addr, sizeof(iram_tlb_phys_addr));
@@ -402,12 +408,13 @@ int update_ddr_freq(int ddr_rate)
curr_ddr_rate = ddr_rate;
+#ifdef CONFIG_SMP
/* DDR frequency change is done . */
*wait_for_ddr_freq_update = false;
/* Wake up all the cores. */
sev();
-
+#endif
local_irq_enable();
printk(KERN_DEBUG "Bus freq set to %d done! cpu=%d\n", ddr_rate, me);
@@ -417,9 +424,12 @@ int update_ddr_freq(int ddr_rate)
int init_mmdc_settings(void)
{
- int i, err, cpu;
+ int i;
unsigned long ddr_code_size = 0;
unsigned long wfe_code_size = 0;
+#ifdef CONFIG_SMP
+ int err, cpu;
+#endif
imx_scu_base = IO_ADDRESS(SCU_BASE_ADDR);
@@ -438,7 +448,9 @@ int init_mmdc_settings(void)
ddr_code_size = (&mx6sl_ddr3_iram_end -&mx6sl_ddr3_iram_start) *4;
} else {
ddr_code_size = (&mx6_ddr3_iram_end -&mx6_ddr3_iram_start) *4;
+#ifdef CONFIG_SMP
wfe_code_size = (&wfe_ddr3_freq_change_end -&wfe_ddr3_freq_change_start) *4;
+#endif
if (cpu_is_mx6q()) {
ddr_settings_size = ARRAY_SIZE(ddr3_dll_mx6q) + ARRAY_SIZE(ddr3_calibration);
iomux_settings_size = ARRAY_SIZE(iomux_offsets_mx6q);
@@ -524,7 +536,9 @@ int init_mmdc_settings(void)
iram_iomux_settings[i+1][0] = iomux_offsets_mx6q[i][0];
iram_iomux_settings[i+1][1] = iomux_offsets_mx6q[i][1];
}
+#ifdef CONFIG_SMP
irq_used = irqs_used_mx6q;
+#endif
}
if (cpu_is_mx6dl()) {
@@ -535,7 +549,9 @@ int init_mmdc_settings(void)
iram_iomux_settings[i+1][0] = iomux_offsets_mx6dl[i][0];
iram_iomux_settings[i+1][1] = iomux_offsets_mx6dl[i][1];
}
+#ifdef CONFIG_SMP
irq_used = irqs_used_mx6dl;
+#endif
}
if (cpu_is_mx6sl()) {
for (i = 0; i < iomux_settings_size; i++) {
@@ -547,6 +563,7 @@ int init_mmdc_settings(void)
}
}
+#ifdef CONFIG_SMP
wfe_freq_change_iram_base = (unsigned long)((u32 *)iram_ddr_settings + (ddr_settings_size * 8) + 8);
if (wfe_freq_change_iram_base & (FNCPY_ALIGN - 1))
@@ -558,8 +575,6 @@ int init_mmdc_settings(void)
/* Store the variable used to communicate between cores in a non-cacheable IRAM area */
wait_for_ddr_freq_update = (u32 *)&iram_iomux_settings[0][1];
- curr_ddr_rate = ddr_normal_rate;
-
if (!cpu_is_mx6sl()) {
for_each_online_cpu(cpu) {
/* Set up a reserved interrupt to get all the active cores into a WFE state
@@ -578,5 +593,8 @@ int init_mmdc_settings(void)
}
}
}
+#endif
+ curr_ddr_rate = ddr_normal_rate;
+
return 0;
}