1
0
mirror of https://github.com/RIOT-OS/RIOT.git synced 2025-01-15 13:52:45 +01:00
RIOT/cpu/arm7_common/include/arm7_common.h
Benjamin Valentin a9d1825e2e cpu/lpc2387: implement periph/pm
Enable IDLE and Deep Powerdown mode.

IDLE is pretty straightforward - insteady of busy waiting, the CPU will
enter an idle state from which it will resume on any event.

Deep Power Down shuts off the entite system except for the battery backup
power domain.
That means the CPU will reset on resume and can be woken by e.g. RTC.

SLEEP and POWERDOWN disable the PLL and the PLL and Flash respectively.
This requires some proper wake-up handling.

Since this turned out to be a major time sink and those modes are never
currently never used in RIOT outside of tests, I left this as an exercise
for a future reader.
2019-11-22 09:11:39 +01:00

105 lines
2.1 KiB
C

/*
* Copyright (C) 2008-2009, 2014 Freie Universität Berlin
*
* This file is subject to the terms and conditions of the GNU Lesser General
* Public License v2.1. See the file LICENSE in the top level directory for
* more details.
*/
#ifndef ARM7_COMMON_H
#define ARM7_COMMON_H
/**
* @defgroup cpu_arm7_common ARM7 CPU common
* @brief Common implementations and headers for ARM based micro-controllers
* @ingroup cpu
* @{
*/
/**
* @file
* @brief ARM7 CPU common declarations
*
* @author Freie Universität Berlin, Computer Systems & Telematics
*
*/
#include "bitarithm.h"
#ifdef __cplusplus
extern "C" {
#endif
/**
* @name PCONP Constants
* @{
*/
#define PCTIM0 (BIT1)
#define PCTIM1 (BIT2)
#define PCUART0 (BIT3)
#define PCUART1 (BIT4)
#define PCPWM1 (BIT6)
#define PCI2C0 (BIT7)
#define PCSPI (BIT8)
#define PCRTC (BIT9)
#define PCSSP1 (BIT10)
#define PCEMC (BIT11)
#define PCAD (BIT12)
#define PCAN1 (BIT13)
#define PCAN2 (BIT14)
#define PCI2C1 (BIT19)
#define PCSSP0 (BIT21)
#define PCTIM2 (BIT22)
#define PCTIM3 (BIT23)
#define PCUART2 (BIT24)
#define PCUART3 (BIT25)
#define PCI2C2 (BIT26)
#define PCI2S (BIT27)
#define PCSDC (BIT28)
#define PCGPDMA (BIT29)
#define PCENET (BIT30)
#define PCUSB (BIT31)
/** @} */
/**
* @name PCON Constants
* @{
*/
#define PM0 (BIT0)
#define PM1 (BIT1)
#define BODPDM (BIT2)
#define BOGD (BIT3)
#define BORD (BIT4)
#define PM2 (BIT7)
#define PM_IDLE (PM0)
#define PM_SLEEP (PM2|PM0)
#define PM_POWERDOWN (PM1)
#define PM_DEEP_POWERDOWN (PM2|PM1)
/** @} */
/**
* @name Timer Symbols
* @{
*/
#define MR0I (BIT0)
#define MR0R (BIT1)
#define MR0S (BIT2)
#define MR1I (BIT3)
#define MR1R (BIT4)
#define MR1S (BIT5)
#define MR2I (BIT6)
#define MR2R (BIT7)
#define MR2S (BIT8)
#define MR3I (BIT9)
#define MR3R (BIT10)
#define MR3S (BIT11)
/** @} */
#ifdef __cplusplus
}
#endif
/** @} */
#endif /* ARM7_COMMON_H */