mirror of
https://git.kernel.org/pub/scm/linux/kernel/git/torvalds/linux.git
synced 2025-01-11 15:49:56 +00:00
dc38e2ad53
Related to d3930614e68bdf83a120d904c039a64e9f75dba1. RCSR is only present on PXA2xx CPUs, not on PXA3xx CPUs. Therefore, we should not be unconditionally writing to RCSR from generic code. Since we now clear the RCSR status from the SoC specific PXA PM code and before reset in the arch_reset() function, the duplication in the corgi, poodle, spitz and tosa code can be removed. Acked-by: Richard Purdie <rpurdie@rpsys.net> Signed-off-by: Russell King <rmk+kernel@arm.linux.org.uk>
39 lines
796 B
C
39 lines
796 B
C
/*
|
|
* linux/include/asm-arm/arch-pxa/system.h
|
|
*
|
|
* Author: Nicolas Pitre
|
|
* Created: Jun 15, 2001
|
|
* Copyright: MontaVista Software Inc.
|
|
*
|
|
* This program is free software; you can redistribute it and/or modify
|
|
* it under the terms of the GNU General Public License version 2 as
|
|
* published by the Free Software Foundation.
|
|
*/
|
|
|
|
#include <asm/proc-fns.h>
|
|
#include "hardware.h"
|
|
#include "pxa-regs.h"
|
|
|
|
static inline void arch_idle(void)
|
|
{
|
|
cpu_do_idle();
|
|
}
|
|
|
|
|
|
static inline void arch_reset(char mode)
|
|
{
|
|
if (cpu_is_pxa2xx())
|
|
RCSR = RCSR_HWR | RCSR_WDR | RCSR_SMR | RCSR_GPR;
|
|
|
|
if (mode == 's') {
|
|
/* Jump into ROM at address 0 */
|
|
cpu_reset(0);
|
|
} else {
|
|
/* Initialize the watchdog and let it fire */
|
|
OWER = OWER_WME;
|
|
OSSR = OSSR_M3;
|
|
OSMR3 = OSCR + 368640; /* ... in 100 ms */
|
|
}
|
|
}
|
|
|