703 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			703 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * @brief LPC13xx System Control registers and control functions
 | |
|  *
 | |
|  * @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 __SYSCTL_13XX_H_
 | |
| #define __SYSCTL_13XX_H_
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /** @defgroup SYSCTL_13XX CHIP: LPC13xx System Control block driver
 | |
|  * @ingroup CHIP_13XX_Drivers
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| #if defined(CHIP_LPC1343)
 | |
| /**
 | |
|  * @brief Start state control structure
 | |
|  */
 | |
| typedef struct {
 | |
| 	__IO uint32_t  STARTAPR;		/*!< Start logic edge control register */
 | |
| 	__IO uint32_t  STARTER;			/*!< Start logic signal enable register */
 | |
| 	__IO uint32_t  STARTRSRCLR;		/*!< Start logic reset register */
 | |
| 	__IO uint32_t  STARTSR;			/*!< Start logic status register */
 | |
| } LPC_SYSCTL_STARTST_T;
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * @brief LPC13XX System Control block structure
 | |
|  */
 | |
| typedef struct {			/*!< SYSCTL Structure */
 | |
| 	__IO uint32_t  SYSMEMREMAP;		/*!< System Memory remap register */
 | |
| 	__IO uint32_t  PRESETCTRL;		/*!< Peripheral reset Control register */
 | |
| 	__IO uint32_t  SYSPLLCTRL;		/*!< System PLL control register */
 | |
| 	__I  uint32_t  SYSPLLSTAT;		/*!< System PLL status register */
 | |
| 	__IO uint32_t  USBPLLCTRL;		/*!< USB PLL control register, LPC134x only */
 | |
| 	__I  uint32_t  USBPLLSTAT;		/*!< USB PLL status register, LPC134x only */
 | |
| 	__I  uint32_t  RESERVED1[2];
 | |
| 	__IO uint32_t  SYSOSCCTRL;		/*!< System Oscillator control register */
 | |
| 	__IO uint32_t  WDTOSCCTRL;		/*!< Watchdog Oscillator control register */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED2[2];
 | |
| #else
 | |
| 	__IO uint32_t  IRCCTRL;			/*!< IRC control register */
 | |
| 	__I  uint32_t  RESERVED2[1];
 | |
| #endif
 | |
| 
 | |
| 	__IO uint32_t  SYSRSTSTAT;		/*!< System Reset Status register           */
 | |
| 	__I  uint32_t  RESERVED3[3];
 | |
| 	__IO uint32_t  SYSPLLCLKSEL;	/*!< System PLL clock source select register */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED4;
 | |
| #else
 | |
| 	__IO uint32_t  SYSPLLCLKUEN;	/*!< System PLL clock source update enable register*/
 | |
| #endif
 | |
| 	__IO uint32_t  USBPLLCLKSEL;	/*!< USB PLL clock source select register, LPC134x only */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED4A[1];
 | |
| #else
 | |
| 	__IO uint32_t  USBPLLCLKUEN;	/*!< USB PLL clock source update enable register, LPC1342/43 only */
 | |
| #endif
 | |
| 	__I  uint32_t  RESERVED5[8];
 | |
| 	__IO uint32_t  MAINCLKSEL;		/*!< Main clock source select register		*/
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__IO uint32_t  RESERVED6;
 | |
| #else
 | |
| 	__IO uint32_t  MAINCLKUEN;		/*!< Main clock source update enable register	*/
 | |
| #endif
 | |
| 	__IO uint32_t  SYSAHBCLKDIV;	/*!< System Clock divider register */
 | |
| 	__I  uint32_t  RESERVED6A;
 | |
| 	__IO uint32_t  SYSAHBCLKCTRL;	/*!< System Clock control register */
 | |
| 	__I  uint32_t  RESERVED7[4];
 | |
| 	__IO uint32_t  SSP0CLKDIV;		/*!< SSP0 clock divider register   */
 | |
| 	__IO uint32_t  USARTCLKDIV;		/*!< UART clock divider register   */
 | |
| 	__IO uint32_t  SSP1CLKDIV;		/*!< SSP1 clock divider register */
 | |
| 	__I  uint32_t  RESERVED8[3];
 | |
| 	__IO uint32_t  TRACECLKDIV;		/*!< ARM trace clock divider register */
 | |
| 	__IO uint32_t  SYSTICKCLKDIV;	/*!< SYSTICK clock divider register */
 | |
| 	__I  uint32_t  RESERVED9[3];
 | |
| 	__IO uint32_t  USBCLKSEL;		/*!< USB clock source select register, LPC134x only */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED10;
 | |
| #else
 | |
| 	__IO uint32_t  USBCLKUEN;		/*!< USB clock source update enable register, LPC1342/43 only */
 | |
| #endif
 | |
| 	__IO uint32_t  USBCLKDIV;		/*!< USB clock source divider register, LPC134x only */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED11[4];
 | |
| #else
 | |
| 	__I  uint32_t  RESERVED11;
 | |
| 	__IO uint32_t  WDTCLKSEL;		/*!< WDT clock source select register, some parts only */
 | |
| 	__IO uint32_t  WDTCLKUEN;		/*!< WDT clock source update enable register, some parts only */
 | |
| 	__IO uint32_t  WDTCLKDIV;		/*!< WDT clock divider register, some parts only */
 | |
| #endif
 | |
| 	__I  uint32_t  RESERVED13;
 | |
| 	__IO uint32_t  CLKOUTSEL;		/*!< Clock out source select register */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED12;
 | |
| #else
 | |
| 	__IO uint32_t  CLKOUTUEN;		/*!< Clock out source update enable register, not on LPC1311/13/42/43 only */
 | |
| #endif
 | |
| 	__IO uint32_t  CLKOUTDIV;		/*!< Clock out divider register */
 | |
| 	__I  uint32_t  RESERVED14[5];
 | |
| 	__I  uint32_t  PIOPORCAP[2];	/*!< POR captured PIO status registers */
 | |
| 	__I  uint32_t  RESERVED15[18];
 | |
| 	__IO uint32_t  BODCTRL;			/*!< Brown Out Detect register */
 | |
| 	__IO uint32_t  SYSTCKCAL;		/*!< System tick counter calibration register */
 | |
| #if defined(CHIP_LPC1347)
 | |
| 	__I  uint32_t  RESERVED16[6];
 | |
| 	__IO uint32_t  IRQLATENCY;		/*!< IRQ delay register */
 | |
| 	__IO uint32_t  NMISRC;			/*!< NMI source control register,some parts only */
 | |
| 	__IO uint32_t  PINTSEL[8];		/*!< GPIO pin interrupt select register 0-7 */
 | |
| 	__IO uint32_t  USBCLKCTRL;		/*!< USB clock control register, LPC134x only */
 | |
| 	__I  uint32_t  USBCLKST;		/*!< USB clock status register, LPC134x only */
 | |
| 	__I  uint32_t  RESERVED17[25];
 | |
| 	__IO uint32_t  STARTERP0;		/*!< Start logic 0 interrupt wake-up enable register */
 | |
| 	__I  uint32_t  RESERVED18[3];
 | |
| 	__IO uint32_t  STARTERP1;		/*!< Start logic 1 interrupt wake-up enable register */
 | |
| 	__I  uint32_t  RESERVED19[6];
 | |
| #else
 | |
| 	__I  uint32_t  RESERVED16[42];
 | |
| 	LPC_SYSCTL_STARTST_T STARTLOGIC[2];
 | |
| 	__I  uint32_t  RESERVED17[4];
 | |
| #endif
 | |
| 	__IO uint32_t  PDSLEEPCFG;		/*!< Power down states in deep sleep mode register */
 | |
| 	__IO uint32_t  PDWAKECFG;		/*!< Power down states in wake up from deep sleep register */
 | |
| 	__IO uint32_t  PDRUNCFG;		/*!< Power configuration register*/
 | |
| 	__I  uint32_t  RESERVED20[110];
 | |
| 	__I  uint32_t  DEVICEID;		/*!< Device ID register */
 | |
| } LPC_SYSCTL_T;
 | |
