351 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			351 lines
		
	
	
		
			13 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/**********************************************************************
							 | 
						||
| 
								 | 
							
								* $Id$      lpc17xx_clkpwr.c                2010-06-18
							 | 
						||
| 
								 | 
							
								*//**
							 | 
						||
| 
								 | 
							
								* @file     lpc17xx_clkpwr.c
							 | 
						||
| 
								 | 
							
								* @brief    Contains all functions support for Clock and Power Control
							 | 
						||
| 
								 | 
							
								*           firmware library on LPC17xx
							 | 
						||
| 
								 | 
							
								* @version  3.0
							 | 
						||
| 
								 | 
							
								* @date     18. June. 2010
							 | 
						||
| 
								 | 
							
								* @author   NXP MCU SW Application Team
							 | 
						||
| 
								 | 
							
								*
							 | 
						||
| 
								 | 
							
								* Copyright(C) 2010, NXP Semiconductor
							 | 
						||
| 
								 | 
							
								* All rights reserved.
							 | 
						||
| 
								 | 
							
								*
							 | 
						||
| 
								 | 
							
								***********************************************************************
							 | 
						||
| 
								 | 
							
								* Software that is described herein is for illustrative purposes only
							 | 
						||
| 
								 | 
							
								* which provides customers with programming information regarding the
							 | 
						||
| 
								 | 
							
								* products. This software is supplied "AS IS" without any warranties.
							 | 
						||
| 
								 | 
							
								* NXP Semiconductors assumes no responsibility or liability for the
							 | 
						||
| 
								 | 
							
								* use of the software, conveys no license or title under any patent,
							 | 
						||
| 
								 | 
							
								* copyright, or mask work right to the product. NXP Semiconductors
							 | 
						||
| 
								 | 
							
								* reserves the right to make changes in the software without
							 | 
						||
| 
								 | 
							
								* notification. NXP Semiconductors also make no representation or
							 | 
						||
| 
								 | 
							
								* warranty that such application will be suitable for the specified
							 | 
						||
| 
								 | 
							
								* use without further testing or modification.
							 | 
						||
| 
								 | 
							
								* Permission to use, copy, modify, and distribute this software and its
							 | 
						||
| 
								 | 
							
								* documentation is hereby granted, under NXP Semiconductors'
							 | 
						||
| 
								 | 
							
								* relevant copyright 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.
							 | 
						||
| 
								 | 
							
								**********************************************************************/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Peripheral group ----------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								/** @addtogroup CLKPWR
							 | 
						||
| 
								 | 
							
								 * @{
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Includes ------------------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								#include "lpc17xx_clkpwr.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Public Functions ----------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								/** @addtogroup CLKPWR_Public_Functions
							 | 
						||
| 
								 | 
							
								 * @{
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Set value of each Peripheral Clock Selection
							 | 
						||
| 
								 | 
							
								 * @param[in]   ClkType Peripheral Clock Selection of each type,
							 | 
						||
| 
								 | 
							
								 *              should be one of the following:
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_WDT        : WDT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER0     : Timer 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER1     : Timer 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART0      : UART 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART1      : UART 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PWM1       : PWM 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C0       : I2C 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SPI        : SPI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP1       : SSP 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_DAC        : DAC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ADC        : ADC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN1       : CAN 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN2       : CAN 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ACF        : ACF
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_QEI        : QEI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PCB        : PCB
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C1       : I2C 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP0       : SSP 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER2     : Timer 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER3     : Timer 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART2      : UART 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART3      : UART 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C2       : I2C 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2S        : I2S
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_RIT        : RIT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SYSCON     : SYSCON
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_MC         : MC
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								 * @param[in]   DivVal  Value of divider, should be:
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_CCLK_DIV_4 : PCLK_peripheral = CCLK/4
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_CCLK_DIV_1 : PCLK_peripheral = CCLK/1
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_CCLK_DIV_2 : PCLK_peripheral = CCLK/2
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @return none
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_SetPCLKDiv (uint32_t ClkType, uint32_t DivVal)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    uint32_t bitpos;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    bitpos = (ClkType < 32) ? (ClkType) : (ClkType - 32);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    /* PCLKSEL0 selected */
							 | 
						||
