mirror of
https://github.com/RT-Thread/rt-thread.git
synced 2025-01-14 19:09:24 +08:00
327 lines
12 KiB
C
327 lines
12 KiB
C
|
/**********************************************************************
|
||
|
* $Id$ lpc_clkpwr.c 2011-06-02
|
||
|
*//**
|
||
|
* @file lpc_clkpwr.c
|
||
|
* @brief Contains all functions support for Clock and Power Control
|
||
|
* firmware library on LPC
|
||
|
* @version 1.0
|
||
|
* @date 02. June. 2011
|
||
|
* @author NXP MCU SW Application Team
|
||
|
*
|
||
|
* Copyright(C) 2011, 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
|
||
|
* @{
|
||
|
*/
|
||
|
#ifdef __BUILD_WITH_EXAMPLE__
|
||
|
#include "lpc_libcfg.h"
|
||
|
#else
|
||
|
#include "lpc_libcfg_default.h"
|
||
|
#endif /* __BUILD_WITH_EXAMPLE__ */
|
||
|
#ifdef _CLKPWR
|
||
|
|
||
|
/* Includes ------------------------------------------------------------------- */
|
||
|
#include "lpc_clkpwr.h"
|
||
|
|
||
|
uint32_t USBFrequency = 0;
|
||
|
|
||
|
|
||
|
/* Public Functions ----------------------------------------------------------- */
|
||
|
/** @addtogroup CLKPWR_Public_Functions
|
||
|
* @{
|
||
|
*/
|
||
|
|
||
|
/*********************************************************************//**
|
||
|
* @brief Set value of each Peripheral Clock Selection
|
||
|
* @param[in] ClkType clock type that will be divided, should be:
|
||
|
* - CLKPWR_CLKTYPE_CPU : CPU clock
|
||
|
* - CLKPWR_CLKTYPE_PER : Peripheral clock
|
||
|
* - CLKPWR_CLKTYPE_EMC : EMC clock
|
||
|
* - CLKPWR_CLKTYPE_USB : USB clock
|
||
|
* @param[in] DivVal Value of divider. This value should be set as follows:
|
||
|
* - CPU clock: DivVal must be in range: 0..31
|
||
|
* - Peripheral clock: DivVal must be in range: 0..31
|
||
|
* - EMC clock: DivVal must be:
|
||
|
* + 0: The EMC uses the same clock as the CPU
|
||
|
* + 1: The EMC uses a clock at half the rate of the CPU
|
||
|
* - USB clock: DivVal must be:
|
||
|
* + 0: the divider is turned off, no clock will
|
||
|
* be provided to the USB subsystem
|
||
|
* + 4: PLL0 output is divided by 4. PLL0 output must be 192MHz
|
||
|
* + 6: PLL0 output is divided by 6. PLL0 output must be 288MHz
|
||
|
* @return none
|
||
|
* Note: Pls assign right DivVal, this function will not check if it is illegal.
|
||
|
**********************************************************************/
|
||
|
void CLKPWR_SetCLKDiv (uint8_t ClkType, uint8_t DivVal)
|
||
|
{
|
||
|
uint32_t tmp;
|
||
|
switch(ClkType)
|
||
|
{
|
||
|
case CLKPWR_CLKTYPE_CPU:
|
||
|
tmp = LPC_SC->CCLKSEL & ~(0x1F);
|
||
|
tmp |= DivVal & 0x1F;
|
||
|
LPC_SC->CCLKSEL = tmp;
|
||
|
SystemCoreClockUpdate(); //Update clock
|
||
|
break;
|
||
|
case CLKPWR_CLKTYPE_PER:
|
||
|
tmp = LPC_SC->PCLKSEL & ~(0x1F);
|
||
|
tmp |= DivVal & 0x1F;
|
||
|
LPC_SC->PCLKSEL = tmp;
|
||
|
SystemCoreClockUpdate(); //Update clock
|
||
|
break;
|
||
|
case CLKPWR_CLKTYPE_EMC:
|
||
|
tmp = LPC_SC->EMCCLKSEL & ~(0x01);
|
||
|
tmp |= DivVal & 0x01;
|
||
|
LPC_SC->EMCCLKSEL = tmp;
|
||
|
SystemCoreClockUpdate(); //Update clock
|
||
|
break;
|
||
|
case CLKPWR_CLKTYPE_USB:
|
||
|
tmp = LPC_SC->USBCLKSEL & ~(0x1F);
|
||
|
tmp |= DivVal & 0x1F;
|
||
|
LPC_SC->USBCLKSEL |= DivVal & 0x1F;
|
||
|
SystemCoreClockUpdate(); //Update clock
|
||
|
break;
|
||
|
default:
|
||
|
while(1);//Error Loop;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*********************************************************************//**
|
||
|
* @brief Get current clock value
|
||
|
* @param[in] ClkType clock type that will be divided, should be:
|
||
|
* - CLKPWR_CLKTYPE_CPU : CPU clock
|
||
|
* - CLKPWR_CLKTYPE_PER : Peripheral clock
|
||
|
* - CLKPWR_CLKTYPE_EMC : EMC clock
|
||
|
* - CLKPWR_CLKTYPE_USB : USB clock
|
||
|
**********************************************************************/
|
||
|
uint32_t CLKPWR_GetCLK (uint8_t ClkType)
|
||
|
{
|
||
|
switch(ClkType)
|
||
|
{
|
||
|
case CLKPWR_CLKTYPE_CPU:
|
||
|
return SystemCoreClock;
|
||
|
|
||
|
case CLKPWR_CLKTYPE_PER:
|
||
|
return PeripheralClock;
|
||
|
|
||
|
case CLKPWR_CLKTYPE_EMC:
|
||
|
return EMCClock;
|
||
|
|
||
|
case CLKPWR_CLKTYPE_USB:
|
||
|
return USBClock;
|
||
|
|
||
|
default:
|
||
|
while(1);//error loop
|
||
|
}
|
||
|
}
|
||
|
|
||
|
/*********************************************************************//**
|
||
|
* @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_PCLCD : LCD
|
||
|
* - CLKPWR_PCONP_PCTIM0 : Timer 0
|
||
|
* - CLKPWR_PCONP_PCTIM1 : Timer 1
|
||
|
* - CLKPWR_PCONP_PCUART0 : UART 0
|
||
|
* - CLKPWR_PCONP_PCUART1 : UART 1
|
||
|
* - CLKPWR_PCONP_PCPWM0 : PWM 0
|
||
|
* - CLKPWR_PCONP_PCPWM1 : PWM 1
|
||
|
* - CLKPWR_PCONP_PCI2C0 : I2C 0
|
||
|
* - CLKPWR_PCONP_PCUART4 : UART4
|
||
|
* - CLKPWR_PCONP_PCLCD : LCD
|
||
|
* - CLKPWR_PCONP_PCTIM0 : Timer 0
|
||
|
* - CLKPWR_PCONP_PCRTC : RTC
|
||
|
* - CLKPWR_PCONP_PCSSP1 : SSP 1
|
||
|
* - CLKPWR_PCONP_PCEMC : EMC
|
||
|
* - CLKPWR_PCONP_PCADC : ADC
|
||
|
* - CLKPWR_PCONP_PCAN1 : CAN 1
|
||
|
* - CLKPWR_PCONP_PCAN2 : CAN 2
|
||
|
* - CLKPWR_PCONP_PCGPIO : GPIO
|
||
|
* - CLKPWR_PCONP_PCMC : MCPWM
|
||
|
* - CLKPWR_PCONP_PCQEI : QEI
|
||
|
* - CLKPWR_PCONP_PCI2C1 : I2C 1
|
||
|
* - CLKPWR_PCONP_PCSSP2 : SSP 2
|
||
|
* - 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_PCSDC : SDC
|
||
|
* - 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;
|
||
|
}
|
||
|
else if (NewState == DISABLE)
|
||
|
{
|
||
|
LPC_SC->PCONP &= ~PPType;
|
||
|
}
|
||
|
}
|
||
|
|
||
|
#if 0
|
||
|
// nxp21346
|
||
|
/*********************************************************************//**
|
||
|
* @brief Configure hardware reset for each peripheral according to NewState
|
||
|
* @param[in] PPType Type of peripheral used to enable power,
|
||
|
* should be one of the following:
|
||
|
* - CLKPWR_RSTCON0_LCD : LCD
|
||
|
* - CLKPWR_RSTCON0_TIM0 : Timer 0
|
||
|
- CLKPWR_RSTCON0_TIM1 : Timer 1
|
||
|
- CLKPWR_RSTCON0_UART0 : UART 0
|
||
|
- CLKPWR_RSTCON0_UART1 : UART 1
|
||
|
- CLKPWR_RSTCON0_PWM0 : PWM 0
|
||
|
- CLKPWR_RSTCON0_PWM1 : PWM 1
|
||
|
- CLKPWR_RSTCON0_I2C0 : I2C 0
|
||
|
- CLKPWR_RSTCON0_UART4 : UART 4
|
||
|
- CLKPWR_RSTCON0_RTC : RTC
|
||
|
- CLKPWR_RSTCON0_SSP1 : SSP 1
|
||
|
- CLKPWR_RSTCON0_EMC : EMC
|
||
|
- CLKPWR_RSTCON0_ADC : ADC
|
||
|
- CLKPWR_RSTCON0_CAN1 : CAN 1
|
||
|
- CLKPWR_RSTCON0_CAN2 : CAN 2
|
||
|
- CLKPWR_RSTCON0_GPIO : GPIO
|
||
|
- CLKPWR_RSTCON0_MCPWM : MCPWM
|
||
|
- CLKPWR_RSTCON0_QEI : QEI
|
||
|
- CLKPWR_RSTCON0_I2C1 : I2C 1
|
||
|
- CLKPWR_RSTCON0_SSP2 : SSP 2
|
||
|
- CLKPWR_RSTCON0_SSP0 : SSP 0
|
||
|
- CLKPWR_RSTCON0_TIM2 : Timer 2
|
||
|
- CLKPWR_RSTCON0_TIM3 : Timer 3
|
||
|
- CLKPWR_RSTCON0_UART2 : UART 2
|
||
|
- CLKPWR_RSTCON0_UART3 : UART 3
|
||
|
- CLKPWR_RSTCON0_I2C2 : I2C 2
|
||
|
- CLKPWR_RSTCON0_I2S : I2S
|
||
|
- CLKPWR_RSTCON0_SDC : SDC
|
||
|
- CLKPWR_RSTCON0_GPDMA : GPDMA
|
||
|
- CLKPWR_RSTCON0_ENET : Ethernet
|
||
|
- CLKPWR_RSTCON0_USB : 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_ConfigReset(uint8_t PType, FunctionalState NewState)
|
||
|
{
|
||
|
if(PType < 32)
|
||
|
{
|
||
|
if(NewState == ENABLE)
|
||
|
LPC_SC->RSTCON0 |=(1<<PType);
|
||
|
else
|
||
|
LPC_SC->RSTCON0 &=~(1<<PType);
|
||
|
}
|
||
|
else
|
||
|
{
|
||
|
if(NewState == ENABLE)
|
||
|
LPC_SC->RSTCON1 |= (1<<(PType - 31));
|
||
|
else
|
||
|
LPC_SC->RSTCON1 &= ~(1<<(PType - 31));
|
||
|
}
|
||
|
}
|
||
|
// nxp21346
|
||
|
#endif
|
||
|
|
||
|
/*********************************************************************//**
|
||
|
* @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();
|
||
|
}
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
#endif /*_CLKPWR*/
|
||
|
|
||
|
/**
|
||
|
* @}
|
||
|
*/
|
||
|
|
||
|
/* --------------------------------- End Of File ------------------------------ */
|