Alexan E
/
blinky
blinky example from NXP code bundle for LPC11Uxx. No mbed library used
Revision 1:0f1be4e75668, committed 2012-05-28
- Comitter:
- alexan_e
- Date:
- Mon May 28 00:13:23 2012 +0000
- Parent:
- 0:4dd6b327586a
- Commit message:
Changed in this revision
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB.lib --- a/KEIL_LPC11U_COMMON_LIB.lib Mon May 28 00:01:35 2012 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,1 +0,0 @@ -http://mbed.org/users/alexan_e/code/KEIL_LPC11U_COMMON_LIB/#05d110ee258e
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/clkconfig.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/clkconfig.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,76 @@ +/**************************************************************************** + * $Id:: clkconfig.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11Uxx Clock Configuration example + * + * Description: + * This file contains clock configuration code example which include + * watchdog setup and debug clock out setup. + * +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.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 ) +{ + /* Freq = 0.5Mhz, div_sel is 0x1F, divided by 64. WDT_OSC should be 7.8125khz */ + LPC_SYSCON->WDTOSCCTRL = (0x1<<5)|0x1F; + LPC_SYSCON->PDRUNCFG &= ~(0x1<<6); /* Let WDT clock run */ + + /* Enables clock for WDT */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<15); + LPC_WWDT->CLKSEL = clksrc; /* Select clock source */ + 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->CLKOUTSEL = 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; +} +
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/clkconfig.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/clkconfig.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,44 @@ +/**************************************************************************** + * $Id:: clkconfig.h 6172 2011-01-13 18:22:51Z usb00423 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains definition and prototype for clock configuration. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __CLKCONFIG_H +#define __CLKCONFIG_H + +#define SYSPLL_SRC_IRC_OSC 0 +#define SYSPLL_SRC_SYS_OSC 1 + +#define MAINCLK_SRC_IRC_OSC 0 +#define MAINCLK_SRC_SYSPLL_IN 1 +#define MAINCLK_SRC_WDT_OSC 2 +#define MAINCLK_SRC_SYS_PLL 3 + +#define WDTCLK_SRC_IRC_OSC 0 +#define WDTCLK_SRC_WDT_OSC 1 + +#define CLKOUTCLK_SRC_IRC_OSC 0 +#define CLKOUTCLK_SRC_SYS_OSC 1 +#define CLKOUTCLK_SRC_WDT_OSC 2 +#define CLKOUTCLK_SRC_MAIN_CLK 3 + +void WDT_CLK_Setup(uint32_t timer_num); +void CLKOUT_Setup(uint32_t timer_num); +#endif /* end __CLKCONFIG_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/gpio.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/gpio.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,827 @@ +/**************************************************************************** + * $Id:: gpio.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11Uxx GPIO example + * + * Description: + * This file contains GPIO code example which include GPIO + * initialization, GPIO interrupt handler, and related APIs for + * GPIO access. +* +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.h" /* LPC11xx Peripheral Registers */ +#include "gpio.h" + +volatile uint32_t flex_int0_counter = 0; +volatile uint32_t flex_int1_counter = 0; +volatile uint32_t flex_int2_counter = 0; +volatile uint32_t flex_int3_counter = 0; +volatile uint32_t flex_int4_counter = 0; +volatile uint32_t flex_int5_counter = 0; +volatile uint32_t flex_int6_counter = 0; +volatile uint32_t flex_int7_counter = 0; +volatile uint32_t gint0_counter = 0; +volatile uint32_t gint1_counter = 0; +volatile uint32_t flex_int0_level_counter = 0; +volatile uint32_t flex_int0_rising_edge_counter = 0; +volatile uint32_t flex_int0_falling_edge_counter = 0; +volatile uint32_t flex_int1_level_counter = 0; +volatile uint32_t flex_int1_rising_edge_counter = 0; +volatile uint32_t flex_int1_falling_edge_counter = 0; +volatile uint32_t flex_int2_level_counter = 0; +volatile uint32_t flex_int2_rising_edge_counter = 0; +volatile uint32_t flex_int2_falling_edge_counter = 0; +volatile uint32_t flex_int3_level_counter = 0; +volatile uint32_t flex_int3_rising_edge_counter = 0; +volatile uint32_t flex_int3_falling_edge_counter = 0; +volatile uint32_t flex_int4_level_counter = 0; +volatile uint32_t flex_int4_rising_edge_counter = 0; +volatile uint32_t flex_int4_falling_edge_counter = 0; +volatile uint32_t flex_int5_level_counter = 0; +volatile uint32_t flex_int5_rising_edge_counter = 0; +volatile uint32_t flex_int5_falling_edge_counter = 0; +volatile uint32_t flex_int6_level_counter = 0; +volatile uint32_t flex_int6_rising_edge_counter = 0; +volatile uint32_t flex_int6_falling_edge_counter = 0; +volatile uint32_t flex_int7_level_counter = 0; +volatile uint32_t flex_int7_rising_edge_counter = 0; +volatile uint32_t flex_int7_falling_edge_counter = 0; +volatile uint32_t gint0_level_counter = 0; +volatile uint32_t gint0_edge_counter = 0; +volatile uint32_t gint1_level_counter = 0; +volatile uint32_t gint1_edge_counter = 0; + +/***************************************************************************** +** Function name: FLEX_INT0_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT0_IRQHandler(void) +{ + flex_int0_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<0) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<0) ) + { + flex_int0_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<0) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<0) ) ) + { + flex_int0_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<0; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<0) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<0) ) ) + { + flex_int0_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<0; + } + LPC_GPIO_PIN_INT->IST = 0x1<<0; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT1_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT1_IRQHandler(void) +{ + flex_int1_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<1) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<1) ) + { + flex_int1_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<1) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<1) ) ) + { + flex_int1_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<1; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<1) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<1) ) ) + { + flex_int1_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<1; + } + LPC_GPIO_PIN_INT->IST = 0x1<<1; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT2_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT2_IRQHandler(void) +{ + flex_int2_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<2) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<2) ) + { + flex_int2_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<2) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<2) ) ) + { + flex_int2_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<2; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<2) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<2) ) ) + { + flex_int2_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<2; + } + LPC_GPIO_PIN_INT->IST = 0x1<<2; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT3_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT3_IRQHandler(void) +{ + flex_int3_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<3) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<3) ) + { + flex_int3_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<3) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<3) ) ) + { + flex_int3_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<3; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<3) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<3) ) ) + { + flex_int3_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<3; + } + LPC_GPIO_PIN_INT->IST = 0x1<<3; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT4_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT4_IRQHandler(void) +{ + flex_int4_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<4) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<4) ) + { + flex_int4_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<4) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<4) ) ) + { + flex_int4_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<4; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<4) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<4) ) ) + { + flex_int4_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<4; + } + LPC_GPIO_PIN_INT->IST = 0x1<<4; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT5_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT5_IRQHandler(void) +{ + flex_int5_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<5) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<5) ) + { + flex_int5_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<5) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<5) ) ) + { + flex_int5_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<5; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<5) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<5) ) ) + { + flex_int5_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<5; + } + LPC_GPIO_PIN_INT->IST = 0x1<<5; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT6_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT6_IRQHandler(void) +{ + flex_int6_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<6) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<6) ) + { + flex_int6_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<6) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<6) ) ) + { + flex_int6_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<6; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<6) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<6) ) ) + { + flex_int6_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<6; + } + LPC_GPIO_PIN_INT->IST = 0x1<<6; + } + } + return; +} + +/***************************************************************************** +** Function name: FLEX_INT7_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void FLEX_INT7_IRQHandler(void) +{ + flex_int7_counter++; + if ( LPC_GPIO_PIN_INT->IST & (0x1<<7) ) + { + if ( LPC_GPIO_PIN_INT->ISEL & (0x1<<7) ) + { + flex_int7_level_counter++; + } + else + { + if ( ( LPC_GPIO_PIN_INT->RISE & (0x1<<7) ) && ( LPC_GPIO_PIN_INT->IENR & (0x1<<7) ) ) + { + flex_int7_rising_edge_counter++; + LPC_GPIO_PIN_INT->RISE = 0x1<<7; + } + if ( ( LPC_GPIO_PIN_INT->FALL & (0x1<<7) ) && ( LPC_GPIO_PIN_INT->IENF & (0x1<<7) ) ) + { + flex_int7_falling_edge_counter++; + LPC_GPIO_PIN_INT->FALL = 0x1<<7; + } + LPC_GPIO_PIN_INT->IST = 0x1<<7; + } + } + return; +} + +/***************************************************************************** +** Function name: GINT0_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void GINT0_IRQHandler(void) +{ + gint0_counter++; + if ( LPC_GPIO_GROUP_INT0->CTRL & 0x1 ) + { + if ( LPC_GPIO_GROUP_INT0->CTRL & (0x1<<2) ) + { + gint0_level_counter++; + } + else + { + gint0_edge_counter++; + } + LPC_GPIO_GROUP_INT0->CTRL |= 0x1; + } + return; +} + +/***************************************************************************** +** Function name: GINT1_IRQHandler +** +** Descriptions: Use one GPIO pin as interrupt source +** +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void GINT1_IRQHandler(void) +{ + gint1_counter++; + if ( LPC_GPIO_GROUP_INT1->CTRL & 0x1 ) + { + if ( LPC_GPIO_GROUP_INT1->CTRL & (0x1<<2) ) + { + gint1_level_counter++; + } + else + { + gint1_edge_counter++; + } + LPC_GPIO_GROUP_INT1->CTRL |= 0x1; + } + return; +} + +/***************************************************************************** +** Function name: GPIOInit +** +** Descriptions: Initialize GPIO, install the +** GPIO interrupt handler +** +** parameters: None +** +** Returned value: true or false, return false if the VIC table +** is full and GPIO interrupt handler can be +** installed. +** +*****************************************************************************/ +void GPIOInit( void ) +{ + /* Enable AHB clock to the GPIO domain. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<6); + + /* Enable AHB clock to the FlexInt, GroupedInt domain. */ + LPC_SYSCON->SYSAHBCLKCTRL |= ((1<<19) | (1<<23) | (1<<24)); + + return; +} + +/***************************************************************************** +** Function name: GPIOSetFlexInterrupt +** +** Descriptions: Set interrupt sense, event, etc. +** sense: edge or level, 0 is edge, 1 is level +** event/polarity: 0 is active low/falling, 1 is high/rising. +** +** parameters: channel #, port #, bit position, sense, event(polarity) +** +** Returned value: None +** +*****************************************************************************/ +void GPIOSetFlexInterrupt( uint32_t channelNum, uint32_t portNum, uint32_t bitPosi, + uint32_t sense, uint32_t event ) +{ + switch ( channelNum ) + { + case CHANNEL0: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[0] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[0] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT0_IRQn); + break; + case CHANNEL1: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[1] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[1] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT1_IRQn); + break; + case CHANNEL2: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[2] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[2] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT2_IRQn); + break; + case CHANNEL3: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[3] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[3] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT3_IRQn); + break; + case CHANNEL4: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[4] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[4] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT4_IRQn); + break; + case CHANNEL5: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[5] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[5] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT5_IRQn); + break; + case CHANNEL6: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[6] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[6] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT6_IRQn); + break; + case CHANNEL7: + if ( portNum ) + { + LPC_SYSCON->PINTSEL[7] = bitPosi + 24; + } + else + { + LPC_SYSCON->PINTSEL[7] = bitPosi; + } + NVIC_EnableIRQ(FLEX_INT7_IRQn); + break; + default: + break; + } + if ( sense == 0 ) + { + LPC_GPIO_PIN_INT->ISEL &= ~(0x1<<channelNum); /* Edge trigger */ + if ( event == 0 ) + { + LPC_GPIO_PIN_INT->IENF |= (0x1<<channelNum); /* faling edge */ + } + else + { + LPC_GPIO_PIN_INT->IENR |= (0x1<<channelNum); /* Rising edge */ + } + } + else + { + LPC_GPIO_PIN_INT->ISEL |= (0x1<<channelNum); /* Level trigger. */ + LPC_GPIO_PIN_INT->IENR |= (0x1<<channelNum); /* Level enable */ + if ( event == 0 ) + { + LPC_GPIO_PIN_INT->IENF &= ~(0x1<<channelNum); /* active-low */ + } + else + { + LPC_GPIO_PIN_INT->IENF |= (0x1<<channelNum); /* active-high */ + } + } + return; +} + +/***************************************************************************** +** Function name: GPIOFlexIntEnable +** +** Descriptions: Enable Interrupt +** +** parameters: channel num, event(0 is falling edge, 1 is rising edge) +** Returned value: None +** +*****************************************************************************/ +void GPIOFlexIntEnable( uint32_t channelNum, uint32_t event ) +{ + if ( !( LPC_GPIO_PIN_INT->ISEL & (0x1<<channelNum) ) ) + { + if ( event == 0 ) + { + LPC_GPIO_PIN_INT->SIENF |= (0x1<<channelNum); /* faling edge */ + } + else + { + LPC_GPIO_PIN_INT->SIENR |= (0x1<<channelNum); /* Rising edge */ + } + } + else + { + LPC_GPIO_PIN_INT->SIENR |= (0x1<<channelNum); /* Level */ + } + return; +} + +/***************************************************************************** +** Function name: GPIOFlexIntDisable +** +** Descriptions: Disable Interrupt +** +** parameters: channel num, event(0 is falling edge, 1 is rising edge) +** +** Returned value: None +** +*****************************************************************************/ +void GPIOFlexIntDisable( uint32_t channelNum, uint32_t event ) +{ + if ( !( LPC_GPIO_PIN_INT->ISEL & (0x1<<channelNum) ) ) + { + if ( event == 0 ) + { + LPC_GPIO_PIN_INT->CIENF |= (0x1<<channelNum); /* faling edge */ + } + else + { + LPC_GPIO_PIN_INT->CIENR |= (0x1<<channelNum); /* Rising edge */ + } + } + else + { + LPC_GPIO_PIN_INT->CIENR |= (0x1<<channelNum); /* Level */ + } + return; +} + +/***************************************************************************** +** Function name: GPIOFlexIntStatus +** +** Descriptions: Get Interrupt status +** +** parameters: channel num +** +** Returned value: None +** +*****************************************************************************/ +uint32_t GPIOFlexIntStatus( uint32_t channelNum ) +{ + if ( LPC_GPIO_PIN_INT->IST & (0x1<<channelNum) ) + { + return( 1 ); + } + else + { + return( 0 ); + } +} + +/***************************************************************************** +** Function name: GPIOFlexIntClear +** +** Descriptions: Clear Interrupt +** +** parameters: channel num +** +** Returned value: None +** +*****************************************************************************/ +void GPIOFlexIntClear( uint32_t channelNum ) +{ + if ( !( LPC_GPIO_PIN_INT->ISEL & (0x1<<channelNum) ) ) + { + LPC_GPIO_PIN_INT->IST = (1<<channelNum); + } + return; +} + +/***************************************************************************** +** Function name: GPIOSetGroupedInterrupt +** +** Descriptions: Set interrupt logic, sense, eventPattern, etc. +** logic: AND or OR, 0 is OR, 1 is AND +** sensePattern: edge or level, 0 is edge, 1 is level +** event/polarity: 0 is active low/falling, 1 is high/rising. +** +** parameters: group #, bit pattern, logic, sense, event(polarity) pattern +** +** Returned value: None +** +*****************************************************************************/ +void GPIOSetGroupedInterrupt( uint32_t groupNum, uint32_t *bitPattern, uint32_t logic, + uint32_t sense, uint32_t *eventPattern ) +{ + switch ( groupNum ) + { + case GROUP0: + if ( sense == 0 ) + { + LPC_GPIO_GROUP_INT0->CTRL &= ~(0x1<<2); /* Edge trigger */ + } + else + { + LPC_GPIO_GROUP_INT0->CTRL |= (0x1<<2); /* Level trigger. */ + } + LPC_GPIO_GROUP_INT0->CTRL |= (logic<<1); + LPC_GPIO_GROUP_INT0->PORT_POL[0] = *((uint32_t *)(eventPattern + 0)); + LPC_GPIO_GROUP_INT0->PORT_POL[1] = *((uint32_t *)(eventPattern + 1)); + LPC_GPIO_GROUP_INT0->PORT_ENA[0] = *((uint32_t *)(bitPattern + 0)); + LPC_GPIO_GROUP_INT0->PORT_ENA[1] = *((uint32_t *)(bitPattern + 1)); + /* as soon as enabled, an edge may be generated */ + /* clear interrupt flag and NVIC pending interrupt to */ + /* workaround the potential edge generated as enabled */ + LPC_GPIO_GROUP_INT0->CTRL |= (1<<0); + NVIC_ClearPendingIRQ(GINT0_IRQn); + NVIC_EnableIRQ(GINT0_IRQn); + break; + case GROUP1: + if ( sense == 0 ) + { + LPC_GPIO_GROUP_INT1->CTRL &= ~(0x1<<2); /* Edge trigger */ + } + else + { + LPC_GPIO_GROUP_INT1->CTRL |= (0x1<<2); /* Level trigger. */ + } + LPC_GPIO_GROUP_INT1->CTRL |= (logic<<1); + LPC_GPIO_GROUP_INT1->PORT_POL[0] = *((uint32_t *)(eventPattern + 0)); + LPC_GPIO_GROUP_INT1->PORT_POL[1] = *((uint32_t *)(eventPattern + 1)); + LPC_GPIO_GROUP_INT1->PORT_ENA[0] = *((uint32_t *)(bitPattern + 0)); + LPC_GPIO_GROUP_INT1->PORT_ENA[1] = *((uint32_t *)(bitPattern + 1)); + /* as soon as enabled, an edge may be generated */ + /* clear interrupt flag and NVIC pending interrupt to */ + /* workaround the potential edge generated as enabled */ + LPC_GPIO_GROUP_INT1->CTRL |= (1<<0); + NVIC_ClearPendingIRQ(GINT1_IRQn); + NVIC_EnableIRQ(GINT1_IRQn); + break; + default: + break; + } + + return; +} + +/***************************************************************************** +** Function name: GPIOGetPinValue +** +** Descriptions: Read Current state of port pin, PIN register value +** +** parameters: port num, bit position +** Returned value: None +** +*****************************************************************************/ +uint32_t GPIOGetPinValue( uint32_t portNum, uint32_t bitPosi ) +{ + uint32_t regVal = 0; + + if( bitPosi < 0x20 ) + { + if ( LPC_GPIO->PIN[portNum] & (0x1<<bitPosi) ) + { + regVal = 1; + } + } + else if( bitPosi == 0xFF ) + { + regVal = LPC_GPIO->PIN[portNum]; + } + return ( regVal ); +} + +/***************************************************************************** +** Function name: GPIOSetBitValue +** +** Descriptions: Set/clear a bit in a specific position +** +** parameters: port num, bit position, bit value +** +** Returned value: None +** +*****************************************************************************/ +void GPIOSetBitValue( uint32_t portNum, uint32_t bitPosi, uint32_t bitVal ) +{ + if ( bitVal ) + { + LPC_GPIO->SET[portNum] = 1<<bitPosi; + } + else + { + LPC_GPIO->CLR[portNum] = 1<<bitPosi; + } + return; +} + +/***************************************************************************** +** Function name: GPIOSetDir +** +** Descriptions: Set the direction in GPIO port +** +** parameters: portNum, bit position, direction (1 out, 0 input) +** +** Returned value: None +** +*****************************************************************************/ +void GPIOSetDir( uint32_t portNum, uint32_t bitPosi, uint32_t dir ) +{ + if( dir ) + { + LPC_GPIO->DIR[portNum] |= (1<<bitPosi); + } + else + { + LPC_GPIO->DIR[portNum] &= ~(1<<bitPosi); + } + return; +} + +/****************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/gpio.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/gpio.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,64 @@ +/**************************************************************************** + * $Id:: gpio.h 6172 2011-01-13 18:22:51Z usb00423 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains definition and prototype for GPIO. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __GPIO_H +#define __GPIO_H + +#define CHANNEL0 0 +#define CHANNEL1 1 +#define CHANNEL2 2 +#define CHANNEL3 3 +#define CHANNEL4 4 +#define CHANNEL5 5 +#define CHANNEL6 6 +#define CHANNEL7 7 + +#define PORT0 0 +#define PORT1 1 + +#define GROUP0 0 +#define GROUP1 1 + +void FLEX_INT0_IRQHandler(void); +void FLEX_INT1_IRQHandler(void); +void FLEX_INT2_IRQHandler(void); +void FLEX_INT3_IRQHandler(void); +void FLEX_INT4_IRQHandler(void); +void FLEX_INT5_IRQHandler(void); +void FLEX_INT6_IRQHandler(void); +void FLEX_INT7_IRQHandler(void); +void GINT0_IRQHandler(void); +void GINT1_IRQHandler(void); +void GPIOInit( void ); +void GPIOSetFlexInterrupt( uint32_t channelNum, uint32_t portNum, uint32_t bitPosi, + uint32_t sense, uint32_t event ); +void GPIOFlexIntEnable( uint32_t channelNum, uint32_t event ); +void GPIOFlexIntDisable( uint32_t channelNum, uint32_t event ); +uint32_t GPIOFlexIntStatus( uint32_t channelNum ); +void GPIOFlexIntClear( uint32_t channelNum ); +void GPIOSetGroupedInterrupt( uint32_t groupNum, uint32_t *bitPattern, uint32_t logic, + uint32_t sense, uint32_t *eventPattern ); +uint32_t GPIOGetPinValue( uint32_t portNum, uint32_t bitPosi ); +void GPIOSetBitValue( uint32_t portNum, uint32_t bitPosi, uint32_t bitVal ); +void GPIOSetDir( uint32_t portNum, uint32_t bitPosi, uint32_t dir ); + +#endif /* end __GPIO_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/nmi.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/nmi.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,98 @@ +/**************************************************************************** + * $Id:: nmi.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11Uxx NMI interrupt example + * + * Description: + * This file contains NMI interrupt handler code example. +* +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.h" +#include "nmi.h" + +#if NMI_ENABLED +volatile uint32_t NMI_Counter[MAX_NMI_NUM]; + +/***************************************************************************** +** Function name: NMI_Handler +** +** Descriptions: NMI interrupt handler +** parameters: None +** +** Returned value: None +** +*****************************************************************************/ +void NMI_Handler( void ) +{ + uint32_t regVal; + + regVal = LPC_SYSCON->NMISRC; + regVal &= ~0x80000000; + if ( regVal < MAX_NMI_NUM ) + { + if ( regVal == TIMER_16_0_IRQn ) + { + /* Use TIMER16_0_IRQHandler as example for real application. */ + LPC_CT16B0->IR = 0xFF; /* Clear timer16_0 interrupt */ + } + else if ( regVal == TIMER_16_1_IRQn ) + { + /* Use TIMER16_1_IRQHandler as example for real application. */ + LPC_CT16B1->IR = 0xFF; /* Clear timer16_1 interrupt */ + } + else if ( regVal == TIMER_32_0_IRQn ) + { + /* Use TIMER32_0_IRQHandler as example for real application. */ + LPC_CT32B0->IR = 0xFF; /* Clear timer32_0 interrupt */ + } + else if ( regVal == TIMER_32_1_IRQn ) + { + /* Use TIMER32_0_IRQHandler as example for real application. */ + LPC_CT32B1->IR = 0xFF; /* Clear timer32_1 interrupt */ + } + NMI_Counter[regVal]++; + } + return; +} + +/***************************************************************************** +** Function name: NMI_Init +** +** Descriptions: NMI initialization +** parameters: NMI number +** +** Returned value: None +** +*****************************************************************************/ +void NMI_Init( uint32_t NMI_num ) +{ + uint32_t i; + + for ( i = 0; i < MAX_NMI_NUM; i++ ) + { + NMI_Counter[i] = 0x0; + } + LPC_SYSCON->NMISRC = 0x80000000|NMI_num; + return; +} + +#endif
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/nmi.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/nmi.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,32 @@ +/**************************************************************************** + * $Id:: nmi.h 6172 2011-01-13 18:22:51Z usb00423 $ + * Project: NXP LPC11Uxx NMI software example + * + * Description: + * This file contains definition and prototype for NMI interrupt. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __NMI_H +#define __NMI_H + +#define NMI_ENABLED 0 + +#define MAX_NMI_NUM 32 + +void NMI_Init( uint32_t NMI_num ); +void NMI_Handler(void); +#endif /* end __NMI_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/timer16.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/timer16.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,581 @@ +/**************************************************************************** + * $Id:: timer16.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11Uxx 16-bit timer example + * + * Description: + * This file contains 16-bit timer code example which include timer + * initialization, timer interrupt handler, and related APIs for + * timer setup. +* +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.h" +#include "timer16.h" +#include "nmi.h" + +volatile uint32_t timer16_0_counter[2] = {0,0}; +volatile uint32_t timer16_1_counter[2] = {0,0}; +volatile uint32_t timer16_0_capture[2] = {0,0}; +volatile uint32_t timer16_1_capture[2] = {0,0}; +volatile uint32_t timer16_0_period = 0; +volatile uint32_t timer16_1_period = 0; + +/***************************************************************************** +** Function name: delayMs +** +** Descriptions: Start the timer delay in milo seconds +** until elapsed +** +** parameters: timer number, Delay value in milo second +** +** Returned value: None +** +*****************************************************************************/ +void delayMs(uint8_t timer_num, uint32_t delayInMs) +{ + if (timer_num == 0) + { + /* + * setup timer #0 for delay + */ + LPC_CT16B0->TCR = 0x02; /* reset timer */ + LPC_CT16B0->PR = 0x00; /* set prescaler to zero */ + LPC_CT16B0->MR0 = delayInMs * (SystemCoreClock / 1000); + LPC_CT16B0->IR = 0xff; /* reset all interrrupts */ + LPC_CT16B0->MCR = 0x04; /* stop timer on match */ + LPC_CT16B0->TCR = 0x01; /* start timer */ + /* wait until delay time has elapsed */ + while (LPC_CT16B0->TCR & 0x01); + } + else if (timer_num == 1) + { + /* + * setup timer #1 for delay + */ + LPC_CT16B1->TCR = 0x02; /* reset timer */ + LPC_CT16B1->PR = 0x00; /* set prescaler to zero */ + LPC_CT16B1->MR0 = delayInMs * (SystemCoreClock / 1000); + LPC_CT16B1->IR = 0xff; /* reset all interrrupts */ + LPC_CT16B1->MCR = 0x04; /* stop timer on match */ + LPC_CT16B1->TCR = 0x01; /* start timer */ + /* wait until delay time has elapsed */ + while (LPC_CT16B1->TCR & 0x01); + } + return; +} + +/****************************************************************************** +** Function name: TIMER_0_IRQHandler +** +** Descriptions: Timer/CounterX and CaptureX interrupt handler +** +** parameters: None +** Returned value: None +** +******************************************************************************/ +extern "C" void TIMER16_0_IRQHandler(void) +{ + if ( LPC_CT16B0->IR & (0x1<<0) ) + { + LPC_CT16B0->IR = 0x1<<0; /* clear interrupt flag */ + timer16_0_counter[0]++; + } + if ( LPC_CT16B0->IR & (0x1<<1) ) + { + LPC_CT16B0->IR = 0x1<<1; /* clear interrupt flag */ + timer16_0_counter[1]++; + } + if ( LPC_CT16B0->IR & (0x1<<4) ) + { + LPC_CT16B0->IR = 0x1<<4; /* clear interrupt flag */ + timer16_0_capture[0]++; + } + if ( LPC_CT16B0->IR & (0x1<<5) ) + { + LPC_CT16B0->IR = 0x1<<5; /* clear interrupt flag */ + timer16_0_capture[1]++; + } + return; +} + +/****************************************************************************** +** Function name: TIMER_1_IRQHandler +** +** Descriptions: Timer/CounterX and CaptureX interrupt handler +** +** parameters: None +** Returned value: None +** +******************************************************************************/ +extern "C" void TIMER16_1_IRQHandler(void) +{ + if ( LPC_CT16B1->IR & (0x1<<0) ) + { + LPC_CT16B1->IR = 0x1<<0; /* clear interrupt flag */ + timer16_1_counter[0]++; + } + if ( LPC_CT16B1->IR & (0x1<<1) ) + { + LPC_CT16B1->IR = 0x1<<1; /* clear interrupt flag */ + timer16_1_counter[1]++; + } + if ( LPC_CT16B1->IR & (0x1<<4) ) + { + LPC_CT16B1->IR = 0x1<<4; /* clear interrupt flag */ + timer16_1_capture[0]++; + } + if ( LPC_CT16B1->IR & (0x1<<5) ) + { + LPC_CT16B1->IR = 0x1<<5; /* clear interrupt flag */ + timer16_1_capture[1]++; + } + return; +} + +/****************************************************************************** +** Function name: enable_timer +** +** Descriptions: Enable timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void enable_timer16(uint8_t timer_num) +{ + if ( timer_num == 0 ) + { + LPC_CT16B0->TCR = 1; + } + else + { + LPC_CT16B1->TCR = 1; + } + return; +} + +/****************************************************************************** +** Function name: disable_timer +** +** Descriptions: Disable timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void disable_timer16(uint8_t timer_num) +{ + if ( timer_num == 0 ) + { + LPC_CT16B0->TCR = 0; + } + else + { + LPC_CT16B1->TCR = 0; + } + return; +} + +/****************************************************************************** +** Function name: reset_timer +** +** Descriptions: Reset timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void reset_timer16(uint8_t timer_num) +{ + uint32_t regVal; + + if ( timer_num == 0 ) + { + regVal = LPC_CT16B0->TCR; + regVal |= 0x02; + LPC_CT16B0->TCR = regVal; + } + else + { + regVal = LPC_CT16B1->TCR; + regVal |= 0x02; + LPC_CT16B1->TCR = regVal; + } + return; +} + +/****************************************************************************** +** Function name: Set_timer_capture +** +** Descriptions: set timer capture based on LOC number. +** +** parameters: timer number and location number +** Returned value: None +** +******************************************************************************/ +void set_timer16_capture(uint8_t timer_num, uint8_t location ) +{ + if ( timer_num == 0 ) + { + /* Timer0_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO1_16 &= ~0x07; + LPC_IOCON->PIO1_16 |= 0x02; /* Timer0_16 CAP0 */ +// LPC_IOCON->PIO1_17 &= ~0x07; +// LPC_IOCON->PIO1_17 |= 0x01; /* Timer0_16 CAP1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO0_2 &= ~0x07; + LPC_IOCON->PIO0_2 |= 0x02; /* Timer0_16 CAP0 */ + } + else + { + while ( 1 ); /* Fatal location number error */ + } + } + else + { + /* Timer1_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO0_20 &= ~0x07; /* Timer1_16 I/O config */ + LPC_IOCON->PIO0_20 |= 0x01; /* Timer1_16 CAP0 */ +// LPC_IOCON->PIO1_18 &= ~0x07; +// LPC_IOCON->PIO1_18 |= 0x01; /* Timer1_16 CAP1 */ + } + else + { + while ( 1 ); /* Fatal location number error */ + } + } + return; +} + +/****************************************************************************** +** Function name: Set_timer_match +** +** Descriptions: set timer match based on LOC number. +** +** parameters: timer number, match enable, and location number +** Returned value: None +** +******************************************************************************/ +void set_timer16_match(uint8_t timer_num, uint8_t match_enable, uint8_t location) +{ + if ( timer_num == 0 ) + { + if ( match_enable & 0x01 ) + { + /* Timer0_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO0_8 &= ~0x07; + LPC_IOCON->PIO0_8 |= 0x02; /* Timer0_16 MAT0 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_13 &= ~0x07; + LPC_IOCON->PIO1_13 |= 0x02; /* Timer0_16 MAT0 */ + } + } + if ( match_enable & 0x02 ) + { + /* Timer0_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO0_9 &= ~0x07; + LPC_IOCON->PIO0_9 |= 0x02; /* Timer0_16 MAT1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_14 &= ~0x07; + LPC_IOCON->PIO1_14 |= 0x02; /* Timer0_16 MAT1 */ + } + } + if ( match_enable & 0x04 ) + { + /* Timer0_16 I/O config */ + if ( location == 0 ) + { +#ifdef __SWD_DISABLED + LPC_IOCON->SWCLK_PIO0_10 &= ~0x07; + LPC_IOCON->SWCLK_PIO0_10 |= 0x03; /* Timer0_16 MAT2 */ +#endif + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_15 &= ~0x07; + LPC_IOCON->PIO1_15 |= 0x02; /* Timer0_16 MAT0 */ + } + } + } + else if ( timer_num == 1 ) + { + if ( match_enable & 0x01 ) + { + /* Timer1_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO0_21 &= ~0x07; + LPC_IOCON->PIO0_21 |= 0x01; /* Timer1_16 MAT0 */ + } + } + if ( match_enable & 0x02 ) + { + /* Timer1_16 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO0_22 &= ~0x07; + LPC_IOCON->PIO0_22 |= 0x02; /* Timer1_16 MAT1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_23 &= ~0x07; + LPC_IOCON->PIO1_23 |= 0x01; /* Timer1_16 MAT0 */ + } + } + } + return; +} + +/****************************************************************************** +** Function name: init_timer +** +** Descriptions: Initialize timer, set timer interval, reset timer, +** install timer interrupt handler +** +** parameters: timer number and timer interval +** Returned value: None +** +******************************************************************************/ +void init_timer16(uint8_t timer_num, uint32_t TimerInterval) +{ + if ( timer_num == 0 ) + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<7); + + LPC_CT16B0->MR0 = TimerInterval; + LPC_CT16B0->MR1 = TimerInterval; +#if TIMER_MATCH + timer16_0_counter[0] = 0; + timer16_0_counter[1] = 0; + set_timer16_match(timer_num, 0x07, 0); + LPC_CT16B0->EMR &= ~(0xFF<<4); + LPC_CT16B0->EMR |= ((0x3<<4)|(0x3<<6)|(0x3<<8)); +#else + timer16_0_capture[0] = 0; + timer16_0_capture[1] = 0; + set_timer16_capture(timer_num, 0); + /* Capture 0 and 1 on rising edge, interrupt enable. */ + LPC_CT16B0->CCR = (0x5<<0)|(0x5<<3); +#endif + LPC_CT16B0->MCR = (0x3<<0)|(0x3<<3); /* Interrupt and Reset on MR0 and MR1 */ + + /* Enable the TIMER0 Interrupt */ +#if NMI_ENABLED + NVIC_DisableIRQ(TIMER_16_0_IRQn); + NMI_Init( TIMER_16_0_IRQn ); +#else + NVIC_EnableIRQ(TIMER_16_0_IRQn); +#endif + } + else if ( timer_num == 1 ) + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<8); + LPC_CT16B1->MR0 = TimerInterval; + LPC_CT16B1->MR1 = TimerInterval; +#if TIMER_MATCH + timer16_1_counter[0] = 0; + timer16_1_counter[1] = 0; + set_timer16_match(timer_num, 0x07, 0); + LPC_CT16B1->EMR &= ~(0xFF<<4); + LPC_CT16B1->EMR |= ((0x3<<4)|(0x3<<6)|(0x3<<8)); +#else + timer16_1_capture[0] = 0; + timer16_1_capture[1] = 0; + set_timer16_capture(timer_num, 0); + /* Capture 0 and 1 on rising edge, interrupt enable. */ + LPC_CT16B1->CCR = (0x5<<0)|(0x5<<3); +#endif + LPC_CT16B1->MCR = (0x3<<0)|(0x3<<3); /* Interrupt and Reset on MR0 and MR1 */ + + /* Enable the TIMER1 Interrupt */ +#if NMI_ENABLED + NVIC_DisableIRQ(TIMER_16_1_IRQn); + NMI_Init( TIMER_16_1_IRQn ); +#else + NVIC_EnableIRQ(TIMER_16_1_IRQn); +#endif + } + return; +} + +/****************************************************************************** +** Function name: init_timer16PWM +** +** Descriptions: Initialize timer as PWM +** +** parameters: timer number, period and match enable: +** match_enable[0] = PWM for MAT0 +** match_enable[1] = PWM for MAT1 +** match_enable[2] = PWM for MAT2 +** +** Returned value: None +** +******************************************************************************/ +void init_timer16PWM(uint8_t timer_num, uint32_t period, uint8_t match_enable, uint8_t cap_enabled) +{ + disable_timer16(timer_num); + + if (timer_num == 1) + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<8); + + /* Setup the external match register */ + LPC_CT16B1->EMR = (1<<EMC3)|(1<<EMC2)|(1<<EMC1)|(2<<EMC0)|(1<<3)|(match_enable); + + /* Setup the outputs */ + /* If match0 is enabled, set the output */ + set_timer16_match(timer_num, match_enable, 0 ); + + /* Enable the selected PWMs and enable Match3 */ + LPC_CT16B1->PWMC = (1<<3)|(match_enable); + + /* Setup the match registers */ + /* set the period value to a global variable */ + timer16_1_period = period; + LPC_CT16B1->MR3 = timer16_1_period; + LPC_CT16B1->MR0 = timer16_1_period/2; + LPC_CT16B1->MR1 = timer16_1_period/2; + LPC_CT16B1->MR2 = timer16_1_period/2; + + /* Set match control register */ + LPC_CT16B1->MCR = 1<<10;// | 1<<9; /* Reset on MR3 */ + + if (cap_enabled) + { + /* Use location 0 for test. */ + set_timer16_capture( timer_num, 0 ); + LPC_CT16B1->IR = 0xF; /* clear interrupt flag */ + + /* Set the capture control register */ + LPC_CT16B1->CCR = 7; + + } + /* Enable the TIMER1 Interrupt */ + NVIC_EnableIRQ(TIMER_16_1_IRQn); + } + else + { + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<7); + + /* Setup the external match register */ + LPC_CT16B0->EMR = (1<<EMC3)|(1<<EMC2)|(1<<EMC1)|(1<<EMC0)|(1<<3)|(match_enable); + + /* Setup the outputs */ + /* If match0 is enabled, set the output */ + set_timer16_match(timer_num, match_enable, 0 ); + + /* Enable the selected PWMs and enable Match3 */ + LPC_CT16B0->PWMC = (1<<3)|(match_enable); + + /* Setup the match registers */ + /* set the period value to a global variable */ + timer16_0_period = period; + LPC_CT16B0->MR3 = timer16_0_period; + LPC_CT16B0->MR0 = timer16_0_period/2; + LPC_CT16B0->MR1 = timer16_0_period/2; + LPC_CT16B0->MR2 = timer16_0_period/2; + + /* Set the match control register */ + LPC_CT16B0->MCR = 1<<10; /* Reset on MR3 */ + + /* Enable the TIMER1 Interrupt */ + NVIC_EnableIRQ(TIMER_16_0_IRQn); + } +} + +/****************************************************************************** +** Function name: pwm16_setMatch +** +** Descriptions: Set the pwm16 match values +** +** parameters: timer number, match numner and the value +** +** Returned value: None +** +******************************************************************************/ +void setMatch_timer16PWM (uint8_t timer_num, uint8_t match_nr, uint32_t value) +{ + if (timer_num) + { + switch (match_nr) + { + case 0: + LPC_CT16B1->MR0 = value; + break; + case 1: + LPC_CT16B1->MR1 = value; + break; + case 2: + LPC_CT16B1->MR2 = value; + break; + case 3: + LPC_CT16B1->MR3 = value; + break; + default: + break; + } + } + else + { + switch (match_nr) + { + case 0: + LPC_CT16B0->MR0 = value; + break; + case 1: + LPC_CT16B0->MR1 = value; + break; + case 2: + LPC_CT16B0->MR2 = value; + break; + case 3: + LPC_CT16B0->MR3 = value; + break; + default: + break; + } + } +} + +/****************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/timer16.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/timer16.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,59 @@ +/**************************************************************************** + * $Id:: timer16.h 6956 2011-03-23 23:03:25Z usb00423 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains definition and prototype for 16-bit timer + * configuration. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __TIMER16_H +#define __TIMER16_H + +/* The test is either MAT_OUT or CAP_IN. Default is MAT_OUT. */ +#define TIMER_MATCH 0 + + +#define EMC0 4 +#define EMC1 6 +#define EMC2 8 +#define EMC3 10 + +#define MATCH0 (1<<0) +#define MATCH1 (1<<1) +#define MATCH2 (1<<2) +#define MATCH3 (1<<3) + +///* For 16-bit timer, make sure that TIME_INTERVAL should be no +//greater than 0xFFFF. */ +#ifndef TIME_INTERVAL +#define TIME_INTERVAL (SystemCoreClock/1000 - 1) +#endif + +void delayMs(uint8_t timer_num, uint32_t delayInMs); +extern "C" void TIMER16_0_IRQHandler(void); +extern "C" void TIMER16_1_IRQHandler(void); +void enable_timer16(uint8_t timer_num); +void disable_timer16(uint8_t timer_num); +void reset_timer16(uint8_t timer_num); +void set_timer16_capture(uint8_t timer_num, uint8_t location ); +void set_timer16_match(uint8_t timer_num, uint8_t match_enable, uint8_t location); +void init_timer16(uint8_t timer_num, uint32_t timerInterval); +void init_timer16PWM(uint8_t timer_num, uint32_t period, uint8_t match_enable, uint8_t cap_enabled); +void setMatch_timer16PWM (uint8_t timer_num, uint8_t match_nr, uint32_t value); + +#endif /* end __TIMER16_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/timer32.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/timer32.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,649 @@ +/**************************************************************************** + * $Id:: timer32.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11Uxx 32-bit timer example + * + * Description: + * This file contains 32-bit timer code example which include timer + * initialization, timer interrupt handler, and related APIs for + * timer setup. +* +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.h" +#include "timer32.h" +#include "nmi.h" + +volatile uint32_t timer32_0_counter[4] = {0,0,0,0}; +volatile uint32_t timer32_1_counter[4] = {0,0,0,0}; +volatile uint32_t timer32_0_capture[4] = {0,0,0,0}; +volatile uint32_t timer32_1_capture[4] = {0,0,0,0}; +volatile uint32_t timer32_0_period = 0; +volatile uint32_t timer32_1_period = 0; + +/***************************************************************************** +** Function name: delay32Ms +** +** Descriptions: Start the timer delay in milo seconds +** until elapsed +** +** parameters: timer number, Delay value in milo second +** +** Returned value: None +** +*****************************************************************************/ +void delay32Ms(uint8_t timer_num, uint32_t delayInMs) +{ + if (timer_num == 0) + { + /* setup timer #0 for delay */ + LPC_CT32B0->TCR = 0x02; /* reset timer */ + LPC_CT32B0->PR = 0x00; /* set prescaler to zero */ + LPC_CT32B0->MR0 = delayInMs * (SystemCoreClock / 1000); + LPC_CT32B0->IR = 0xff; /* reset all interrrupts */ + LPC_CT32B0->MCR = 0x04; /* stop timer on match */ + LPC_CT32B0->TCR = 0x01; /* start timer */ + + /* wait until delay time has elapsed */ + while (LPC_CT32B0->TCR & 0x01); + } + else if (timer_num == 1) + { + /* setup timer #1 for delay */ + LPC_CT32B1->TCR = 0x02; /* reset timer */ + LPC_CT32B1->PR = 0x00; /* set prescaler to zero */ + LPC_CT32B1->MR0 = delayInMs * (SystemCoreClock / 1000); + LPC_CT32B1->IR = 0xff; /* reset all interrrupts */ + LPC_CT32B1->MCR = 0x04; /* stop timer on match */ + LPC_CT32B1->TCR = 0x01; /* start timer */ + + /* wait until delay time has elapsed */ + while (LPC_CT32B1->TCR & 0x01); + } + return; +} + +/****************************************************************************** +** Function name: TIMER32_0_IRQHandler +** +** Descriptions: Timer/CounterX and captureX interrupt handler +** +** parameters: None +** Returned value: None +** +******************************************************************************/ +void TIMER32_0_IRQHandler(void) +{ + if ( LPC_CT32B0->IR & (0x01<<0) ) + { + LPC_CT32B0->IR = 0x1<<0; /* clear interrupt flag */ + timer32_0_counter[0]++; + } + if ( LPC_CT32B0->IR & (0x01<<1) ) + { + LPC_CT32B0->IR = 0x1<<1; /* clear interrupt flag */ + timer32_0_counter[1]++; + } + if ( LPC_CT32B0->IR & (0x01<<2) ) + { + LPC_CT32B0->IR = 0x1<<2; /* clear interrupt flag */ + timer32_0_counter[2]++; + } + if ( LPC_CT32B0->IR & (0x01<<3) ) + { + LPC_CT32B0->IR = 0x1<<3; /* clear interrupt flag */ + timer32_0_counter[3]++; + } + if ( LPC_CT32B0->IR & (0x1<<4) ) + { + LPC_CT32B0->IR = 0x1<<4; /* clear interrupt flag */ + timer32_0_capture[0]++; + } + if ( LPC_CT32B0->IR & (0x1<<5) ) + { + LPC_CT32B0->IR = 0x1<<5; /* clear interrupt flag */ + timer32_0_capture[1]++; + } + if ( LPC_CT32B0->IR & (0x1<<6) ) + { + LPC_CT32B0->IR = 0x1<<6; /* clear interrupt flag */ + timer32_0_capture[2]++; + } + if ( LPC_CT32B0->IR & (0x1<<7) ) + { + LPC_CT32B0->IR = 0x1<<7; /* clear interrupt flag */ + timer32_0_capture[3]++; + } + return; +} + +/****************************************************************************** +** Function name: TIMER32_1_IRQHandler +** +** Descriptions: Timer/CounterX and captureX interrupt handler +** +** parameters: None +** Returned value: None +** +******************************************************************************/ +void TIMER32_1_IRQHandler(void) +{ + if ( LPC_CT32B1->IR & (0x01<<0) ) + { + LPC_CT32B1->IR = 0x1<<0; /* clear interrupt flag */ + timer32_1_counter[0]++; + } + if ( LPC_CT32B1->IR & (0x01<<1) ) + { + LPC_CT32B1->IR = 0x1<<1; /* clear interrupt flag */ + timer32_1_counter[1]++; + } + if ( LPC_CT32B1->IR & (0x01<<2) ) + { + LPC_CT32B1->IR = 0x1<<2; /* clear interrupt flag */ + timer32_1_counter[2]++; + } + if ( LPC_CT32B1->IR & (0x01<<3) ) + { + LPC_CT32B1->IR = 0x1<<3; /* clear interrupt flag */ + timer32_1_counter[3]++; + } + if ( LPC_CT32B1->IR & (0x1<<4) ) + { + LPC_CT32B1->IR = 0x1<<4; /* clear interrupt flag */ + timer32_1_capture[0]++; + } + if ( LPC_CT32B1->IR & (0x1<<5) ) + { + LPC_CT32B1->IR = 0x1<<5; /* clear interrupt flag */ + timer32_1_capture[1]++; + } + if ( LPC_CT32B1->IR & (0x1<<6) ) + { + LPC_CT32B1->IR = 0x1<<6; /* clear interrupt flag */ + timer32_1_capture[2]++; + } + if ( LPC_CT32B1->IR & (0x1<<7) ) + { + LPC_CT32B1->IR = 0x1<<7; /* clear interrupt flag */ + timer32_1_capture[3]++; + } + return; +} + +/****************************************************************************** +** Function name: enable_timer +** +** Descriptions: Enable timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void enable_timer32(uint8_t timer_num) +{ + if ( timer_num == 0 ) + { + LPC_CT32B0->TCR = 1; + } + else + { + LPC_CT32B1->TCR = 1; + } + return; +} + +/****************************************************************************** +** Function name: disable_timer +** +** Descriptions: Disable timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void disable_timer32(uint8_t timer_num) +{ + if ( timer_num == 0 ) + { + LPC_CT32B0->TCR = 0; + } + else + { + LPC_CT32B1->TCR = 0; + } + return; +} + +/****************************************************************************** +** Function name: reset_timer +** +** Descriptions: Reset timer +** +** parameters: timer number: 0 or 1 +** Returned value: None +** +******************************************************************************/ +void reset_timer32(uint8_t timer_num) +{ + uint32_t regVal; + + if ( timer_num == 0 ) + { + regVal = LPC_CT32B0->TCR; + regVal |= 0x02; + LPC_CT32B0->TCR = regVal; + } + else + { + regVal = LPC_CT32B1->TCR; + regVal |= 0x02; + LPC_CT32B1->TCR = regVal; + } + return; +} + +/****************************************************************************** +** Function name: set_timer_capture +** +** Descriptions: Set timer capture based on location +** +** parameters: timer number: 0~1, location 0~2 +** Returned value: None +** +******************************************************************************/ +void set_timer32_capture(uint8_t timer_num, uint8_t location ) +{ + if ( timer_num == 0 ) + { + /* Timer0_32 I/O config */ + if ( location == 0 ) + { + LPC_IOCON->PIO1_28 &= ~0x07; + LPC_IOCON->PIO1_28 |= 0x01; /* Timer0_32 CAP0 */ + LPC_IOCON->PIO1_29 &= ~0x07; + LPC_IOCON->PIO1_29 |= 0x02; /* Timer0_32 CAP1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO0_17 &= ~0x07; + LPC_IOCON->PIO0_17 |= 0x02; /* Timer0_32 CAP0 */ + } + else + { + while ( 1 ); /* Fatal location number error */ + } + } + else + { + /* Timer1_32 I/O config */ + if ( location == 0 ) + { +// LPC_IOCON->PIO1_4 &= ~0x07; /* Timer1_32 I/O config */ +// LPC_IOCON->PIO1_4 |= 0x01; /* Timer1_32 CAP0 */ +// LPC_IOCON->PIO1_5 &= ~0x07; +// LPC_IOCON->PIO1_5 |= 0x01; /* Timer1_32 CAP1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->TMS_PIO0_12 &= ~0x07; + LPC_IOCON->TMS_PIO0_12 |= 0x03; /* Timer1_32 CAP0 */ + } + else + { + while ( 1 ); /* Fatal location number error */ + } + } + return; +} + +/****************************************************************************** +** Function name: set_timer_match +** +** Descriptions: Set timer match based on location +** +** parameters: timer number: 0~1, location 0~2 +** Returned value: None +** +******************************************************************************/ +void set_timer32_match(uint8_t timer_num, uint8_t match_enable, uint8_t location) +{ + if ( timer_num == 0 ) + { + if ( match_enable & 0x01 ) + { + if ( location == 0 ) + { + LPC_IOCON->PIO0_18 &= ~0x07; + LPC_IOCON->PIO0_18 |= 0x02; /* Timer0_32 MAT0 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_24 &= ~0x07; + LPC_IOCON->PIO1_24 |= 0x01; /* Timer0_32 MAT0 */ + } + } + if ( match_enable & 0x02 ) + { + if ( location == 0 ) + { + LPC_IOCON->PIO0_19 &= ~0x07; + LPC_IOCON->PIO0_19 |= 0x02; /* Timer0_32 MAT1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_25 &= ~0x07; + LPC_IOCON->PIO1_25 |= 0x01; /* Timer0_32 MAT1 */ + } + } + if ( match_enable & 0x04 ) + { + if ( location == 0 ) + { + LPC_IOCON->PIO0_1 &= ~0x07; + LPC_IOCON->PIO0_1 |= 0x02; /* Timer0_32 MAT2 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_26 &= ~0x07; + LPC_IOCON->PIO1_26 |= 0x01; /* Timer0_32 MAT2 */ + } + } + if ( match_enable & 0x08 ) + { + if ( location == 0 ) + { + LPC_IOCON->TDI_PIO0_11 &= ~0x07; + LPC_IOCON->TDI_PIO0_11 |= 0x03; /* Timer0_32 MAT3 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO1_27 &= ~0x07; + LPC_IOCON->PIO1_27 |= 0x01; /* Timer0_32 MAT3 */ + } + } + } + else if ( timer_num == 1 ) + { + if ( match_enable & 0x01 ) + { + if ( location == 0 ) + { +// LPC_IOCON->PIO1_0 &= ~0x07; +// LPC_IOCON->PIO1_0 |= 0x01; /* Timer1_32 MAT0 */ + } + else if ( location == 1 ) + { + LPC_IOCON->TDO_PIO0_13 &= ~0x07; + LPC_IOCON->TDO_PIO0_13 |= 0x03; /* Timer1_32 MAT0 */ + } + } + if ( match_enable & 0x02 ) + { + if ( location == 0 ) + { +// LPC_IOCON->PIO1_1 &= ~0x07; +// LPC_IOCON->PIO1_1 |= 0x01; /* Timer1_32 MAT1 */ + } + else if ( location == 1 ) + { + LPC_IOCON->TRST_PIO0_14 &= ~0x07; + LPC_IOCON->TRST_PIO0_14 |= 0x03; /* Timer1_32 MAT1 */ + } + } + if ( match_enable & 0x04 ) + { + if ( location == 0 ) + { +// LPC_IOCON->PIO1_2 &= ~0x07; +// LPC_IOCON->PIO1_2 |= 0x01; /* Timer1_32 MAT2 */ + } + else if ( location == 1 ) + { +#if __SWD_DISABLED + LPC_IOCON->SWDIO_PIO0_15 &= ~0x07; + LPC_IOCON->SWDIO_PIO0_15 |= 0x03; /* Timer1_32 MAT2 */ +#endif + } + } + if ( match_enable & 0x08 ) + { + if ( location == 0 ) + { +// LPC_IOCON->PIO1_3 &= ~0x07; +// LPC_IOCON->PIO1_3 |= 0x01; /* Timer1_32 MAT3 */ + } + else if ( location == 1 ) + { + LPC_IOCON->PIO0_16 &= ~0x07; + LPC_IOCON->PIO0_16 |= 0x02; /* Timer1_32 MAT3 */ + } + } + } + return; +} + +/****************************************************************************** +** Function name: init_timer +** +** Descriptions: Initialize timer, set timer interval, reset timer, +** install timer interrupt handler +** +** parameters: timer number and timer interval +** Returned value: None +** +******************************************************************************/ +void init_timer32(uint8_t timer_num, uint32_t TimerInterval) +{ + uint32_t i; + + if ( timer_num == 0 ) + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<9); + + LPC_CT32B0->MR0 = TimerInterval; +#if TIMER_MATCH + for ( i = 0; i < 4; i++ ) + { + timer32_0_counter[i] = 0; + } + set_timer32_match(timer_num, 0x0F, 0); + LPC_CT32B0->EMR &= ~(0xFF<<4); + LPC_CT32B0->EMR |= ((0x3<<4)|(0x3<<6)|(0x3<<8)|(0x3<<10)); /* MR0/1/2/3 Toggle */ +#else + for ( i = 0; i < 4; i++ ) + { + timer32_0_capture[i] = 0; + } + set_timer32_capture(timer_num, 0 ); + /* Capture 0 on rising edge, interrupt enable. */ + LPC_CT32B0->CCR = (0x5<<0)|(0x5<<3); +#endif + LPC_CT32B0->MCR = 3; /* Interrupt and Reset on MR0 */ + + /* Enable the TIMER0 Interrupt */ +#if NMI_ENABLED + NVIC_DisableIRQ( TIMER_32_0_IRQn ); + NMI_Init( TIMER_32_0_IRQn ); +#else + NVIC_EnableIRQ(TIMER_32_0_IRQn); +#endif + } + else if ( timer_num == 1 ) + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<10); + + LPC_CT32B1->MR0 = TimerInterval; +#if TIMER_MATCH + for ( i = 0; i < 4; i++ ) + { + timer32_1_counter[i] = 0; + } + set_timer32_match(timer_num, 0x0F, 0); + LPC_CT32B1->EMR &= ~(0xFF<<4); + LPC_CT32B1->EMR |= ((0x3<<4)|(0x3<<6)|(0x3<<8)|(0x3<<10)); /* MR0/1/2 Toggle */ +#else + for ( i = 0; i < 4; i++ ) + { + timer32_1_capture[i] = 0; + } + set_timer32_capture(timer_num, 0 ); + /* Capture 0 on rising edge, interrupt enable. */ + LPC_CT32B1->CCR = (0x5<<0)|(0x5<<3); +#endif + LPC_CT32B1->MCR = 3; /* Interrupt and Reset on MR0 */ + + /* Enable the TIMER1 Interrupt */ +#if NMI_ENABLED + NVIC_DisableIRQ( TIMER_32_1_IRQn ); + NMI_Init( TIMER_32_1_IRQn ); +#else + NVIC_EnableIRQ(TIMER_32_1_IRQn); +#endif + } + return; +} +/****************************************************************************** +** Function name: init_timer32PWM +** +** Descriptions: Initialize timer as PWM +** +** parameters: timer number, period and match enable: +** match_enable[0] = PWM for MAT0 +** match_enable[1] = PWM for MAT1 +** match_enable[2] = PWM for MAT2 +** Returned value: None +** +******************************************************************************/ +void init_timer32PWM(uint8_t timer_num, uint32_t period, uint8_t match_enable) +{ + disable_timer32(timer_num); + if (timer_num == 1) + { + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<10); + + /* Setup the external match register */ + LPC_CT32B1->EMR = (1<<EMC3)|(1<<EMC2)|(2<<EMC1)|(1<<EMC0)|MATCH3|(match_enable); + + /* Setup the outputs */ + /* If match0 is enabled, set the output, use location 0 for test. */ + set_timer32_match( timer_num, match_enable, 0 ); + + /* Enable the selected PWMs and enable Match3 */ + LPC_CT32B1->PWMC = MATCH3|(match_enable); + + /* Setup the match registers */ + /* set the period value to a global variable */ + timer32_1_period = period; + LPC_CT32B1->MR3 = timer32_1_period; + LPC_CT32B1->MR0 = timer32_1_period/2; + LPC_CT32B1->MR1 = timer32_1_period/2; + LPC_CT32B1->MR2 = timer32_1_period/2; + LPC_CT32B1->MCR = 1<<10; /* Reset on MR3 */ + } + else + { + /* Some of the I/O pins need to be clearfully planned if + you use below module because JTAG and TIMER CAP/MAT pins are muxed. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<9); + + /* Setup the external match register */ + LPC_CT32B0->EMR = (1<<EMC3)|(2<<EMC2)|(1<<EMC1)|(1<<EMC0)|MATCH3|(match_enable); + + /* Setup the outputs */ + /* If match0 is enabled, set the output, use location 0 for test. */ + set_timer32_match( timer_num, match_enable, 0 ); + + /* Enable the selected PWMs and enable Match3 */ + LPC_CT32B0->PWMC = MATCH3|(match_enable); + + /* Setup the match registers */ + /* set the period value to a global variable */ + timer32_0_period = period; + LPC_CT32B0->MR3 = timer32_0_period; + LPC_CT32B0->MR0 = timer32_0_period/2; + LPC_CT32B0->MR1 = timer32_0_period/2; + LPC_CT32B0->MR2 = timer32_0_period/2; + LPC_CT32B0->MCR = 1<<10; /* Reset on MR3 */ + } +} + +/****************************************************************************** +** Function name: pwm32_setMatch +** +** Descriptions: Set the pwm32 match values +** +** parameters: timer number, match numner and the value +** +** Returned value: None +** +******************************************************************************/ +void setMatch_timer32PWM (uint8_t timer_num, uint8_t match_nr, uint32_t value) +{ + if (timer_num) + { + switch (match_nr) + { + case 0: + LPC_CT32B1->MR0 = value; + break; + case 1: + LPC_CT32B1->MR1 = value; + break; + case 2: + LPC_CT32B1->MR2 = value; + break; + case 3: + LPC_CT32B1->MR3 = value; + break; + default: + break; + } + } + else + { + switch (match_nr) + { + case 0: + LPC_CT32B0->MR0 = value; + break; + case 1: + LPC_CT32B0->MR1 = value; + break; + case 2: + LPC_CT32B0->MR2 = value; + break; + case 3: + LPC_CT32B0->MR3 = value; + break; + default: + break; + } + } +} + +/****************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/timer32.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/timer32.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,58 @@ +/**************************************************************************** + * $Id:: timer32.h 7146 2011-04-19 19:48:01Z nxp28548 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains definition and prototype for 32-bit timer + * configuration. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __TIMER32_H +#define __TIMER32_H + +/* The test is either MAT_OUT or CAP_IN. Default is CAP_IN. */ +#ifndef TIMER_MATCH +#define TIMER_MATCH 0 +#endif//TIMER_MATCH + +#define EMC0 4 +#define EMC1 6 +#define EMC2 8 +#define EMC3 10 + +#define MATCH0 (1<<0) +#define MATCH1 (1<<1) +#define MATCH2 (1<<2) +#define MATCH3 (1<<3) + +#ifndef TIME_INTERVAL +#define TIME_INTERVAL (SystemCoreClock/100 - 1) +#endif + +void delay32Ms(uint8_t timer_num, uint32_t delayInMs); +void TIMER32_0_IRQHandler(void); +void TIMER32_1_IRQHandler(void); +void enable_timer32(uint8_t timer_num); +void disable_timer32(uint8_t timer_num); +void reset_timer32(uint8_t timer_num); +void set_timer32_capture(uint8_t timer_num, uint8_t location ); +void set_timer32_match(uint8_t timer_num, uint8_t match_enable, uint8_t location); +void init_timer32(uint8_t timer_num, uint32_t timerInterval); +void init_timer32PWM(uint8_t timer_num, uint32_t period, uint8_t match_enable); +void setMatch_timer32PWM (uint8_t timer_num, uint8_t match_nr, uint32_t value); + +#endif /* end __TIMER32_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/type.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/type.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,47 @@ +/**************************************************************************** + * $Id:: type.h 6172 2011-01-13 18:22:51Z usb00423 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains different type definition. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __TYPE_H__ +#define __TYPE_H__ + +/* exact-width signed integer types */ +typedef signed char int8_t; +typedef signed short int int16_t; +typedef signed int int32_t; +typedef signed __int64 int64_t; + + /* exact-width unsigned integer types */ +typedef unsigned char uint8_t; +typedef unsigned short int uint16_t; +typedef unsigned int uint32_t; +typedef unsigned __int64 uint64_t; + +#ifndef NULL +#define NULL ((void *)0) +#endif + +#ifndef FALSE +#define FALSE (0) +#endif + +#ifndef TRUE +#define TRUE (1) +#endif + +#endif /* __TYPE_H__ */
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/uart.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/uart.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,440 @@ +/**************************************************************************** + * $Id:: uart.c 9188 2012-02-16 20:53:43Z nxp41306 $ + * Project: NXP LPC11Uxx UART example + * + * Description: + * This file contains UART code example which include UART + * initialization, UART interrupt handler, and related APIs for + * UART access. + * +**************************************************************************** +* 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. + +****************************************************************************/ + +#include "LPC11Uxx.h" +#include "type.h" +#include "uart.h" + +volatile uint32_t UARTStatus; +volatile uint8_t UARTTxEmpty = 1; +volatile uint8_t UARTBuffer[BUFSIZE]; +volatile uint32_t UARTCount = 0; + +#if AUTOBAUD_ENABLE +volatile uint32_t UARTAutoBaud = 0, AutoBaudTimeout = 0; +#endif + +/***************************************************************************** +** Function name: UART_IRQHandler +** +** Descriptions: UART interrupt handler +** +** parameters: None +** Returned value: None +** +*****************************************************************************/ +void UART_IRQHandler(void) +{ + uint8_t IIRValue, LSRValue; + uint8_t Dummy = Dummy; + + IIRValue = LPC_USART->IIR; + + IIRValue >>= 1; /* skip pending bit in IIR */ + IIRValue &= 0x07; /* check bit 1~3, interrupt identification */ + if (IIRValue == IIR_RLS) /* Receive Line Status */ + { + LSRValue = LPC_USART->LSR; + /* Receive Line Status */ + if (LSRValue & (LSR_OE | LSR_PE | LSR_FE | LSR_RXFE | LSR_BI)) + { + /* There are errors or break interrupt */ + /* Read LSR will clear the interrupt */ + UARTStatus = LSRValue; + Dummy = LPC_USART->RBR; /* Dummy read on RX to clear + interrupt, then bail out */ + return; + } + if (LSRValue & LSR_RDR) /* Receive Data Ready */ + { + /* If no error on RLS, normal ready, save into the data buffer. */ + /* Note: read RBR will clear the interrupt */ + UARTBuffer[UARTCount++] = LPC_USART->RBR; + if (UARTCount == BUFSIZE) + { + UARTCount = 0; /* buffer overflow */ + } + } + } + else if (IIRValue == IIR_RDA) /* Receive Data Available */ + { + /* Receive Data Available */ + UARTBuffer[UARTCount++] = LPC_USART->RBR; + if (UARTCount == BUFSIZE) + { + UARTCount = 0; /* buffer overflow */ + } + } + else if (IIRValue == IIR_CTI) /* Character timeout indicator */ + { + /* Character Time-out indicator */ + UARTStatus |= 0x100; /* Bit 9 as the CTI error */ + } + else if (IIRValue == IIR_THRE) /* THRE, transmit holding register empty */ + { + /* THRE interrupt */ + LSRValue = LPC_USART->LSR; /* Check status in the LSR to see if + valid data in U0THR or not */ + if (LSRValue & LSR_THRE) + { + UARTTxEmpty = 1; + } + else + { + UARTTxEmpty = 0; + } + } +#if AUTOBAUD_ENABLE + if (LPC_USART->IIR & IIR_ABEO) /* End of Auto baud */ + { + LPC_USART->IER &= ~IIR_ABEO; + /* clear bit ABEOInt in the IIR by set ABEOIntClr in the ACR register */ + LPC_USART->ACR |= IIR_ABEO; + UARTAutoBaud = 1; + } + else if (LPC_USART->IIR & IIR_ABTO)/* Auto baud time out */ + { + LPC_USART->IER &= ~IIR_ABTO; + AutoBaudTimeout = 1; + /* clear bit ABTOInt in the IIR by set ABTOIntClr in the ACR register */ + LPC_USART->ACR |= IIR_ABTO; + } +#endif + return; +} + +#if MODEM_TEST +/***************************************************************************** +** Function name: ModemInit +** +** Descriptions: Initialize UART0 port as modem, setup pin select. +** +** parameters: None +** Returned value: None +** +*****************************************************************************/ +void ModemInit( void ) +{ + + LPC_IOCON->PIO0_7 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO0_7 |= 0x01; /* UART CTS */ + LPC_IOCON->PIO0_17 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO0_17 |= 0x01; /* UART RTS */ +#if 1 + LPC_IOCON->PIO1_13 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_13 |= 0x01; /* UART DTR */ + LPC_IOCON->PIO1_14 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_14 |= 0x01; /* UART DSR */ + LPC_IOCON->PIO1_15 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_15 |= 0x01; /* UART DCD */ + LPC_IOCON->PIO1_16 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_16 |= 0x01; /* UART RI */ + +#else + LPC_IOCON->PIO1_19 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_19 |= 0x01; /* UART DTR */ + LPC_IOCON->PIO1_20 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_20 |= 0x01; /* UART DSR */ + LPC_IOCON->PIO1_21 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_21 |= 0x01; /* UART DCD */ + LPC_IOCON->PIO1_22 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_22 |= 0x01; /* UART RI */ +#endif + LPC_USART->MCR = 0xC0; /* Enable Auto RTS and Auto CTS. */ + return; +} +#endif + +/*********************************************************************** + * + * Function: uart_set_divisors + * + * Purpose: Determines best dividers to get a target clock rate + * + * Processing: + * See function. + * + * Parameters: + * UARTClk : UART clock + * baudrate : Desired UART baud rate + * + * Outputs: + * baudrate : Sets the estimated buadrate value in DLL, DLM, and FDR. + * + * Returns: Error status. + * + * Notes: None + * + **********************************************************************/ +uint32_t uart_set_divisors(uint32_t UARTClk, uint32_t baudrate) +{ + uint32_t uClk; + uint32_t calcBaudrate = 0; + uint32_t temp = 0; + + uint32_t mulFracDiv, dividerAddFracDiv; + uint32_t diviser = 0 ; + uint32_t mulFracDivOptimal = 1; + uint32_t dividerAddOptimal = 0; + uint32_t diviserOptimal = 0; + + uint32_t relativeError = 0; + uint32_t relativeOptimalError = 100000; + + /* get UART block clock */ + uClk = UARTClk >> 4; /* div by 16 */ + /* In the Uart IP block, baud rate is calculated using FDR and DLL-DLM registers + * The formula is : + * BaudRate= uClk * (mulFracDiv/(mulFracDiv+dividerAddFracDiv) / (16 * (DLL) + * It involves floating point calculations. That's the reason the formulae are adjusted with + * Multiply and divide method.*/ + /* The value of mulFracDiv and dividerAddFracDiv should comply to the following expressions: + * 0 < mulFracDiv <= 15, 0 <= dividerAddFracDiv <= 15 */ + for (mulFracDiv = 1; mulFracDiv <= 15; mulFracDiv++) + { + for (dividerAddFracDiv = 0; dividerAddFracDiv <= 15; dividerAddFracDiv++) + { + temp = (mulFracDiv * uClk) / ((mulFracDiv + dividerAddFracDiv)); + diviser = temp / baudrate; + if ((temp % baudrate) > (baudrate / 2)) + diviser++; + + if (diviser > 2 && diviser < 65536) + { + calcBaudrate = temp / diviser; + + if (calcBaudrate <= baudrate) + relativeError = baudrate - calcBaudrate; + else + relativeError = calcBaudrate - baudrate; + + if ((relativeError < relativeOptimalError)) + { + mulFracDivOptimal = mulFracDiv ; + dividerAddOptimal = dividerAddFracDiv; + diviserOptimal = diviser; + relativeOptimalError = relativeError; + if (relativeError == 0) + break; + } + } /* End of if */ + } /* end of inner for loop */ + if (relativeError == 0) + break; + } /* end of outer for loop */ + + if (relativeOptimalError < (baudrate / 30)) + { + /* Set the `Divisor Latch Access Bit` and enable so the DLL/DLM access*/ + /* Initialise the `Divisor latch LSB` and `Divisor latch MSB` registers */ + LPC_USART->DLM = (diviserOptimal >> 8) & 0xFF; + LPC_USART->DLL = diviserOptimal & 0xFF; + + /* Initialise the Fractional Divider Register */ + LPC_USART->FDR = ((mulFracDivOptimal & 0xF) << 4) | (dividerAddOptimal & 0xF); + return( TRUE ); + } + return ( FALSE ); +} + +/***************************************************************************** +** Function name: UARTInit +** +** Descriptions: Initialize UART0 port, setup pin select, +** clock, parity, stop bits, FIFO, etc. +** +** parameters: UART baudrate +** Returned value: None +** +*****************************************************************************/ +void UARTInit(uint32_t baudrate) +{ +#if !AUTOBAUD_ENABLE + uint32_t Fdiv; +#endif + volatile uint32_t regVal; + + UARTTxEmpty = 1; + UARTCount = 0; + + NVIC_DisableIRQ(UART_IRQn); + /* Select only one location from below. */ +#if 1 + LPC_IOCON->PIO0_18 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO0_18 |= 0x01; /* UART RXD */ + LPC_IOCON->PIO0_19 &= ~0x07; + LPC_IOCON->PIO0_19 |= 0x01; /* UART TXD */ +#endif +#if 0 + LPC_IOCON->PIO1_14 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_14 |= 0x03; /* UART RXD */ + LPC_IOCON->PIO1_13 &= ~0x07; + LPC_IOCON->PIO1_13 |= 0x03; /* UART TXD */ +#endif +#if 0 + LPC_IOCON->PIO1_17 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_17 |= 0x02; /* UART RXD */ + LPC_IOCON->PIO1_18 &= ~0x07; + LPC_IOCON->PIO1_18 |= 0x02; /* UART TXD */ +#endif +#if 0 + LPC_IOCON->PIO1_26 &= ~0x07; /* UART I/O config */ + LPC_IOCON->PIO1_26 |= 0x02; /* UART RXD */ + LPC_IOCON->PIO1_27 &= ~0x07; + LPC_IOCON->PIO1_27 |= 0x02; /* UART TXD */ +#endif + + /* Enable UART clock */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<12); + LPC_SYSCON->UARTCLKDIV = 0x1; /* divided by 1 */ + + LPC_USART->LCR = 0x83; /* 8 bits, no Parity, 1 Stop bit */ +#if !AUTOBAUD_ENABLE +#if FDR_CALIBRATION + if ( uart_set_divisors(SystemCoreClock/LPC_SYSCON->UARTCLKDIV, baudrate) != TRUE ) + { + Fdiv = ((SystemCoreClock/LPC_SYSCON->UARTCLKDIV)/16)/baudrate ; /*baud rate */ + LPC_USART->DLM = Fdiv / 256; + LPC_USART->DLL = Fdiv % 256; + LPC_USART->FDR = 0x10; /* Default */ + } +#else + Fdiv = ((SystemCoreClock/LPC_SYSCON->UARTCLKDIV)/16)/baudrate ; /*baud rate */ + LPC_USART->DLM = Fdiv / 256; + LPC_USART->DLL = Fdiv % 256; + LPC_USART->FDR = 0x10; /* Default */ +#endif +#endif + LPC_USART->LCR = 0x03; /* DLAB = 0 */ + LPC_USART->FCR = 0x07; /* Enable and reset TX and RX FIFO. */ + + /* Read to clear the line status. */ + regVal = LPC_USART->LSR; + + /* Ensure a clean start, no data in either TX or RX FIFO. */ + while (( LPC_USART->LSR & (LSR_THRE|LSR_TEMT)) != (LSR_THRE|LSR_TEMT) ); + while ( LPC_USART->LSR & LSR_RDR ) + { + regVal = LPC_USART->RBR; /* Dump data from RX FIFO */ + } + + /* Enable the UART Interrupt */ + NVIC_EnableIRQ(UART_IRQn); + +#if TX_INTERRUPT + LPC_USART->IER = IER_RBR | IER_THRE | IER_RLS; /* Enable UART interrupt */ +#else + LPC_USART->IER = IER_RBR | IER_RLS; /* Enable UART interrupt */ +#endif +#if AUTOBAUD_ENABLE + LPC_USART->IER |= IER_ABEO | IER_ABTO; +#endif + return; +} + +/***************************************************************************** +** Function name: UARTSend +** +** Descriptions: Send a block of data to the UART 0 port based +** on the data length +** +** parameters: buffer pointer, and data length +** Returned value: None +** +*****************************************************************************/ +void UARTSend(uint8_t *BufferPtr, uint32_t Length) +{ + + while ( Length != 0 ) + { + /* THRE status, contain valid data */ +#if !TX_INTERRUPT + while ( !(LPC_USART->LSR & LSR_THRE) ); + LPC_USART->THR = *BufferPtr; +#else + /* Below flag is set inside the interrupt handler when THRE occurs. */ + while ( !(UARTTxEmpty & 0x01) ); + LPC_USART->THR = *BufferPtr; + UARTTxEmpty = 0; /* not empty in the THR until it shifts out */ +#endif + BufferPtr++; + Length--; + } + return; +} + +/***************************************************************************** +** Function name: print_string +** +** Descriptions: print out string on the terminal +** +** parameters: pointer to the string end with NULL char. +** Returned value: none. +** +*****************************************************************************/ +void print_string( uint8_t *str_ptr ) +{ + while(*str_ptr != 0x00) + { + while((LPC_USART->LSR & 0x60) != 0x60); + LPC_USART->THR = *str_ptr; + str_ptr++; + } + return; +} + +/***************************************************************************** +** Function name: get_key +** +** Descriptions: Get a character from the terminal +** +** parameters: None +** Returned value: character, zero is none. +** +*****************************************************************************/ +uint8_t get_key( void ) +{ + uint8_t dummy; + + while ( !(LPC_USART->LSR & 0x01) ); + dummy = LPC_USART->RBR; + if ((dummy>=65) && (dummy<=90)) + { + /* convert capital to non-capital character, A2a, B2b, C2c. */ + dummy +=32; + } + /* echo */ + LPC_USART->THR = dummy; + return(dummy); +} + +/****************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/uart.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/uart.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,72 @@ +/**************************************************************************** + * $Id:: uart.h 9155 2012-02-14 23:23:34Z nxp41306 $ + * Project: NXP LPC11Uxx software example + * + * Description: + * This file contains definition and prototype for UART configuration. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __UART_H +#define __UART_H + +#define AUTOBAUD_ENABLE 0 +#define FDR_CALIBRATION 0 +#define RS485_ENABLED 0 +#define TX_INTERRUPT 0 /* 0 if TX uses polling, 1 interrupt driven. */ +#define MODEM_TEST 0 + +#define IER_RBR (0x01<<0) +#define IER_THRE (0x01<<1) +#define IER_RLS (0x01<<2) +#define IER_ABEO (0x01<<8) +#define IER_ABTO (0x01<<9) + +#define IIR_PEND 0x01 +#define IIR_RLS 0x03 +#define IIR_RDA 0x02 +#define IIR_CTI 0x06 +#define IIR_THRE 0x01 +#define IIR_ABEO (0x01<<8) +#define IIR_ABTO (0x01<<9) + +#define LSR_RDR (0x01<<0) +#define LSR_OE (0x01<<1) +#define LSR_PE (0x01<<2) +#define LSR_FE (0x01<<3) +#define LSR_BI (0x01<<4) +#define LSR_THRE (0x01<<5) +#define LSR_TEMT (0x01<<6) +#define LSR_RXFE (0x01<<7) + +#define BUFSIZE 0x40 + +/* RS485 mode definition. */ +#define RS485_NMMEN (0x1<<0) +#define RS485_RXDIS (0x1<<1) +#define RS485_AADEN (0x1<<2) +#define RS485_SEL (0x1<<3) +#define RS485_DCTRL (0x1<<4) +#define RS485_OINV (0x1<<5) + +void ModemInit( void ); +void UARTInit(uint32_t Baudrate); +void UART_IRQHandler(void); +void UARTSend(uint8_t *BufferPtr, uint32_t Length); +void print_string( uint8_t *str_ptr ); +uint8_t get_key( void ); + +#endif /* end __UART_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 KEIL_LPC11U_COMMON_LIB/usart.h --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/KEIL_LPC11U_COMMON_LIB/usart.h Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,44 @@ +/**************************************************************************** + * $Id:: usart.h 6172 2011-01-13 18:22:51Z usb00423 $ + * Project: NXP LPC11xx software example + * + * Description: + * This file contains definition and prototype for UART configuration. + * + **************************************************************************** + * 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. +****************************************************************************/ +#ifndef __USART_H +#define __USART_H + +/* Synchronous mode control register definition. */ +#define SYNC_ON (0x1<<0) +#define SYNC_OFF (0x0<<0) + +#define SYNC_MASTER (0x1<<1) +#define SYNC_SLAVE (0x0<<1) + +#define SYNC_RE (0x0<<2) +#define SYNC_FE (0x1<<2) + +#define SYNC_CONT_CLK_EN (0x1<<4) +#define SYNC_CONT_CLK_DIS (0x0<<4) + +#define SYNC_STARTSTOPOFF (0x1<<5) +#define SYNC_STARTSTOPON (0x0<<5) + +#define SYNC_CON_CLK_CLR (0x1<<6) + +#endif /* end __USART_H */ +/***************************************************************************** +** End Of File +******************************************************************************/
diff -r 4dd6b327586a -r 0f1be4e75668 blinky.c --- /dev/null Thu Jan 01 00:00:00 1970 +0000 +++ b/blinky.c Mon May 28 00:13:23 2012 +0000 @@ -0,0 +1,91 @@ +/**************************************************************************** + * $Id:: blinky.c 9190 2012-02-16 20:59:45Z nxp41306 $ + * Project: NXP LPC11xx Blinky example + * + * Description: + * This file contains LED blink code example which include timer, + * GPIO initialization, and clock monitoring. + * + **************************************************************************** + * 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. +****************************************************************************/ +#include "LPC11Uxx.h" /* LPC11Uxx definitions */ +#include "timer16.h" +#include "clkconfig.h" +#include "gpio.h" +#include "nmi.h" + +#define TEST_TIMER_NUM 0 /* 0 or 1 for 16-bit timers only */ + +extern volatile uint32_t timer16_0_counter[2]; +extern volatile uint32_t timer16_1_counter[2]; + +/* Main Program */ + +int main (void) { + uint32_t interval; + + SystemCoreClockUpdate(); + + /* Config CLKOUT, mostly used for debugging. */ + // CLKOUT_Setup( CLKOUTCLK_SRC_MAIN_CLK ); + // LPC_IOCON->PIO0_1 &= ~0x07; + // LPC_IOCON->PIO0_1 |= 0x01; /* CLK OUT */ + + /* Enable AHB clock to the GPIO domain. */ + LPC_SYSCON->SYSAHBCLKCTRL |= (1<<6); + + /* TEST_TIMER_NUM is either 0 or 1 for 16-bit timer 0 or 1. */ + interval = SystemCoreClock/1000 - 1; + if ( interval > 0xFFFF ) + { + interval = 0xFFFF; + } + init_timer16(TEST_TIMER_NUM, interval); + enable_timer16(TEST_TIMER_NUM); + + /* Set port 1_8 to output */ + GPIOSetDir( 1, 8, 1 ); + + while (1) /* Loop forever */ + { +#if TEST_TIMER_NUM + /* I/O configuration and LED setting pending. */ + if ( (timer16_1_counter[0] > 0) && (timer16_1_counter[0] <= 200) ) + { + GPIOSetBitValue( 1, 8, 0 ); + } + if ( (timer16_1_counter[0] > 200) && (timer16_1_counter[0] <= 400) ) + { + GPIOSetBitValue( 1, 8, 1 ); + } + else if ( timer16_1_counter[0] > 400 ) + { + timer16_1_counter[0] = 0; + } +#else + /* I/O configuration and LED setting pending. */ + if ( (timer16_0_counter[0] > 0) && (timer16_0_counter[0] <= 200) ) + { + GPIOSetBitValue( 1, 8, 0 ); + } + if ( (timer16_0_counter[0] > 200) && (timer16_0_counter[0] <= 400) ) + { + GPIOSetBitValue( 1, 8, 1 ); + } + else if ( timer16_0_counter[0] > 400 ) + { + timer16_0_counter[0] = 0; + } +#endif + } +}
diff -r 4dd6b327586a -r 0f1be4e75668 main.cpp --- a/main.cpp Mon May 28 00:01:35 2012 +0000 +++ /dev/null Thu Jan 01 00:00:00 1970 +0000 @@ -1,91 +0,0 @@ -/**************************************************************************** - * $Id:: blinky.c 9190 2012-02-16 20:59:45Z nxp41306 $ - * Project: NXP LPC11xx Blinky example - * - * Description: - * This file contains LED blink code example which include timer, - * GPIO initialization, and clock monitoring. - * - **************************************************************************** - * 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. -****************************************************************************/ -#include <LPC11Uxx.h> /* LPC11Uxx definitions */ -#include "timer16.h" -#include "clkconfig.h" -#include "gpio.h" -#include "nmi.h" - -#define TEST_TIMER_NUM 0 /* 0 or 1 for 16-bit timers only */ - -extern volatile uint32_t timer16_0_counter[2]; -extern volatile uint32_t timer16_1_counter[2]; - -/* Main Program */ - -int main (void) { - uint32_t interval; - - SystemCoreClockUpdate(); - - /* Config CLKOUT, mostly used for debugging. */ - // CLKOUT_Setup( CLKOUTCLK_SRC_MAIN_CLK ); - // LPC_IOCON->PIO0_1 &= ~0x07; - // LPC_IOCON->PIO0_1 |= 0x01; /* CLK OUT */ - - /* Enable AHB clock to the GPIO domain. */ - LPC_SYSCON->SYSAHBCLKCTRL |= (1<<6); - - /* TEST_TIMER_NUM is either 0 or 1 for 16-bit timer 0 or 1. */ - interval = SystemCoreClock/1000 - 1; - if ( interval > 0xFFFF ) - { - interval = 0xFFFF; - } - init_timer16(TEST_TIMER_NUM, interval); - enable_timer16(TEST_TIMER_NUM); - - /* Set port 1_8 to output */ - GPIOSetDir( 1, 8, 1 ); - - while (1) /* Loop forever */ - { -#if TEST_TIMER_NUM - /* I/O configuration and LED setting pending. */ - if ( (timer16_1_counter[0] > 0) && (timer16_1_counter[0] <= 200) ) - { - GPIOSetBitValue( 1, 8, 0 ); - } - if ( (timer16_1_counter[0] > 200) && (timer16_1_counter[0] <= 400) ) - { - GPIOSetBitValue( 1, 8, 1 ); - } - else if ( timer16_1_counter[0] > 400 ) - { - timer16_1_counter[0] = 0; - } -#else - /* I/O configuration and LED setting pending. */ - if ( (timer16_0_counter[0] > 0) && (timer16_0_counter[0] <= 200) ) - { - GPIOSetBitValue( 1, 8, 0 ); - } - if ( (timer16_0_counter[0] > 200) && (timer16_0_counter[0] <= 400) ) - { - GPIOSetBitValue( 1, 8, 1 ); - } - else if ( timer16_0_counter[0] > 400 ) - { - timer16_0_counter[0] = 0; - } -#endif - } -}