| 
								 | 
							
								    if (ClkType < 32)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        /* Clear two bit at bit position */
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCLKSEL0 &= (~(CLKPWR_PCLKSEL_BITMASK(bitpos)));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        /* Set two selected bit */
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCLKSEL0 |= (CLKPWR_PCLKSEL_SET(bitpos, DivVal));
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    /* PCLKSEL1 selected */
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        /* Clear two bit at bit position */
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCLKSEL1 &= ~(CLKPWR_PCLKSEL_BITMASK(bitpos));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        /* Set two selected bit */
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCLKSEL1 |= (CLKPWR_PCLKSEL_SET(bitpos, DivVal));
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Get current value of each Peripheral Clock Selection
							 | 
						||
| 
								 | 
							
								 * @param[in]   ClkType Peripheral Clock Selection of each type,
							 | 
						||
| 
								 | 
							
								 *              should be one of the following:
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_WDT        : WDT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER0     : Timer 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER1     : Timer 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART0      : UART 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART1      : UART 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PWM1       : PWM 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C0       : I2C 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SPI        : SPI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP1       : SSP 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_DAC        : DAC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ADC        : ADC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN1       : CAN 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN2       : CAN 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ACF        : ACF
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_QEI        : QEI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PCB        : PCB
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C1       : I2C 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP0       : SSP 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER2     : Timer 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER3     : Timer 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART2      : UART 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART3      : UART 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C2       : I2C 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2S        : I2S
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_RIT        : RIT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SYSCON     : SYSCON
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_MC         : MC
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								 * @return      Value of Selected Peripheral Clock Selection
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								uint32_t CLKPWR_GetPCLKSEL (uint32_t ClkType)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    uint32_t bitpos, retval;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (ClkType < 32)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        bitpos = ClkType;
							 | 
						||
| 
								 | 
							
								        retval = LPC_SC->PCLKSEL0;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        bitpos = ClkType - 32;
							 | 
						||
| 
								 | 
							
								        retval = LPC_SC->PCLKSEL1;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    retval = CLKPWR_PCLKSEL_GET(bitpos, retval);
							 | 
						||
| 
								 | 
							
								    return retval;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Get current value of each Peripheral Clock
							 | 
						||
| 
								 | 
							
								 * @param[in]   ClkType Peripheral Clock Selection of each type,
							 | 
						||
| 
								 | 
							
								 *              should be one of the following:
							 | 
						||
| 
								 | 
							
								 *              - CLKPWR_PCLKSEL_WDT        : WDT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER0     : Timer 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER1     : Timer 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART0      : UART 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART1      : UART 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PWM1       : PWM 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C0       : I2C 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SPI        : SPI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP1       : SSP 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_DAC        : DAC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ADC        : ADC
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN1       : CAN 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_CAN2       : CAN 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_ACF        : ACF
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_QEI        : QEI
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_PCB        : PCB
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C1       : I2C 1
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SSP0       : SSP 0
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER2     : Timer 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_TIMER3     : Timer 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART2      : UART 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_UART3      : UART 3
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2C2       : I2C 2
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_I2S        : I2S
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_RIT        : RIT
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_SYSCON     : SYSCON
							 | 
						||
| 
								 | 
							
								                - CLKPWR_PCLKSEL_MC         : MC
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								 * @return      Value of Selected Peripheral Clock
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								uint32_t CLKPWR_GetPCLK (uint32_t ClkType)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    uint32_t retval, div;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    retval = SystemCoreClock;
							 | 
						||
| 
								 | 
							
								    div = CLKPWR_GetPCLKSEL(ClkType);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    switch (div)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								    case 0:
							 | 
						||
| 
								 | 
							
								        div = 4;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 1:
							 | 
						||
| 
								 | 
							
								        div = 1;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 2:
							 | 
						||
| 
								 | 
							
								        div = 2;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 3:
							 | 
						||
