mirror of
https://github.com/Fishwaldo/Star64_linux.git
synced 2025-05-10 17:23:57 +00:00
[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: Eric Miao <eric.miao@marvell.com>
This commit is contained in:
parent
ab27712142
commit
04fef228fb
10 changed files with 79 additions and 3 deletions
|
@ -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);
|
||||||
#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 @@
|
||||||
#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)
|
||||||
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 @@
|
||||||
#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)
|
||||||
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 @@
|
||||||
#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 @@
|
||||||
|
|
||||||
#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)
|
||||||
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)
|
||||||
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 @@
|
||||||
#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)
|
||||||
|
|
||||||
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 @@
|
||||||
|
|
||||||
#include "generic.h"
|
#include "generic.h"
|
||||||
|
|
||||||
|
unsigned int reset_status;
|
||||||
|
EXPORT_SYMBOL(reset_status);
|
||||||
|
|
||||||
#define NR_FREQS 16
|
#define NR_FREQS 16
|
||||||
|
|
||||||
/*
|
/*
|
||||||
|
|
|
@ -1,6 +1,15 @@
|
||||||
#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
|
||||||
*/
|
*/
|
||||||
|
|
18
include/asm-arm/arch-sa1100/reset.h
Normal file
18
include/asm-arm/arch-sa1100/reset.h
Normal file
|
@ -0,0 +1,18 @@
|
||||||
|
#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 */
|
Loading…
Add table
Reference in a new issue