These are the examples provided for [[/users/frank26080115/libraries/LPC1700CMSIS_Lib/]] Note, the entire "program" is not compilable!
PWM/Match_Interrupt/pwm_match_int.c
- Committer:
- frank26080115
- Date:
- 2011-03-20
- Revision:
- 0:bf7b9fba3924
File content as of revision 0:bf7b9fba3924:
/***********************************************************************//** * @file pwm_match_int.c * @purpose PWM match interrupt example * @version 2.0 * @date 21. May. 2010 * @author NXP MCU SW Application Team *--------------------------------------------------------------------- * 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 "lpc17xx_pwm.h" #include "lpc17xx_libcfg.h" #include "lpc17xx_pinsel.h" /* Example group ----------------------------------------------------------- */ /** @defgroup PWM_Match_Interrupt Match_Interrupt * @ingroup PWM_Examples * @{ */ /************************** PRIVATE DEFINITIONS *************************/ // Time out definition - used in blocking mode in read/write function #define TIME_OUT 10000 /************************** PRIVATE VARIABLES *************************/ __IO uint32_t match_cnt = 0; __IO uint32_t long_duty = 0; /************************** PRIVATE FUNCTIONS *************************/ /* Interrupt service routine */ void PWM1_IRQHandler(void); /*----------------- INTERRUPT SERVICE ROUTINES --------------------------*/ /*********************************************************************//** * @brief GPDMA interrupt handler sub-routine * @param[in] None * @return None **********************************************************************/ void PWM1_IRQHandler(void) { /* Check whether if match flag for channel 0 is set or not */ if (PWM_GetIntStatus(LPC_PWM1, PWM_INTSTAT_MR0)) { match_cnt++; /* Clear the interrupt flag */ PWM_ClearIntPending(LPC_PWM1, PWM_INTSTAT_MR0); } } /*-------------------------MAIN FUNCTION------------------------------*/ /*********************************************************************//** * @brief c_entry: Main PWM program body * @param[in] None * @return int **********************************************************************/ int c_entry(void) { uint8_t temp, temp2; PWM_TIMERCFG_Type PWMCfgDat; PWM_MATCHCFG_Type PWMMatchCfgDat; PINSEL_CFG_Type PinCfg; /* PWM block section -------------------------------------------- */ /* Initialize PWM peripheral, timer mode * PWM prescale value = 1 (absolute value - tick value) */ PWMCfgDat.PrescaleOption = PWM_TIMER_PRESCALE_TICKVAL; PWMCfgDat.PrescaleValue = 1; PWM_Init(LPC_PWM1, PWM_MODE_TIMER, (void *) &PWMCfgDat); /* * Initialize PWM pin connect */ PinCfg.Funcnum = 1; PinCfg.OpenDrain = 0; PinCfg.Pinmode = 0; PinCfg.Portnum = 2; for (temp = 0; temp <= 6; temp++){ PinCfg.Pinnum = temp; PINSEL_ConfigPin(&PinCfg); } /* Set match value for PWM match channel 0 = 256, update immediately */ PWM_MatchUpdate(LPC_PWM1, 0, 256, PWM_MATCH_UPDATE_NOW); /* PWM Timer/Counter will be reset when channel 0 matching * Enable interrupt when match * no stop when match */ PWMMatchCfgDat.IntOnMatch = ENABLE; PWMMatchCfgDat.MatchChannel = 0; PWMMatchCfgDat.ResetOnMatch = ENABLE; PWMMatchCfgDat.StopOnMatch = DISABLE; PWM_ConfigMatch(LPC_PWM1, &PWMMatchCfgDat); /* Configure each PWM channel: --------------------------------------------- */ /* - Single edge * - PWM Duty on each PWM channel determined by * the match on channel 0 to the match of that match channel. * Example: PWM Duty on PWM channel 1 determined by * the match on channel 0 to the match of match channel 1. */ /* Configure PWM channel edge option * Note: PWM Channel 1 is in single mode as default state and * can not be changed to double edge mode */ for (temp = 2; temp < 7; temp++) { PWM_ChannelConfig(LPC_PWM1, temp, PWM_CHANNEL_SINGLE_EDGE); } /* Setting interrupt for PWM ---------------------------------------------- */ /* Disable PWM interrupt */ NVIC_DisableIRQ(PWM1_IRQn); /* preemption = 1, sub-priority = 1 */ NVIC_SetPriority(PWM1_IRQn, ((0x01<<3)|0x01)); /* Configure match value for each match channel */ temp2 = 10; for (temp = 1; temp < 7; temp++) { /* Set up match value */ PWM_MatchUpdate(LPC_PWM1, temp, temp2, PWM_MATCH_UPDATE_NOW); /* Configure match option */ PWMMatchCfgDat.IntOnMatch = DISABLE; PWMMatchCfgDat.MatchChannel = temp; PWMMatchCfgDat.ResetOnMatch = DISABLE; PWMMatchCfgDat.StopOnMatch = DISABLE; PWM_ConfigMatch(LPC_PWM1, &PWMMatchCfgDat); /* Enable PWM Channel Output */ PWM_ChannelCmd(LPC_PWM1, temp, ENABLE); /* Increase match value by 10 */ temp2 += 10; } /* Enable PWM interrupt */ NVIC_EnableIRQ(PWM1_IRQn); /* Reset and Start counter */ PWM_ResetCounter(LPC_PWM1); PWM_CounterCmd(LPC_PWM1, ENABLE); /* Start PWM now */ PWM_Cmd(LPC_PWM1, ENABLE); // Update PWM1.1 every 0x1000 match interrupt while (1) { if (match_cnt >= 0x1000) { match_cnt = 0; long_duty++; if (long_duty >= 256) { // Reset duty long_duty = 0; // Print info //UART_Puts_(uartdev, "PWM1.1 is reset!"); } // Update PWM1.1 duty PWM_MatchUpdate(LPC_PWM1, 1, long_duty, PWM_MATCH_UPDATE_NOW); } } return 1; } /* With ARM and GHS toolsets, the entry point is main() - this will allow the linker to generate wrapper code to setup stacks, allocate heap area, and initialize and copy code and data segments. For GNU toolsets, the entry point is through __start() in the crt0_gnu.asm file, and that startup code will setup stacks and data */ int main(void) { return c_entry(); } #ifdef DEBUG /******************************************************************************* * @brief Reports the name of the source file and the source line number * where the CHECK_PARAM error has occurred. * @param[in] file Pointer to the source file name * @param[in] line assert_param error line source number * @return None *******************************************************************************/ void check_failed(uint8_t *file, uint32_t line) { /* User can add his own implementation to report the file name and line number, ex: printf("Wrong parameters value: file %s on line %d\r\n", file, line) */ /* Infinite loop */ while(1); } #endif /* * @} */