| 
 | |
| /**
 | |
|  * System memory remap modes used to remap interrupt vectors
 | |
|  */
 | |
| typedef enum CHIP_SYSCTL_BOOT_MODE_REMAP {
 | |
| 	REMAP_BOOT_LOADER_MODE,	/*!< Interrupt vectors are re-mapped to Boot ROM */
 | |
| 	REMAP_USER_RAM_MODE,	/*!< Interrupt vectors are re-mapped to Static RAM */
 | |
| 	REMAP_USER_FLASH_MODE	/*!< Interrupt vectors are not re-mapped and reside in Flash */
 | |
| } CHIP_SYSCTL_BOOT_MODE_REMAP_T;
 | |
| 
 | |
| /**
 | |
|  * @brief	Re-map interrupt vectors
 | |
|  * @param	remap	: system memory map value
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_Map(CHIP_SYSCTL_BOOT_MODE_REMAP_T remap)
 | |
| {
 | |
| 	LPC_SYSCTL->SYSMEMREMAP = (uint32_t) remap;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Peripheral reset identifiers, not available on all devices
 | |
|  */
 | |
| typedef enum CHIP_SYSCTL_PERIPH_RESET {
 | |
| 	RESET_SSP0,			/*!< SSP0 reset control */
 | |
| 	RESET_I2C0,			/*!< I2C0 reset control */
 | |
| 	RESET_SSP1			/*!< SSP1 reset control */
 | |
| } CHIP_SYSCTL_PERIPH_RESET_T;
 | |