| 
								 | 
							
								        div = 8;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    retval /= div;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return retval;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Configure power supply for each peripheral according to NewState
							 | 
						||
| 
								 | 
							
								 * @param[in]   PPType  Type of peripheral used to enable power,
							 | 
						||
| 
								 | 
							
								 *                      should be one of the following:
							 | 
						||
| 
								 | 
							
								 *              -  CLKPWR_PCONP_PCTIM0      : Timer 0
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCTIM1      : Timer 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCUART0     : UART 0
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCUART1     : UART 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCPWM1      : PWM 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCI2C0      : I2C 0
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCSPI       : SPI
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCRTC       : RTC
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCSSP1      : SSP 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCAD        : ADC
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCAN1       : CAN 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCAN2       : CAN 2
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCGPIO      : GPIO
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCRIT       : RIT
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCMC        : MC
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCQEI       : QEI
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCI2C1      : I2C 1
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCSSP0      : SSP 0
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCTIM2      : Timer 2
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCTIM3      : Timer 3
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCUART2     : UART 2
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCUART3     : UART 3
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCI2C2      : I2C 2
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCI2S       : I2S
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCGPDMA     : GPDMA
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCENET      : Ethernet
							 | 
						||
| 
								 | 
							
								                -  CLKPWR_PCONP_PCUSB       : USB
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @param[in]   NewState    New state of Peripheral Power, should be:
							 | 
						||
| 
								 | 
							
								 *              - ENABLE    : Enable power for this peripheral
							 | 
						||
| 
								 | 
							
								 *              - DISABLE   : Disable power for this peripheral
							 | 
						||
| 
								 | 
							
								 *
							 | 
						||
| 
								 | 
							
								 * @return none
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_ConfigPPWR (uint32_t PPType, FunctionalState NewState)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    if (NewState == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCONP |= PPType & CLKPWR_PCONP_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else if (NewState == DISABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        LPC_SC->PCONP &= (~PPType) & CLKPWR_PCONP_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enter Sleep mode with co-operated instruction by the Cortex-M3.
							 | 
						||
| 
								 | 
							
								 * @param[in]   None
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_Sleep(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    LPC_SC->PCON = 0x00;
							 | 
						||
| 
								 | 
							
								    /* Sleep Mode*/
							 | 
						||
| 
								 | 
							
								    __WFI();
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enter Deep Sleep mode with co-operated instruction by the Cortex-M3.
							 | 
						||
| 
								 | 
							
								 * @param[in]   None
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_DeepSleep(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /* Deep-Sleep Mode, set SLEEPDEEP bit */
							 | 
						||
| 
								 | 
							
								    SCB->SCR = 0x4;
							 | 
						||
| 
								 | 
							
								    LPC_SC->PCON = 0x00;
							 | 
						||
| 
								 | 
							
								    /* Deep Sleep Mode*/
							 | 
						||
| 
								 | 
							
								    __WFI();
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enter Power Down mode with co-operated instruction by the Cortex-M3.
							 | 
						||
| 
								 | 
							
								 * @param[in]   None
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_PowerDown(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /* Deep-Sleep Mode, set SLEEPDEEP bit */
							 | 
						||
| 
								 | 
							
								    SCB->SCR = 0x4;
							 | 
						||
| 
								 | 
							
								    LPC_SC->PCON = 0x01;
							 | 
						||
| 
								 | 
							
								    /* Power Down Mode*/
							 | 
						||
| 
								 | 
							
								    __WFI();
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enter Deep Power Down mode with co-operated instruction by the Cortex-M3.
							 | 
						||
| 
								 | 
							
								 * @param[in]   None
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void CLKPWR_DeepPowerDown(void)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    /* Deep-Sleep Mode, set SLEEPDEEP bit */
							 | 
						||
| 
								 | 
							
								    SCB->SCR = 0x4;
							 | 
						||
| 
								 | 
							
								    LPC_SC->PCON = 0x03;
							 | 
						||
| 
								 | 
							
								    /* Deep Power Down Mode*/
							 | 
						||
| 
								 | 
							
								    __WFI();
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @}
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @}
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* --------------------------------- End Of File ------------------------------ */
							 |