Commit 8c6d8319 authored by Shawn Guo's avatar Shawn Guo Committed by Sascha Hauer

arm/imx: remove imx_idle hook and use pm_idle instead

The patch removes imx_idle hook and use pm_idle instead to get imx
arch_idle prepared for the cleanup.  It's suggested by Russel King
as below.

> The final removal of mach/system.h depends on getting rid of the arch_idle
> thing.  While going through these headers, I was dismayed to find these:
>
> arch/arm/mach-s3c2410/include/mach/system.h:void (*s3c24xx_idle)(void);
> arch/arm/plat-mxc/include/mach/system.h:extern void (*imx_idle)(void);
>
> when we have a perfectly good pm_idle hook already in place - so there's
> no excuse for these especially when other platforms are already using
> pm_idle to hook their platform specific idle function into.  This is
> something that better be gone at the next merge window!
Suggested-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: default avatarShawn Guo <shawn.guo@linaro.org>
Acked-by: default avatarRussell King <rmk+kernel@arm.linux.org.uk>
Signed-off-by: default avatarSascha Hauer <s.hauer@pengutronix.de>
parent 6a53fc53
...@@ -33,29 +33,32 @@ ...@@ -33,29 +33,32 @@
static void imx3_idle(void) static void imx3_idle(void)
{ {
unsigned long reg = 0; unsigned long reg = 0;
__asm__ __volatile__(
/* disable I and D cache */ if (!need_resched())
"mrc p15, 0, %0, c1, c0, 0\n" __asm__ __volatile__(
"bic %0, %0, #0x00001000\n" /* disable I and D cache */
"bic %0, %0, #0x00000004\n" "mrc p15, 0, %0, c1, c0, 0\n"
"mcr p15, 0, %0, c1, c0, 0\n" "bic %0, %0, #0x00001000\n"
/* invalidate I cache */ "bic %0, %0, #0x00000004\n"
"mov %0, #0\n" "mcr p15, 0, %0, c1, c0, 0\n"
"mcr p15, 0, %0, c7, c5, 0\n" /* invalidate I cache */
/* clear and invalidate D cache */ "mov %0, #0\n"
"mov %0, #0\n" "mcr p15, 0, %0, c7, c5, 0\n"
"mcr p15, 0, %0, c7, c14, 0\n" /* clear and invalidate D cache */
/* WFI */ "mov %0, #0\n"
"mov %0, #0\n" "mcr p15, 0, %0, c7, c14, 0\n"
"mcr p15, 0, %0, c7, c0, 4\n" /* WFI */
"nop\n" "nop\n" "nop\n" "nop\n" "mov %0, #0\n"
"nop\n" "nop\n" "nop\n" "mcr p15, 0, %0, c7, c0, 4\n"
/* enable I and D cache */ "nop\n" "nop\n" "nop\n" "nop\n"
"mrc p15, 0, %0, c1, c0, 0\n" "nop\n" "nop\n" "nop\n"
"orr %0, %0, #0x00001000\n" /* enable I and D cache */
"orr %0, %0, #0x00000004\n" "mrc p15, 0, %0, c1, c0, 0\n"
"mcr p15, 0, %0, c1, c0, 0\n" "orr %0, %0, #0x00001000\n"
: "=r" (reg)); "orr %0, %0, #0x00000004\n"
"mcr p15, 0, %0, c1, c0, 0\n"
: "=r" (reg));
local_irq_enable();
} }
static void __iomem *imx3_ioremap(unsigned long phys_addr, size_t size, static void __iomem *imx3_ioremap(unsigned long phys_addr, size_t size,
...@@ -143,7 +146,7 @@ void __init imx31_init_early(void) ...@@ -143,7 +146,7 @@ void __init imx31_init_early(void)
{ {
mxc_set_cpu_type(MXC_CPU_MX31); mxc_set_cpu_type(MXC_CPU_MX31);
mxc_arch_reset_init(MX31_IO_ADDRESS(MX31_WDOG_BASE_ADDR)); mxc_arch_reset_init(MX31_IO_ADDRESS(MX31_WDOG_BASE_ADDR));
imx_idle = imx3_idle; pm_idle = imx3_idle;
imx_ioremap = imx3_ioremap; imx_ioremap = imx3_ioremap;
} }
...@@ -152,7 +155,7 @@ void __init imx35_init_early(void) ...@@ -152,7 +155,7 @@ void __init imx35_init_early(void)
mxc_set_cpu_type(MXC_CPU_MX35); mxc_set_cpu_type(MXC_CPU_MX35);
mxc_iomux_v3_init(MX35_IO_ADDRESS(MX35_IOMUXC_BASE_ADDR)); mxc_iomux_v3_init(MX35_IO_ADDRESS(MX35_IOMUXC_BASE_ADDR));
mxc_arch_reset_init(MX35_IO_ADDRESS(MX35_WDOG_BASE_ADDR)); mxc_arch_reset_init(MX35_IO_ADDRESS(MX35_WDOG_BASE_ADDR));
imx_idle = imx3_idle; pm_idle = imx3_idle;
imx_ioremap = imx3_ioremap; imx_ioremap = imx3_ioremap;
} }
......
...@@ -23,7 +23,9 @@ ...@@ -23,7 +23,9 @@
static void imx5_idle(void) static void imx5_idle(void)
{ {
mx5_cpu_lp_set(WAIT_UNCLOCKED_POWER_OFF); if (!need_resched())
mx5_cpu_lp_set(WAIT_UNCLOCKED_POWER_OFF);
local_irq_enable();
} }
/* /*
...@@ -89,7 +91,7 @@ void __init imx51_init_early(void) ...@@ -89,7 +91,7 @@ void __init imx51_init_early(void)
mxc_set_cpu_type(MXC_CPU_MX51); mxc_set_cpu_type(MXC_CPU_MX51);
mxc_iomux_v3_init(MX51_IO_ADDRESS(MX51_IOMUXC_BASE_ADDR)); mxc_iomux_v3_init(MX51_IO_ADDRESS(MX51_IOMUXC_BASE_ADDR));
mxc_arch_reset_init(MX51_IO_ADDRESS(MX51_WDOG1_BASE_ADDR)); mxc_arch_reset_init(MX51_IO_ADDRESS(MX51_WDOG1_BASE_ADDR));
imx_idle = imx5_idle; pm_idle = imx5_idle;
} }
void __init imx53_init_early(void) void __init imx53_init_early(void)
......
...@@ -85,7 +85,6 @@ enum mxc_cpu_pwr_mode { ...@@ -85,7 +85,6 @@ enum mxc_cpu_pwr_mode {
}; };
extern void mx5_cpu_lp_set(enum mxc_cpu_pwr_mode mode); extern void mx5_cpu_lp_set(enum mxc_cpu_pwr_mode mode);
extern void (*imx_idle)(void);
extern void imx_print_silicon_rev(const char *cpu, int srev); extern void imx_print_silicon_rev(const char *cpu, int srev);
void avic_handle_irq(struct pt_regs *); void avic_handle_irq(struct pt_regs *);
......
...@@ -17,14 +17,9 @@ ...@@ -17,14 +17,9 @@
#ifndef __ASM_ARCH_MXC_SYSTEM_H__ #ifndef __ASM_ARCH_MXC_SYSTEM_H__
#define __ASM_ARCH_MXC_SYSTEM_H__ #define __ASM_ARCH_MXC_SYSTEM_H__
extern void (*imx_idle)(void);
static inline void arch_idle(void) static inline void arch_idle(void)
{ {
if (imx_idle != NULL) cpu_do_idle();
(imx_idle)();
else
cpu_do_idle();
} }
void arch_reset(char mode, const char *cmd); void arch_reset(char mode, const char *cmd);
......
...@@ -28,7 +28,6 @@ ...@@ -28,7 +28,6 @@
#include <asm/system.h> #include <asm/system.h>
#include <asm/mach-types.h> #include <asm/mach-types.h>
void (*imx_idle)(void) = NULL;
void __iomem *(*imx_ioremap)(unsigned long, size_t, unsigned int) = NULL; void __iomem *(*imx_ioremap)(unsigned long, size_t, unsigned int) = NULL;
static void __iomem *wdog_base; static void __iomem *wdog_base;
......
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