| 
 | |
| /**
 | |
|  * @brief	Assert reset for a peripheral
 | |
|  * @param	periph	: Peripheral to assert reset for
 | |
|  * @return	Nothing
 | |
|  * @note	The peripheral will stay in reset until reset is de-asserted. Call
 | |
|  * Chip_SYSCTL_DeassertPeriphReset() to de-assert the reset.
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_AssertPeriphReset(CHIP_SYSCTL_PERIPH_RESET_T periph)
 | |
| {
 | |
| 	LPC_SYSCTL->PRESETCTRL &= ~(1 << (uint32_t) periph);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	De-assert reset for a peripheral
 | |
|  * @param	periph	: Peripheral to de-assert reset for
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DeassertPeriphReset(CHIP_SYSCTL_PERIPH_RESET_T periph)
 | |
| {
 | |
| 	LPC_SYSCTL->PRESETCTRL |= (1 << (uint32_t) periph);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Resets a peripheral
 | |
|  * @param	periph	:	Peripheral to reset
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_PeriphReset(CHIP_SYSCTL_PERIPH_RESET_T periph)
 | |
| {
 | |
| 	Chip_SYSCTL_AssertPeriphReset(periph);
 | |
| 	Chip_SYSCTL_DeassertPeriphReset(periph);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * System reset status
 | |
|  */
 | |
| #define SYSCTL_RST_POR    (1 << 0)	/*!< POR reset status */
 | |
| #define SYSCTL_RST_EXTRST (1 << 1)	/*!< External reset status */
 | |
| #define SYSCTL_RST_WDT    (1 << 2)	/*!< Watchdog reset status */
 | |
| #define SYSCTL_RST_BOD    (1 << 3)	/*!< Brown-out detect reset status */
 | |
| #define SYSCTL_RST_SYSRST (1 << 4)	/*!< software system reset status */
 | |
| 
 | |
| /**
 | |
|  * @brief	Get system reset status
 | |
|  * @return	An Or'ed value of SYSCTL_RST_*
 | |
|  * @note	This function returns the detected reset source(s).
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetSystemRSTStatus(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->SYSRSTSTAT;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Clear system reset status
 | |
|  * @param	reset	: An Or'ed value of SYSCTL_RST_* status to clear
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_ClearSystemRSTStatus(uint32_t reset)
 | |
| {
 | |
| 	LPC_SYSCTL->SYSRSTSTAT = reset;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Read POR captured PIO status
 | |
|  * @param	index	: POR register index, 0 or 1
 | |
|  * @return	captured POR PIO status
 | |
|  * @note	See the user manual for decoing of these bits.
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetPORPIOStatus(int index)
 | |
| {
 | |
| 	return LPC_SYSCTL->PIOPORCAP[index];
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Brown-out detector reset level
 | |
|  */
 | |
