Commit 04fef228 authored by Eric Miao's avatar Eric Miao

[ARM] pxa: introduce reset_status and clear_reset_status for driver's usage

Due to the problem of reset status bits being handled by different
registers between pxa2xx and pxa3xx, introduce a global reset_status
variable, initialized by SoC-specific code and later being used by
other drivers.

And also introduce clear_reset_status(), which is used to clear the
corresponding status bits. Pass RESET_STATUS_ALL to clear all bits.
Signed-off-by: default avatarEric Miao <eric.miao@marvell.com>
parent ab277121
...@@ -26,9 +26,19 @@ ...@@ -26,9 +26,19 @@
#include <asm/mach/map.h> #include <asm/mach/map.h>
#include <asm/arch/pxa-regs.h> #include <asm/arch/pxa-regs.h>
#include <asm/arch/reset.h>
#include "generic.h" #include "generic.h"
void clear_reset_status(unsigned int mask)
{
if (cpu_is_pxa2xx())
pxa2xx_clear_reset_status(mask);
if (cpu_is_pxa3xx())
pxa3xx_clear_reset_status(mask);
}
/* /*
* Get the clock frequency as reflected by CCCR and the turbo flag. * Get the clock frequency as reflected by CCCR and the turbo flag.
* We assume these values have been applied via a fcs. * We assume these values have been applied via a fcs.
......
...@@ -47,12 +47,20 @@ extern unsigned pxa27x_get_memclk_frequency_10khz(void); ...@@ -47,12 +47,20 @@ extern unsigned pxa27x_get_memclk_frequency_10khz(void);
#define pxa27x_get_memclk_frequency_10khz() (0) #define pxa27x_get_memclk_frequency_10khz() (0)
#endif #endif
#if defined(CONFIG_PXA25x) || defined(CONFIG_PXA27x)
extern void pxa2xx_clear_reset_status(unsigned int);
#else
static inline void pxa2xx_clear_reset_status(unsigned int mask) {}
#endif
#ifdef CONFIG_PXA3xx #ifdef CONFIG_PXA3xx
extern unsigned pxa3xx_get_clk_frequency_khz(int); extern unsigned pxa3xx_get_clk_frequency_khz(int);
extern unsigned pxa3xx_get_memclk_frequency_10khz(void); extern unsigned pxa3xx_get_memclk_frequency_10khz(void);
extern void pxa3xx_clear_reset_status(unsigned int);
#else #else
#define pxa3xx_get_clk_frequency_khz(x) (0) #define pxa3xx_get_clk_frequency_khz(x) (0)
#define pxa3xx_get_memclk_frequency_10khz() (0) #define pxa3xx_get_memclk_frequency_10khz() (0)
static inline void pxa3xx_clear_reset_status(unsigned int mask) {}
#endif #endif
extern struct sysdev_class pxa_irq_sysclass; extern struct sysdev_class pxa_irq_sysclass;
......
...@@ -28,6 +28,7 @@ ...@@ -28,6 +28,7 @@
#include <asm/arch/pxa-regs.h> #include <asm/arch/pxa-regs.h>
#include <asm/arch/pxa2xx-regs.h> #include <asm/arch/pxa2xx-regs.h>
#include <asm/arch/mfp-pxa25x.h> #include <asm/arch/mfp-pxa25x.h>
#include <asm/arch/reset.h>
#include <asm/arch/pm.h> #include <asm/arch/pm.h>
#include <asm/arch/dma.h> #include <asm/arch/dma.h>
...@@ -348,6 +349,9 @@ static int __init pxa25x_init(void) ...@@ -348,6 +349,9 @@ static int __init pxa25x_init(void)
clks_register(&pxa25x_hwuart_clk, 1); clks_register(&pxa25x_hwuart_clk, 1);
if (cpu_is_pxa21x() || cpu_is_pxa25x()) { if (cpu_is_pxa21x() || cpu_is_pxa25x()) {
reset_status = RCSR;
clks_register(pxa25x_clks, ARRAY_SIZE(pxa25x_clks)); clks_register(pxa25x_clks, ARRAY_SIZE(pxa25x_clks));
if ((ret = pxa_init_dma(16))) if ((ret = pxa_init_dma(16)))
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <asm/arch/pxa-regs.h> #include <asm/arch/pxa-regs.h>
#include <asm/arch/pxa2xx-regs.h> #include <asm/arch/pxa2xx-regs.h>
#include <asm/arch/mfp-pxa27x.h> #include <asm/arch/mfp-pxa27x.h>
#include <asm/arch/reset.h>
#include <asm/arch/ohci.h> #include <asm/arch/ohci.h>
#include <asm/arch/pm.h> #include <asm/arch/pm.h>
#include <asm/arch/dma.h> #include <asm/arch/dma.h>
...@@ -384,6 +385,9 @@ static int __init pxa27x_init(void) ...@@ -384,6 +385,9 @@ static int __init pxa27x_init(void)
int i, ret = 0; int i, ret = 0;
if (cpu_is_pxa27x()) { if (cpu_is_pxa27x()) {
reset_status = RCSR;
clks_register(pxa27x_clks, ARRAY_SIZE(pxa27x_clks)); clks_register(pxa27x_clks, ARRAY_SIZE(pxa27x_clks));
if ((ret = pxa_init_dma(32))) if ((ret = pxa_init_dma(32)))
......
...@@ -14,10 +14,19 @@ ...@@ -14,10 +14,19 @@
#include <linux/kernel.h> #include <linux/kernel.h>
#include <linux/device.h> #include <linux/device.h>
#include <asm/hardware.h>
#include <asm/arch/pxa2xx-regs.h>
#include <asm/arch/mfp-pxa2xx.h> #include <asm/arch/mfp-pxa2xx.h>
#include <asm/arch/mfp-pxa25x.h> #include <asm/arch/mfp-pxa25x.h>
#include <asm/arch/reset.h>
#include <asm/arch/irda.h> #include <asm/arch/irda.h>
void pxa2xx_clear_reset_status(unsigned int mask)
{
/* RESET_STATUS_* has a 1:1 mapping with RCSR */
RCSR = mask;
}
static unsigned long pxa2xx_mfp_fir[] = { static unsigned long pxa2xx_mfp_fir[] = {
GPIO46_FICP_RXD, GPIO46_FICP_RXD,
GPIO47_FICP_TXD, GPIO47_FICP_TXD,
......
...@@ -24,6 +24,7 @@ ...@@ -24,6 +24,7 @@
#include <asm/hardware.h> #include <asm/hardware.h>
#include <asm/arch/pxa3xx-regs.h> #include <asm/arch/pxa3xx-regs.h>
#include <asm/arch/reset.h>
#include <asm/arch/ohci.h> #include <asm/arch/ohci.h>
#include <asm/arch/pm.h> #include <asm/arch/pm.h>
#include <asm/arch/dma.h> #include <asm/arch/dma.h>
...@@ -109,6 +110,12 @@ unsigned int pxa3xx_get_memclk_frequency_10khz(void) ...@@ -109,6 +110,12 @@ unsigned int pxa3xx_get_memclk_frequency_10khz(void)
return (clk / 10000); return (clk / 10000);
} }
void pxa3xx_clear_reset_status(unsigned int mask)
{
/* RESET_STATUS_* has a 1:1 mapping with ARSR */
ARSR = mask;
}
/* /*
* Return the current AC97 clock frequency. * Return the current AC97 clock frequency.
*/ */
...@@ -532,6 +539,9 @@ static int __init pxa3xx_init(void) ...@@ -532,6 +539,9 @@ static int __init pxa3xx_init(void)
int i, ret = 0; int i, ret = 0;
if (cpu_is_pxa3xx()) { if (cpu_is_pxa3xx()) {
reset_status = ARSR;
/* /*
* clear RDH bit every time after reset * clear RDH bit every time after reset
* *
......
...@@ -11,9 +11,11 @@ ...@@ -11,9 +11,11 @@
#include <asm/proc-fns.h> #include <asm/proc-fns.h>
#include <asm/arch/pxa-regs.h> #include <asm/arch/pxa-regs.h>
#include <asm/arch/pxa2xx-regs.h>
#include <asm/arch/reset.h> #include <asm/arch/reset.h>
unsigned int reset_status;
EXPORT_SYMBOL(reset_status);
static void do_hw_reset(void); static void do_hw_reset(void);
static int reset_gpio = -1; static int reset_gpio = -1;
...@@ -78,8 +80,7 @@ static void do_hw_reset(void) ...@@ -78,8 +80,7 @@ static void do_hw_reset(void)
void arch_reset(char mode) void arch_reset(char mode)
{ {
if (cpu_is_pxa2xx()) clear_reset_status(RESET_STATUS_ALL);
RCSR = RCSR_HWR | RCSR_WDR | RCSR_SMR | RCSR_GPR;
switch (mode) { switch (mode) {
case 's': case 's':
......
...@@ -31,6 +31,9 @@ ...@@ -31,6 +31,9 @@
#include "generic.h" #include "generic.h"
unsigned int reset_status;
EXPORT_SYMBOL(reset_status);
#define NR_FREQS 16 #define NR_FREQS 16
/* /*
......
#ifndef __ASM_ARCH_RESET_H #ifndef __ASM_ARCH_RESET_H
#define __ASM_ARCH_RESET_H #define __ASM_ARCH_RESET_H
#define RESET_STATUS_HARDWARE (1 << 0) /* Hardware Reset */
#define RESET_STATUS_WATCHDOG (1 << 1) /* Watchdog Reset */
#define RESET_STATUS_LOWPOWER (1 << 2) /* Low Power/Sleep Exit */
#define RESET_STATUS_GPIO (1 << 3) /* GPIO Reset */
#define RESET_STATUS_ALL (0xf)
extern unsigned int reset_status;
extern void clear_reset_status(unsigned int mask);
/* /*
* register GPIO as reset generator * register GPIO as reset generator
*/ */
......
#ifndef __ASM_ARCH_RESET_H
#define __ASM_ARCH_RESET_H
#include "hardware.h"
#define RESET_STATUS_HARDWARE (1 << 0) /* Hardware Reset */
#define RESET_STATUS_WATCHDOG (1 << 1) /* Watchdog Reset */
#define RESET_STATUS_LOWPOWER (1 << 2) /* Exit from Low Power/Sleep */
#define RESET_STATUS_GPIO (1 << 3) /* GPIO Reset */
#define RESET_STATUS_ALL (0xf)
extern unsigned int reset_status;
static inline void clear_reset_status(unsigned int mask)
{
RCSR = mask;
}
#endif /* __ASM_ARCH_RESET_H */
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