123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112113114115116117118119120121122123124125126127128129130131132133134135136137138139140141142143144145146147148149150151152153154155156157158159160161162163164165166167168169170171172173174175176177178179180181182183184185186187188189190191192193194195196197198199200201202203204205206207208209210211212213214215216217218219220221222223224225226227228229230231232233234235236237 |
- /*
- * @brief LPC8xx PMU chip driver
- *
- * @note
- * Copyright(C) NXP Semiconductors, 2012
- * All rights reserved.
- *
- * @par
- * Software that is described herein is for illustrative purposes only
- * which provides customers with programming information regarding the
- * LPC products. This software is supplied "AS IS" without any warranties of
- * any kind, and NXP Semiconductors and its licensor disclaim any and
- * all warranties, express or implied, including all implied warranties of
- * merchantability, fitness for a particular purpose and non-infringement of
- * intellectual property rights. NXP Semiconductors assumes no responsibility
- * or liability for the use of the software, conveys no license or rights under any
- * patent, copyright, mask work right, or any other intellectual property rights in
- * or to any products. NXP Semiconductors reserves the right to make changes
- * in the software without notification. NXP Semiconductors also makes no
- * representation or warranty that such application will be suitable for the
- * specified use without further testing or modification.
- *
- * @par
- * Permission to use, copy, modify, and distribute this software and its
- * documentation is hereby granted, under NXP Semiconductors' and its
- * licensor's relevant copyrights in the software, without fee, provided that it
- * is used in conjunction with NXP Semiconductors microcontrollers. This
- * copyright, permission, and disclaimer notice must appear in all copies of
- * this code.
- */
- #ifndef __PMU_8XX_H_
- #define __PMU_8XX_H_
- #ifdef __cplusplus
- extern "C" {
- #endif
- /** @defgroup PMU_8XX CHIP: LPC8xx PMU driver
- * @ingroup CHIP_8XX_Drivers
- * @{
- */
- /**
- * @brief LPC8xx Power Management Unit register block structure
- */
- typedef struct {
- __IO uint32_t PCON; /*!< Offset: 0x000 Power control Register (R/W) */
- __IO uint32_t GPREG[4]; /*!< Offset: 0x004 General purpose Registers 0..3 (R/W) */
- __IO uint32_t DPDCTRL; /*!< Offset: 0x014 Deep power-down control register (R/W) */
- } LPC_PMU_T;
- /* Reserved bits masks for registers */
- #define PMU_PCON_RESERVED ((0xf<<4)|(0x6<<8)|0xfffff000)
- #define PMU_DPDCTRL_RESERVED (~0xf)
- /**
- * @brief LPC8xx low power mode type definitions
- */
- typedef enum CHIP_PMU_MCUPOWER {
- PMU_MCU_SLEEP = 0, /*!< Sleep mode */
- PMU_MCU_DEEP_SLEEP, /*!< Deep Sleep mode */
- PMU_MCU_POWER_DOWN, /*!< Power down mode */
- PMU_MCU_DEEP_PWRDOWN /*!< Deep power down mode */
- } CHIP_PMU_MCUPOWER_T;
- /**
- * PMU PCON register bit fields & masks
- */
- #define PMU_PCON_PM_SLEEP (0x0) /*!< ARM WFI enter sleep mode */
- #define PMU_PCON_PM_DEEPSLEEP (0x1) /*!< ARM WFI enter Deep-sleep mode */
- #define PMU_PCON_PM_POWERDOWN (0x2) /*!< ARM WFI enter Power-down mode */
- #define PMU_PCON_PM_DEEPPOWERDOWN (0x3) /*!< ARM WFI enter Deep Power-down mode */
- #define PMU_PCON_NODPD (1 << 3) /*!< Disable deep power-down mode */
- #define PMU_PCON_SLEEPFLAG (1 << 8) /*!< Sleep mode flag */
- #define PMU_PCON_DPDFLAG (1 << 11) /*!< Deep power-down flag */
- /**
- * PMU DPDCTRL register bit fields & masks
- */
- #define PMU_DPDCTRL_WAKEUPPHYS (1 << 0) /** Enable wake-up pin hysteresis */
- #define PMU_DPDCTRL_WAKEPAD (1 << 1) /** Disable the Wake-up */
- #define PMU_DPDCTRL_LPOSCEN (1 << 2) /** Enable the low-power oscillator (10 khz self wk) */
- #define PMU_DPDCTRL_LPOSCDPDEN (1 << 3) /** Enable the low-power oscillator in deep power-down*/
- /**
- * @brief Write a value to a GPREG register
- * @param pPMU : Pointer to PMU register block
- * @param regIndex : Register index to write to, must be 0..3
- * @param value : Value to write
- * @return None
- */
- STATIC INLINE void Chip_PMU_WriteGPREG(LPC_PMU_T *pPMU, uint8_t regIndex, uint32_t value)
- {
- pPMU->GPREG[regIndex] = value;
- }
- /**
- * @brief Read a value to a GPREG register
- * @param pPMU : Pointer to PMU register block
- * @param regIndex : Register index to read from, must be 0..3
- * @return Value read from the GPREG register
- */
- STATIC INLINE uint32_t Chip_PMU_ReadGPREG(LPC_PMU_T *pPMU, uint8_t regIndex)
- {
- return pPMU->GPREG[regIndex];
- }
- /**
- * @brief Enter MCU Sleep mode
- * @param pPMU : Pointer to PMU register block
- * @return None
- * @note The sleep mode affects the ARM Cortex-M0+ core only. Peripherals
- * and memories are active.
- */
- void Chip_PMU_SleepState(LPC_PMU_T *pPMU);
- /**
- * @brief Enter MCU Deep Sleep mode
- * @param pPMU : Pointer to PMU register block
- * @return None
- * @note In Deep-sleep mode, the peripherals receive no internal clocks.
- * The flash is in stand-by mode. The SRAM memory and all peripheral registers
- * as well as the processor maintain their internal states. The WWDT, WKT,
- * and BOD can remain active to wake up the system on an interrupt.
- */
- void Chip_PMU_DeepSleepState(LPC_PMU_T *pPMU);
- /**
- * @brief Enter MCU Power down mode
- * @param pPMU : Pointer to PMU register block
- * @return None
- * @note In Power-down mode, the peripherals receive no internal clocks.
- * The internal SRAM memory and all peripheral registers as well as the
- * processor maintain their internal states. The flash memory is powered
- * down. The WWDT, WKT, and BOD can remain active to wake up the system
- * on an interrupt.
- */
- void Chip_PMU_PowerDownState(LPC_PMU_T *pPMU);
- /**
- * @brief Enter MCU Deep Power down mode
- * @param pPMU : Pointer to PMU register block
- * @return None
- * @note For maximal power savings, the entire system is shut down
- * except for the general purpose registers in the PMU and the self
- * wake-up timer. Only the general purpose registers in the PMU maintain
- * their internal states. The part can wake up on a pulse on the WAKEUP
- * pin or when the self wake-up timer times out. On wake-up, the part
- * reboots.
- */
- void Chip_PMU_DeepPowerDownState(LPC_PMU_T *pPMU);
- /**
- * @brief Place the MCU in a low power state
- * @param pPMU : Pointer to PMU register block
- * @param SleepMode : Sleep mode
- * @return None
- */
- void Chip_PMU_Sleep(LPC_PMU_T *pPMU, CHIP_PMU_MCUPOWER_T SleepMode);
- /**
- * @brief Disables deep power-down mode
- * @param pPMU : Pointer to PMU register block
- * @return None
- * @note Calling this functions prevents entry to Deep power-down
- * mode. Once set, this can only be cleared by power-on reset.
- */
- STATIC INLINE void Chip_PMU_DisableDeepPowerDown(LPC_PMU_T *pPMU)
- {
- pPMU->PCON = PMU_PCON_NODPD | (pPMU->PCON & ~PMU_PCON_RESERVED);
- }
- /**
- * @brief Returns sleep/power-down flags
- * @param pPMU : Pointer to PMU register block
- * @return Or'ed values of PMU_PCON_SLEEPFLAG and PMU_PCON_DPDFLAG
- * @note These indicate that the PMU is setup for entry into a low
- * power state on the next WFI() instruction.
- */
- STATIC INLINE uint32_t Chip_PMU_GetSleepFlags(LPC_PMU_T *pPMU)
- {
- return (pPMU->PCON & (PMU_PCON_SLEEPFLAG | PMU_PCON_DPDFLAG));
- }
- /**
- * @brief Clears sleep/power-down flags
- * @param pPMU : Pointer to PMU register block
- * @param flags : Or'ed value of PMU_PCON_SLEEPFLAG and PMU_PCON_DPDFLAG
- * @return Nothing
- * @note Use this function to clear a low power state prior to calling
- * WFI().
- */
- STATIC INLINE void Chip_PMU_ClearSleepFlags(LPC_PMU_T *pPMU, uint32_t flags)
- {
- pPMU->PCON |= (flags & (~PMU_PCON_RESERVED));
- }
- /**
- * @brief Sets deep power-down functions
- * @param pPMU : Pointer to PMU register block
- * @param flags : Or'ed value of PMU_DPDCTRL_* values
- * @return Nothing
- * @note Some of these functions may need to be set prior to going
- * into a low power mode. Note that some calls to this function enable
- * functions while others disable it based on the PMU_DPDCTRL_*
- * definitions.
- */
- STATIC INLINE void Chip_PMU_SetPowerDownControl(LPC_PMU_T *pPMU, uint32_t flags)
- {
- pPMU->DPDCTRL = flags | (pPMU->DPDCTRL & ~PMU_DPDCTRL_RESERVED);
- }
- /**
- * @brief Cleats deep power-down functions
- * @param pPMU : Pointer to PMU register block
- * @param flags : Or'ed value of PMU_DPDCTRL_* values
- * @return Nothing
- * @note Some of these functions may need to be cleared prior to going
- * into a low power mode. Note that some calls to this function enable
- * functions while others disable it based on the PMU_DPDCTRL_*
- * definitions.
- */
- STATIC INLINE void Chip_PMU_ClearPowerDownControl(LPC_PMU_T *pPMU, uint32_t flags)
- {
- pPMU->DPDCTRL &= ~(flags | PMU_DPDCTRL_RESERVED);
- }
- /**
- * @}
- */
- #ifdef __cplusplus
- }
- #endif
- #endif /* __PMU_8XX_H_ */
|