| typedef enum CHIP_SYSCTL_BODRSTLVL {
 | |
| 	SYSCTL_BODRSTLVL_1_46V,	/*!< Brown-out reset at 1.46v */
 | |
| 	SYSCTL_BODRSTLVL_2_06V,	/*!< Brown-out reset at 2.06v */
 | |
| 	SYSCTL_BODRSTLVL_2_35V,	/*!< Brown-out reset at 2.35v */
 | |
| 	SYSCTL_BODRSTLVL_2_63V,	/*!< Brown-out reset at 2.63v */
 | |
| } CHIP_SYSCTL_BODRSTLVL_T;
 | |
| 
 | |
| /**
 | |
|  * Brown-out detector interrupt level
 | |
|  */
 | |
| typedef enum CHIP_SYSCTL_BODRINTVAL {
 | |
| #if defined(CHIP_LPC1343)
 | |
| 	SYSCTL_BODINTVAL_1_69V,	/*!< Brown-out interrupt at 1.65v */
 | |
| #else
 | |
| 	SYSCTL_BODINTVAL_RESERVED1,
 | |
| #endif
 | |
| 	SYSCTL_BODINTVAL_2_22V,	/*!< Brown-out interrupt at 2.22v */
 | |
| 	SYSCTL_BODINTVAL_2_52V,	/*!< Brown-out interrupt at 2.52v */
 | |
| 	SYSCTL_BODINTVAL_2_80V,	/*!< Brown-out interrupt at 2.8v */
 | |
| } CHIP_SYSCTL_BODRINTVAL_T;
 | |
| 
 | |
| /**
 | |
|  * @brief	Set brown-out detection interrupt and reset levels
 | |
|  * @param	rstlvl	: Brown-out detector reset level
 | |
|  * @param	intlvl	: Brown-out interrupt level
 | |
|  * @return	Nothing
 | |
|  * @note	Brown-out detection reset will be disabled upon exiting this function.
 | |
|  * Use Chip_SYSCTL_EnableBODReset() to re-enable.
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetBODLevels(CHIP_SYSCTL_BODRSTLVL_T rstlvl,
 | |
| 											CHIP_SYSCTL_BODRINTVAL_T intlvl)
 | |
| {
 | |
| 	LPC_SYSCTL->BODCTRL = ((uint32_t) rstlvl) | (((uint32_t) intlvl) << 2);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Enable brown-out detection reset
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_EnableBODReset(void)
 | |
| {
 | |
| 	LPC_SYSCTL->BODCTRL |= (1 << 4);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Disable brown-out detection reset
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DisableBODReset(void)
 | |
| {
 | |
| 	LPC_SYSCTL->BODCTRL &= ~(1 << 4);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Set System tick timer calibration value
 | |
|  * @param	sysCalVal	: System tick timer calibration value
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetSYSTCKCAL(uint32_t sysCalVal)
 | |
| {
 | |
| 	LPC_SYSCTL->SYSTCKCAL = sysCalVal;
 | |
| }
 | |
| 
 | |
| #if defined(CHIP_LPC1347)
 | |
| /**
 | |
|  * @brief	Set System IRQ latency
 | |
|  * @param	latency	: Latency in clock ticks
 | |
|  * @return	Nothing
 | |
|  * @note	Sets the IRQ latency, a value between 0 and 255 clocks. Lower
 | |
|  * values allow better latency.
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetIRQLatency(uint32_t latency)
 | |
| {
 | |
| 	LPC_SYSCTL->IRQLATENCY = latency;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Get System IRQ latency
 | |
|  * @return	Latency in clock ticks
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetIRQLatency(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->IRQLATENCY;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Non-Maskable Interrupt Enable/Disable value
 | |
|  */
 | |
