2013-11-09 00:43:35 +01:00
|
|
|
/**************************************************************************//**
|
2015-05-22 07:34:41 +02:00
|
|
|
* @file
|
2013-11-09 00:43:35 +01:00
|
|
|
* @brief CMSIS Cortex-M3 Device Peripheral Access Layer Source File
|
|
|
|
* for the NXP LPC17xx Device Series
|
|
|
|
* @version V1.09
|
|
|
|
* @date 09. November 2013
|
|
|
|
*
|
|
|
|
* @note Integrated, adopted, and renamed for RIOT by Oliver Hahm.
|
|
|
|
*
|
|
|
|
* Copyright (C) 2009 ARM Limited. All rights reserved.
|
|
|
|
* Copyright (C) 2013 Oliver Hahm <oliver.hahm@inria.fr>
|
|
|
|
*
|
|
|
|
* @par
|
|
|
|
* ARM Limited (ARM) is supplying this software for use with Cortex-M
|
|
|
|
* processor based microcontrollers. This file can be freely distributed
|
|
|
|
* within development tools that are supporting such ARM based processors.
|
|
|
|
*
|
|
|
|
* THIS SOFTWARE IS PROVIDED "AS IS". NO WARRANTIES, WHETHER EXPRESS, IMPLIED
|
|
|
|
* OR STATUTORY, INCLUDING, BUT NOT LIMITED TO, IMPLIED WARRANTIES OF
|
|
|
|
* MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE APPLY TO THIS SOFTWARE.
|
|
|
|
* ARM SHALL NOT, IN ANY CIRCUMSTANCES, BE LIABLE FOR SPECIAL, INCIDENTAL, OR
|
|
|
|
* CONSEQUENTIAL DAMAGES, FOR ANY REASON WHATSOEVER.
|
|
|
|
*
|
|
|
|
******************************************************************************/
|
|
|
|
|
2017-03-06 16:28:11 +01:00
|
|
|
#include "vendor/LPC17xx.h"
|
2021-01-08 21:46:22 +01:00
|
|
|
#include "vendor/conf.h"
|
2013-11-09 00:43:35 +01:00
|
|
|
|
|
|
|
/**
|
|
|
|
* Initialize the system
|
|
|
|
*
|
|
|
|
* @brief Setup the microcontroller system.
|
2015-07-14 09:17:38 +02:00
|
|
|
* Initialize the System. */
|
2014-11-19 16:34:45 +01:00
|
|
|
void SystemInit(void)
|
2013-11-09 00:43:35 +01:00
|
|
|
{
|
2015-07-14 09:17:38 +02:00
|
|
|
#if (CLOCK_SETUP) /* Clock Setup */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->SCS = SCS_Val;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
if (SCS_Val & (1 << 5)) { /* If Main Oscillator is enabled */
|
|
|
|
while ((LPC_SC->SCS & (1 << 6)) == 0); /* Wait for Oscillator to be ready */
|
2013-11-09 00:43:35 +01:00
|
|
|
}
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->CCLKCFG = CCLKCFG_Val; /* Setup Clock Divider */
|
2013-11-09 00:43:35 +01:00
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PCLKSEL0 = PCLKSEL0_Val; /* Peripheral Clock Selection */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PCLKSEL1 = PCLKSEL1_Val;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->CLKSRCSEL = CLKSRCSEL_Val; /* Select Clock Source for PLL0 */
|
2013-11-09 00:43:35 +01:00
|
|
|
|
|
|
|
#if (PLL0_SETUP)
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PLL0CFG = PLL0CFG_Val; /* configure PLL0 */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PLL0FEED = 0xAA;
|
|
|
|
LPC_SC->PLL0FEED = 0x55;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PLL0CON = 0x01; /* PLL0 Enable */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PLL0FEED = 0xAA;
|
|
|
|
LPC_SC->PLL0FEED = 0x55;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
while (!(LPC_SC->PLL0STAT & (1 << 26))); /* Wait for PLOCK0 */
|
2013-11-09 00:43:35 +01:00
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PLL0CON = 0x03; /* PLL0 Enable & Connect */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PLL0FEED = 0xAA;
|
|
|
|
LPC_SC->PLL0FEED = 0x55;
|
|
|
|
|
|
|
|
while (!(LPC_SC->PLL0STAT & ((1 << 25) | (1 << 24)))); /* Wait for PLLC0_STAT & PLLE0_STAT */
|
|
|
|
|
|
|
|
#endif
|
|
|
|
|
|
|
|
#if (PLL1_SETUP)
|
|
|
|
LPC_SC->PLL1CFG = PLL1CFG_Val;
|
|
|
|
LPC_SC->PLL1FEED = 0xAA;
|
|
|
|
LPC_SC->PLL1FEED = 0x55;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PLL1CON = 0x01; /* PLL1 Enable */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PLL1FEED = 0xAA;
|
|
|
|
LPC_SC->PLL1FEED = 0x55;
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
while (!(LPC_SC->PLL1STAT & (1 << 10))); /* Wait for PLOCK1 */
|
2013-11-09 00:43:35 +01:00
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PLL1CON = 0x03; /* PLL1 Enable & Connect */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->PLL1FEED = 0xAA;
|
|
|
|
LPC_SC->PLL1FEED = 0x55;
|
|
|
|
|
|
|
|
while (!(LPC_SC->PLL1STAT & ((1 << 9) | (1 << 8)))); /* Wait for PLLC1_STAT & PLLE1_STAT */
|
|
|
|
|
|
|
|
#else
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->USBCLKCFG = USBCLKCFG_Val; /* Setup USB Clock Divider */
|
2013-11-09 00:43:35 +01:00
|
|
|
#endif
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->PCONP = PCONP_Val; /* Power Control for Peripherals */
|
2013-11-09 00:43:35 +01:00
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
LPC_SC->CLKOUTCFG = CLKOUTCFG_Val; /* Clock Output Configuration */
|
2013-11-09 00:43:35 +01:00
|
|
|
#endif
|
|
|
|
|
2015-07-14 09:17:38 +02:00
|
|
|
#if (FLASH_SETUP == 1) /* Flash Accelerator Setup */
|
2013-11-09 00:43:35 +01:00
|
|
|
LPC_SC->FLASHCFG = (LPC_SC->FLASHCFG & ~0x0000F000) | FLASHCFG_Val;
|
|
|
|
#endif
|
|
|
|
}
|