barebox/arch/arm/mach-pxa/pxa3xx.c
Robert Jarzmik e340ce0483 ARM: pxa: add pxa3xx architecture
Add the pxa3xx architecture, for pxa300, pxa310 and pxa320 SoCs.
This includes :
 - the registers
 - the cpu type
 - the reset source handling
 - a minimal set of clocks
 - pin control definitions
   In this last case, the big mfp-pxaxxx.h files were dropped, forcing
   board developers to use MFP_LPM_* macros cunningly.

Signed-off-by: Robert Jarzmik <robert.jarzmik@free.fr>
Signed-off-by: Sascha Hauer <s.hauer@pengutronix.de>
2015-01-19 09:02:23 +01:00

60 lines
1.4 KiB
C

/*
* (C) Copyright 2015 Robert Jarzmik <robert.jarzmik@free.fr>
*
* This program is free software; you can redistribute it and/or
* modify it under the terms of the GNU General Public License as
* published by the Free Software Foundation; either version 2 of
* the License, or (at your option) any later version.
*
* This program is distributed in the hope that it will be useful,
* but WITHOUT ANY WARRANTY; without even the implied warranty of
* MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
* GNU General Public License for more details.
*/
#include <common.h>
#include <init.h>
#include <reset_source.h>
#include <mach/hardware.h>
#include <mach/pxa-regs.h>
extern void pxa3xx_suspend(int mode);
static int pxa_detect_reset_source(void)
{
u32 reg = ARSR;
/*
* Order is important, as many bits can be set together
*/
if (reg & ARSR_GPR)
reset_source_set(RESET_RST);
else if (reg & ARSR_WDT)
reset_source_set(RESET_WDG);
else if (reg & ARSR_HWR)
reset_source_set(RESET_POR);
else if (reg & ARSR_LPMR)
reset_source_set(RESET_WKE);
else
reset_source_set(RESET_UKWN);
return 0;
}
void pxa_clear_reset_source(void)
{
ARSR = ARSR_GPR | ARSR_LPMR | ARSR_WDT | ARSR_HWR;
}
device_initcall(pxa_detect_reset_source);
void __noreturn poweroff(void)
{
shutdown_barebox();
/* Clear last reset source */
pxa_clear_reset_source();
pxa3xx_suspend(PXA3xx_PM_S3D4C4);
unreachable();
}