| #define SYSCTL_NMISRC_ENABLE   ((uint32_t) 1 << 31)	/*!< Enable the Non-Maskable Interrupt (NMI) source */
 | |
| 
 | |
| /**
 | |
|  * @brief	Set source for non-maskable interrupt (NMI)
 | |
|  * @param	intsrc	: IRQ number to assign to the NMI
 | |
|  * @return	Nothing
 | |
|  * @note	The NMI source will be disabled upon exiting this function. use the
 | |
|  * Chip_SYSCTL_EnableNMISource() function to enable the NMI source.
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetNMISource(uint32_t intsrc)
 | |
| {
 | |
| 	LPC_SYSCTL->NMISRC = intsrc;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Enable interrupt used for NMI source
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_EnableNMISource(void)
 | |
| {
 | |
| 	LPC_SYSCTL->NMISRC |= SYSCTL_NMISRC_ENABLE;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Disable interrupt used for NMI source
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DisableNMISource(void)
 | |
| {
 | |
| 	LPC_SYSCTL->NMISRC &= ~(SYSCTL_NMISRC_ENABLE);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Setup a pin source for the pin interrupts (0-7)
 | |
|  * @param	intno	: IRQ number
 | |
|  * @param	port		: port number 0/1)
 | |
|  * @param	pin		: pin number (0->23 for GPIO Port 0 and 0->31 for GPIO Port 1)
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetPinInterrupt(uint32_t intno, uint8_t port, uint8_t pin)
 | |
| 
 | |
| {
 | |
| 	LPC_SYSCTL->PINTSEL[intno] = (uint32_t) (port * 24 + pin);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Setup USB clock control
 | |
|  * @param	ap_clk	: USB need_clock signal control (0 or 1)
 | |
|  * @param	pol_clk	: USB need_clock polarity for triggering the USB wake-up interrupt (0 or 1)
 | |
|  * @return	Nothing
 | |
|  * @note	See the USBCLKCTRL register in the user manual for these settings.
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetUSBCLKCTRL(uint32_t ap_clk, uint32_t pol_clk)
 | |
| {
 | |
| 	LPC_SYSCTL->USBCLKCTRL = ap_clk | (pol_clk << 1);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Returns the status of the USB need_clock signal
 | |
|  * @return	true if USB need_clock statis is high, otherwise false
 | |
|  */
 | |
| STATIC INLINE bool Chip_SYSCTL_GetUSBCLKStatus(void)
 | |
| {
 | |
| 	return (bool) ((LPC_SYSCTL->USBCLKST & 0x1) != 0);
 | |
| }
 | |
| 
 | |
| #endif
 | |
| 
 | |
| #if defined(CHIP_LPC1347)
 | |
| /**
 | |
|  * @brief	Enable PIO start logic for a pin (ERP0)
 | |
|  * @param	pin	: PIO pin number (0 - 7)
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_EnableStartPin(uint32_t pin)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTERP0 |= (1 << pin);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Disable PIO start logic for a pin
 | |
|  * @param	pin	: PIO pin number (0 - 7)
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DisableStartPin(uint32_t pin)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTERP0 &= ~(1 << pin);
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Peripheral interrupt wakeup events
 | |
|  */
 | |
| #define SYSCTL_WAKEUP_WWDTINT    (1 << 12)	/*!< WWDT interrupt wake-up */
 | |
| #define SYSCTL_WAKEUP_BODINT     (1 << 13)	/*!< Brown Out Detect (BOD) interrupt wake-up */
 | |
| #define SYSCTL_WAKEUP_USB_WAKEUP (1 << 19)	/*!< USB need_clock signal wake-up, LPC1134x only */
 | |
| #define SYSCTL_WAKEUP_GPIOINT0   (1 << 20)	/*!< GPIO GROUP0 interrupt wake-up */
 | |
| #define SYSCTL_WAKEUP_GPIOINT1   (1 << 21)	/*!< GPIO GROUP1 interrupt wake-up */
 | |
