61 lines
2.1 KiB
C
61 lines
2.1 KiB
C
/******************************************************************************
|
|
* clkconfig.c: clock configuration C file for NXP LPC13xx Family
|
|
* Microprocessors
|
|
*
|
|
* Copyright(C) 2009, NXP Semiconductor
|
|
* All rights reserved.
|
|
*
|
|
* History
|
|
* 2009.08.20 ver 1.00 Preliminary version, first Release
|
|
*
|
|
******************************************************************************/
|
|
#include "LPC13xx.h"
|
|
#include "clkconfig.h"
|
|
|
|
/*****************************************************************************
|
|
** Function name: WDT_CLK_Setup
|
|
**
|
|
** Descriptions: Configure WDT clock.
|
|
** parameters: clock source: irc_osc(0), main_clk(1), wdt_osc(2).
|
|
**
|
|
** Returned value: None
|
|
**
|
|
*****************************************************************************/
|
|
void
|
|
WDT_CLK_Setup (uint32_t clksrc)
|
|
{
|
|
/* Watchdog configuration. */
|
|
/* Freq = 0.5Mhz, div_sel is 0, divided by 2. WDT_OSC should be 250khz */
|
|
LPC_SYSCON->WDTOSCCTRL = (0x1 << 5) | 0x00;
|
|
LPC_SYSCON->WDTCLKSEL = clksrc; /* Select clock source */
|
|
LPC_SYSCON->WDTCLKUEN = 0x01; /* Update clock */
|
|
LPC_SYSCON->WDTCLKUEN = 0x00; /* Toggle update register once */
|
|
LPC_SYSCON->WDTCLKUEN = 0x01;
|
|
while (!(LPC_SYSCON->WDTCLKUEN & 0x01)); /* Wait until updated */
|
|
LPC_SYSCON->WDTCLKDIV = 1; /* Divided by 1 */
|
|
LPC_SYSCON->PDRUNCFG &= ~(0x1 << 6); /* Let WDT clock run */
|
|
return;
|
|
}
|
|
|
|
/*****************************************************************************
|
|
** Function name: CLKOUT_Setup
|
|
**
|
|
** Descriptions: Configure CLKOUT for reference clock check.
|
|
** parameters: clock source: irc_osc(0), sys_osc(1), wdt_osc(2),
|
|
** main_clk(3).
|
|
**
|
|
** Returned value: None
|
|
**
|
|
*****************************************************************************/
|
|
void
|
|
CLKOUT_Setup (uint32_t clksrc)
|
|
{
|
|
/* debug PLL after configuration. */
|
|
LPC_SYSCON->CLKOUTCLKSEL = clksrc; /* Select Main clock */
|
|
LPC_SYSCON->CLKOUTUEN = 0x01; /* Update clock */
|
|
LPC_SYSCON->CLKOUTUEN = 0x00; /* Toggle update register once */
|
|
LPC_SYSCON->CLKOUTUEN = 0x01;
|
|
while (!(LPC_SYSCON->CLKOUTUEN & 0x01)); /* Wait until updated */
|
|
LPC_SYSCON->CLKOUTDIV = 1; /* Divided by 1 */
|
|
return;
|
|
}
|