| 
 | |
| /**
 | |
|  * @brief	Enables a peripheral's wakeup logic
 | |
|  * @param	periphmask	: OR'ed values of SYSCTL_WAKEUP_* for wakeup
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_EnablePeriphWakeup(uint32_t periphmask)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTERP1 |= periphmask;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Disables a peripheral's wakeup logic
 | |
|  * @param	periphmask	: OR'ed values of SYSCTL_WAKEUP_* for wakeup
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DisablePeriphWakeup(uint32_t periphmask)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTERP1 &= ~periphmask;
 | |
| }
 | |
| 
 | |
| #else /* defined(CHIP_LPC1343) */
 | |
| 
 | |
| /* Macro for Chip_SYSCTL_SetStartPinRising and Chip_SYSCTL_SetStartPinFalling
 | |
|    functions */
 | |
| #define SYSCTL_STARTST_PIN_BIT(port, pin)      (((port) * 12) + pin)
 | |
| #define SYSCTL_STARTST_PIN_INDEX(port, pin)     (SYSCTL_STARTST_PIN_BIT(port, pin) / 32)
 | |
| #define SYSCTL_STARTST_PIN(port, pin)           (1 << (SYSCTL_STARTST_PIN_BIT(port, pin) % 32))
 | |
| 
 | |
| /**
 | |
|  * @brief	Set rising edge for PIO start logic (APRP0)
 | |
|  * @param	index	: register index (0/1)
 | |
|  * @param	pins	: PIO pin(s) mask for setting rising edge start (see note)
 | |
|  * @return	Nothing
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Multiple pins can be setup for rising edge start with this function
 | |
|  *			by Or'ing together the pin values in the call. For example, the
 | |
|  *			following call would enable PIO0_5 and PIO_1_10 as rising edge start
 | |
|  *			conditions.<br>
 | |
|  *			Chip_SYSCTL_SetStartPinRising(0, SYSCTL_STARTST_PIN(0, 5) | SYSCTL_STARTST_PIN(1, 10));
 | |
|  *
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetStartPinRising(uint8_t index, uint32_t pins)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTLOGIC[index].STARTAPR |= pins;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Set falling edge for PIO start logic (APRP0)
 | |
|  * @param	index	: register index (0/1)
 | |
|  * @param	pins	: PIO pin(s) mask for setting falling edge start (see note)
 | |
|  * @return	Nothing
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Multiple pins can be setup for falling edge start with this function
 | |
|  *			by Or'ing together the pin values in the call. For example, the
 | |
|  *			following call would enable PIO0_5 and PIO_1_10 as falling edge start
 | |
|  *			conditions.<br>
 | |
|  *			Chip_SYSCTL_SetStartPinFalling(0, SYSCTL_STARTST_PIN(0, 5) | SYSCTL_STARTST_PIN(1, 10));
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_SetStartPinFalling(uint8_t index, uint32_t pins)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTLOGIC[index].STARTAPR &= ~pins;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Enables start signal for PIO start logic
 | |
|  * @param	index	: register index (0/1)
 | |
|  * @param	pins	: PIO pin(s) mask for enabling start (see note)
 | |
|  * @return	Nothing
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Multiple pins can be enabled with this function by Or'ing together the pin values
 | |
|  *			in the call. For example, the following call would enable PIO0_5 and PIO_1_10 <br>
 | |
|  *			Chip_SYSCTL_EnableStartPin(0, SYSCTL_STARTST_PIN(0, 5) | SYSCTL_STARTST_PIN(1, 10));
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_EnableStartPin(uint8_t index, uint32_t pins)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTLOGIC[index].STARTER |= pins;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Disables start signal for PIO start logic
 | |
|  * @param	index	: register index (0/1)
 | |
|  * @param	pins	: PIO pin(s) mask for disabling start (see note)
 | |
|  * @return	Nothing
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Multiple pins can be disabled with this function by Or'ing together the pin values
 | |
|  *			in the call. For example, the following call would disable PIO0_5 and PIO_1_10 <br>
 | |
|  *			Chip_SYSCTL_DisableStartPin(0, SYSCTL_STARTST_PIN(0, 5) | SYSCTL_STARTST_PIN(1, 10));
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_DisableStartPin(uint8_t index, uint32_t pins)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTLOGIC[index].STARTER &= ~pins;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Resets start logic state for PIO start logic
 | |
|  * @param	index	: register index (0/1)
 | |
|  * @param	pins	: PIO pin(s) mask for resetting state (see note)
 | |
|  * @return	Nothing
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Multiple pins can be reset with this function by Or'ing together the pin values
 | |
|  *			in the call. For example, the following call would reset start logic signal for PIO0_5 and PIO_1_10 <br>
 | |
|  *			Chip_SYSCTL_ResetStartPin(0, SYSCTL_STARTST_PIN(0, 5) | SYSCTL_STARTST_PIN(1, 10));
 | |
|  */
 | |
| STATIC INLINE void Chip_SYSCTL_ResetStartPin(uint8_t index, uint32_t pins)
 | |
| {
 | |
| 	LPC_SYSCTL->STARTLOGIC[index].STARTRSRCLR |= pins;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Returns start logic state for PIO pins
 | |
|  * @return	The start status of all PIO pins (STARTSRP0 register)
 | |
|  * @note	Use index 0 for pin PIO0_0->PIO0_11,PIO1_0->PIO1_11 and PIO2_0->PIO2_7. Index 1
 | |
|  *			is used for PIO2_8->PIO2_11 and PIO3_0->PIO3_3. <br>
 | |
|  *			Use SYSCTL_STARTST_PIN_INDEX macro to calculate the index value.<br>
 | |
|  *			Use the SYSCTL_STARTST_PIN(port, pin) to mask out status conditions.
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetStartPinStatus(uint8_t index)
 | |
| {
 | |
| 	return LPC_SYSCTL->STARTLOGIC[index].STARTSR;
 | |
| }
 | |
| 
 | |
| #endif
 | |
| 
 | |
| /**
 | |
|  * Deep sleep setup values
 | |
|  */
 | |
| #define SYSCTL_DEEPSLP_BOD_PD    (1 << 3)	/*!< BOD power-down control in Deep-sleep mode, powered down */
 | |
| #define SYSCTL_DEEPSLP_WDTOSC_PD (1 << 6)	/*!< Watchdog oscillator power control in Deep-sleep, powered down */
 | |
| 
 | |
| /**
 | |
|  * @brief	Setup deep sleep behaviour for power down
 | |
|  * @param	sleepmask	: OR'ed values of SYSCTL_DEEPSLP_* values (high to powerdown on deepsleep)
 | |
|  * @return	Nothing
 | |
|  * @note	This must be setup prior to using deep sleep. See the user manual
 | |
|  * *(PDSLEEPCFG register) for more info on setting this up. This function selects
 | |
|  * which peripherals are powered down on deep sleep.
 | |
|  * This function should only be called once with all options for power-down
 | |
|  * in that call.
 | |
|  */
 | |
| void Chip_SYSCTL_SetDeepSleepPD(uint32_t sleepmask);
 | |
| 
 | |
| /**
 | |
|  * @brief	Returns current deep sleep mask
 | |
|  * @return	OR'ed values of SYSCTL_DEEPSLP_* values
 | |
|  * @note	A high bit indicates the peripheral will power down on deep sleep.
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetDeepSleepPD(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->PDSLEEPCFG;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Deep sleep to wakeup setup values
 | |
|  */
 | |
| #define SYSCTL_SLPWAKE_IRCOUT_PD (1 << 0)	/*!< IRC oscillator output wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_IRC_PD    (1 << 1)	/*!< IRC oscillator power-down wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_FLASH_PD  (1 << 2)	/*!< Flash wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_BOD_PD    (1 << 3)	/*!< BOD wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_ADC_PD    (1 << 4)	/*!< ADC wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_SYSOSC_PD (1 << 5)	/*!< System oscillator wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_WDTOSC_PD (1 << 6)	/*!< Watchdog oscillator wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_SYSPLL_PD (1 << 7)	/*!< System PLL wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_USBPLL_PD (1 << 8)	/*!< USB PLL wake-up configuration */
 | |
| #define SYSCTL_SLPWAKE_USBPAD_PD (1 << 10)	/*!< USB transceiver wake-up configuration */
 | |
| 
 | |
| /**
 | |
|  * @brief	Setup wakeup behaviour from deep sleep
 | |
|  * @param	wakeupmask	: OR'ed values of SYSCTL_SLPWAKE_* values (high is powered down)
 | |
|  * @return	Nothing
 | |
|  * @note	This must be setup prior to using deep sleep. See the user manual
 | |
|  * *(PDWAKECFG register) for more info on setting this up. This function selects
 | |
|  * which peripherals are powered up on exit from deep sleep.
 | |
|  * This function should only be called once with all options for wakeup
 | |
|  * in that call.
 | |
|  */
 | |
| void Chip_SYSCTL_SetWakeup(uint32_t wakeupmask);
 | |
| 
 | |
| /**
 | |
|  * @brief	Return current wakeup mask
 | |
|  * @return	OR'ed values of SYSCTL_SLPWAKE_* values
 | |
|  * @note	A high state indicates the peripehral will powerup on wakeup.
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetWakeup(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->PDWAKECFG;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * Power down configuration values
 | |
|  */
 | |
| #define SYSCTL_POWERDOWN_IRCOUT_PD (1 << 0)	/*!< IRC oscillator output power down */
 | |
| #define SYSCTL_POWERDOWN_IRC_PD    (1 << 1)	/*!< IRC oscillator power-down */
 | |
| #define SYSCTL_POWERDOWN_FLASH_PD  (1 << 2)	/*!< Flash power down */
 | |
| #define SYSCTL_POWERDOWN_BOD_PD    (1 << 3)	/*!< BOD power down */
 | |
| #define SYSCTL_POWERDOWN_ADC_PD    (1 << 4)	/*!< ADC power down */
 | |
| #define SYSCTL_POWERDOWN_SYSOSC_PD (1 << 5)	/*!< System oscillator power down */
 | |
| #define SYSCTL_POWERDOWN_WDTOSC_PD (1 << 6)	/*!< Watchdog oscillator power down */
 | |
| #define SYSCTL_POWERDOWN_SYSPLL_PD (1 << 7)	/*!< System PLL power down */
 | |
| #define SYSCTL_POWERDOWN_USBPLL_PD (1 << 8)	/*!< USB PLL power-down */
 | |
| #define SYSCTL_POWERDOWN_USBPAD_PD (1 << 10)/*!< USB transceiver power-down */
 | |
| 
 | |
| /**
 | |
|  * @brief	Power down one or more blocks or peripherals
 | |
|  * @param	powerdownmask	: OR'ed values of SYSCTL_POWERDOWN_* values
 | |
|  * @return	Nothing
 | |
|  */
 | |
| void Chip_SYSCTL_PowerDown(uint32_t powerdownmask);
 | |
| 
 | |
| /**
 | |
|  * @brief	Power up one or more blocks or peripherals
 | |
|  * @param	powerupmask	: OR'ed values of SYSCTL_POWERDOWN_* values
 | |
|  * @return	Nothing
 | |
|  */
 | |
| void Chip_SYSCTL_PowerUp(uint32_t powerupmask);
 | |
| 
 | |
| /**
 | |
|  * @brief	Get power status
 | |
|  * @return	OR'ed values of SYSCTL_POWERDOWN_* values
 | |
|  * @note	A high state indicates the peripheral is powered down.
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetPowerStates(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->PDRUNCFG;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Return the device ID
 | |
|  * @return	the device ID
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_SYSCTL_GetDeviceID(void)
 | |
| {
 | |
| 	return LPC_SYSCTL->DEVICEID;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* __SYSCTL_13XX_H_ */
 | 
