589 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			589 lines
		
	
	
		
			21 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| 
								 | 
							
								/**********************************************************************
							 | 
						||
| 
								 | 
							
								* $Id$      lpc17xx_pwm.c               2011-03-31
							 | 
						||
| 
								 | 
							
								*//**
							 | 
						||
| 
								 | 
							
								* @file     lpc17xx_pwm.c
							 | 
						||
| 
								 | 
							
								* @brief    Contains all functions support for PWM firmware library on LPC17xx
							 | 
						||
| 
								 | 
							
								* @version  2.1
							 | 
						||
| 
								 | 
							
								* @date     31. Mar. 2011
							 | 
						||
| 
								 | 
							
								* @author   NXP MCU SW Application Team
							 | 
						||
| 
								 | 
							
								*
							 | 
						||
| 
								 | 
							
								* Copyright(C) 2011, NXP Semiconductor
							 | 
						||
| 
								 | 
							
								* All rights reserved.
							 | 
						||
| 
								 | 
							
								*
							 | 
						||
| 
								 | 
							
								***********************************************************************
							 | 
						||
| 
								 | 
							
								* Software that is described herein is for illustrative purposes only
							 | 
						||
| 
								 | 
							
								* which provides customers with programming information regarding the
							 | 
						||
| 
								 | 
							
								* products. This software is supplied "AS IS" without any warranties.
							 | 
						||
| 
								 | 
							
								* NXP Semiconductors assumes no responsibility or liability for the
							 | 
						||
| 
								 | 
							
								* use of the software, conveys no license or title under any patent,
							 | 
						||
| 
								 | 
							
								* copyright, or mask work right to the product. NXP Semiconductors
							 | 
						||
| 
								 | 
							
								* reserves the right to make changes in the software without
							 | 
						||
| 
								 | 
							
								* notification. NXP Semiconductors also make no representation or
							 | 
						||
| 
								 | 
							
								* warranty that such application will be suitable for the specified
							 | 
						||
| 
								 | 
							
								* use without further testing or modification.
							 | 
						||
| 
								 | 
							
								* Permission to use, copy, modify, and distribute this software and its
							 | 
						||
| 
								 | 
							
								* documentation is hereby granted, under NXP Semiconductors'
							 | 
						||
| 
								 | 
							
								* relevant copyright in the software, without fee, provided that it
							 | 
						||
| 
								 | 
							
								* is used in conjunction with NXP Semiconductors microcontrollers.  This
							 | 
						||
| 
								 | 
							
								* copyright, permission, and disclaimer notice must appear in all copies of
							 | 
						||
| 
								 | 
							
								* this code.
							 | 
						||
| 
								 | 
							
								**********************************************************************/
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Peripheral group ----------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								/** @addtogroup PWM
							 | 
						||
| 
								 | 
							
								 * @{
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Includes ------------------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								#include "lpc17xx_pwm.h"
							 | 
						||
| 
								 | 
							
								#include "lpc17xx_clkpwr.h"
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* If this source file built with example, the LPC17xx FW library configuration
							 | 
						||
| 
								 | 
							
								 * file in each example directory ("lpc17xx_libcfg.h") must be included,
							 | 
						||
| 
								 | 
							
								 * otherwise the default FW library configuration file must be included instead
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								#ifdef __BUILD_WITH_EXAMPLE__
							 | 
						||
| 
								 | 
							
								#include "lpc17xx_libcfg.h"
							 | 
						||
| 
								 | 
							
								#else
							 | 
						||
| 
								 | 
							
								#include "lpc17xx_libcfg_default.h"
							 | 
						||
| 
								 | 
							
								#endif /* __BUILD_WITH_EXAMPLE__ */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#ifdef _PWM
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* Public Functions ----------------------------------------------------------- */
							 | 
						||
| 
								 | 
							
								/** @addtogroup PWM_Public_Functions
							 | 
						||
| 
								 | 
							
								 * @{
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Check whether specified interrupt flag in PWM is set or not
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx: PWM peripheral, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   IntFlag: PWM interrupt flag, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR0: Interrupt flag for PWM match channel 0
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR1: Interrupt flag for PWM match channel 1
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR2: Interrupt flag for PWM match channel 2
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR3: Interrupt flag for PWM match channel 3
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR4: Interrupt flag for PWM match channel 4
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR5: Interrupt flag for PWM match channel 5
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR6: Interrupt flag for PWM match channel 6
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_CAP0: Interrupt flag for capture input 0
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_CAP1: Interrupt flag for capture input 1
							 | 
						||
| 
								 | 
							
								 * @return      New State of PWM interrupt flag (SET or RESET)
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								IntStatus PWM_GetIntStatus(LPC_PWM_TypeDef *PWMx, uint32_t IntFlag)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_INTSTAT(IntFlag));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    return ((PWMx->IR & IntFlag) ? SET : RESET);
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Clear specified PWM Interrupt pending
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx: PWM peripheral, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   IntFlag: PWM interrupt flag, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR0: Interrupt flag for PWM match channel 0
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR1: Interrupt flag for PWM match channel 1
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR2: Interrupt flag for PWM match channel 2
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR3: Interrupt flag for PWM match channel 3
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR4: Interrupt flag for PWM match channel 4
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR5: Interrupt flag for PWM match channel 5
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_MR6: Interrupt flag for PWM match channel 6
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_CAP0: Interrupt flag for capture input 0
							 | 
						||
| 
								 | 
							
								 *              - PWM_INTSTAT_CAP1: Interrupt flag for capture input 1
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ClearIntPending(LPC_PWM_TypeDef *PWMx, uint32_t IntFlag)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_INTSTAT(IntFlag));
							 | 
						||
| 
								 | 
							
								    PWMx->IR = IntFlag;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*****************************************************************************//**
							 | 
						||
| 
								 | 
							
								* @brief        Fills each PWM_InitStruct member with its default value:
							 | 
						||
| 
								 | 
							
								*               - If PWMCounterMode = PWM_MODE_TIMER:
							 | 
						||
| 
								 | 
							
								*                   + PrescaleOption = PWM_TIMER_PRESCALE_USVAL
							 | 
						||
| 
								 | 
							
								*                   + PrescaleValue = 1
							 | 
						||
| 
								 | 
							
								*               - If PWMCounterMode = PWM_MODE_COUNTER:
							 | 
						||
| 
								 | 
							
								*                   + CountInputSelect = PWM_COUNTER_PCAP1_0
							 | 
						||
| 
								 | 
							
								*                   + CounterOption = PWM_COUNTER_RISING
							 | 
						||
| 
								 | 
							
								* @param[in]    PWMTimerCounterMode Timer or Counter mode, should be:
							 | 
						||
| 
								 | 
							
								*               - PWM_MODE_TIMER: Counter of PWM peripheral is in Timer mode
							 | 
						||
| 
								 | 
							
								*               - PWM_MODE_COUNTER: Counter of PWM peripheral is in Counter mode
							 | 
						||
| 
								 | 
							
								* @param[in]    PWM_InitStruct Pointer to structure (PWM_TIMERCFG_Type or
							 | 
						||
| 
								 | 
							
								*                PWM_COUNTERCFG_Type) which will be initialized.
							 | 
						||
| 
								 | 
							
								* @return       None
							 | 
						||
| 
								 | 
							
								* Note: PWM_InitStruct pointer will be assigned to corresponding structure
							 | 
						||
| 
								 | 
							
								*       (PWM_TIMERCFG_Type or PWM_COUNTERCFG_Type) due to PWMTimerCounterMode.
							 | 
						||
| 
								 | 
							
								*******************************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ConfigStructInit(uint8_t PWMTimerCounterMode, void *PWM_InitStruct)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    PWM_TIMERCFG_Type *pTimeCfg;
							 | 
						||
| 
								 | 
							
								    PWM_COUNTERCFG_Type *pCounterCfg;
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_TC_MODE(PWMTimerCounterMode));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    pTimeCfg = (PWM_TIMERCFG_Type *) PWM_InitStruct;
							 | 
						||
| 
								 | 
							
								    pCounterCfg = (PWM_COUNTERCFG_Type *) PWM_InitStruct;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (PWMTimerCounterMode == PWM_MODE_TIMER )
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        pTimeCfg->PrescaleOption = PWM_TIMER_PRESCALE_USVAL;
							 | 
						||
| 
								 | 
							
								        pTimeCfg->PrescaleValue = 1;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else if (PWMTimerCounterMode == PWM_MODE_COUNTER)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        pCounterCfg->CountInputSelect = PWM_COUNTER_PCAP1_0;
							 | 
						||
| 
								 | 
							
								        pCounterCfg->CounterOption = PWM_COUNTER_RISING;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Initializes the PWMx peripheral corresponding to the specified
							 | 
						||
| 
								 | 
							
								 *               parameters in the PWM_ConfigStruct.
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx PWM peripheral, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMTimerCounterMode Timer or Counter mode, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_MODE_TIMER: Counter of PWM peripheral is in Timer mode
							 | 
						||
| 
								 | 
							
								 *              - PWM_MODE_COUNTER: Counter of PWM peripheral is in Counter mode
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWM_ConfigStruct Pointer to structure (PWM_TIMERCFG_Type or
							 | 
						||
| 
								 | 
							
								 *               PWM_COUNTERCFG_Type) which will be initialized.
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 * Note: PWM_ConfigStruct pointer will be assigned to corresponding structure
							 | 
						||
| 
								 | 
							
								 *      (PWM_TIMERCFG_Type or PWM_COUNTERCFG_Type) due to PWMTimerCounterMode.
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_Init(LPC_PWM_TypeDef *PWMx, uint32_t PWMTimerCounterMode, void *PWM_ConfigStruct)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    PWM_TIMERCFG_Type *pTimeCfg;
							 | 
						||
| 
								 | 
							
								    PWM_COUNTERCFG_Type *pCounterCfg;
							 | 
						||
| 
								 | 
							
								    uint64_t clkdlycnt;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_TC_MODE(PWMTimerCounterMode));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    pTimeCfg = (PWM_TIMERCFG_Type *)PWM_ConfigStruct;
							 | 
						||
| 
								 | 
							
								    pCounterCfg = (PWM_COUNTERCFG_Type *)PWM_ConfigStruct;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    CLKPWR_ConfigPPWR (CLKPWR_PCONP_PCPWM1, ENABLE);
							 | 
						||
| 
								 | 
							
								    CLKPWR_SetPCLKDiv (CLKPWR_PCLKSEL_PWM1, CLKPWR_PCLKSEL_CCLK_DIV_4);
							 | 
						||
| 
								 | 
							
								    // Get peripheral clock of PWM1
							 | 
						||
| 
								 | 
							
								    clkdlycnt = (uint64_t) CLKPWR_GetPCLK (CLKPWR_PCLKSEL_PWM1);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // Clear all interrupts pending
							 | 
						||
| 
								 | 
							
								    PWMx->IR = 0xFF & PWM_IR_BITMASK;
							 | 
						||
| 
								 | 
							
								    PWMx->TCR = 0x00;
							 | 
						||
| 
								 | 
							
								    PWMx->CTCR = 0x00;
							 | 
						||
| 
								 | 
							
								    PWMx->MCR = 0x00;
							 | 
						||
| 
								 | 
							
								    PWMx->CCR = 0x00;
							 | 
						||
| 
								 | 
							
								    PWMx->PCR = 0x00;
							 | 
						||
| 
								 | 
							
								    PWMx->LER = 0x00;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (PWMTimerCounterMode == PWM_MODE_TIMER)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        CHECK_PARAM(PARAM_PWM_TIMER_PRESCALE(pTimeCfg->PrescaleOption));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        /* Absolute prescale value */
							 | 
						||
| 
								 | 
							
								        if (pTimeCfg->PrescaleOption == PWM_TIMER_PRESCALE_TICKVAL)
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								            PWMx->PR   = pTimeCfg->PrescaleValue - 1;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								        /* uSecond prescale value */
							 | 
						||
| 
								 | 
							
								        else
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								            clkdlycnt = (clkdlycnt * pTimeCfg->PrescaleValue) / 1000000;
							 | 
						||
| 
								 | 
							
								            PWMx->PR = ((uint32_t) clkdlycnt) - 1;
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else if (PWMTimerCounterMode == PWM_MODE_COUNTER)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        CHECK_PARAM(PARAM_PWM_COUNTER_INPUTSEL(pCounterCfg->CountInputSelect));
							 | 
						||
| 
								 | 
							
								        CHECK_PARAM(PARAM_PWM_COUNTER_EDGE(pCounterCfg->CounterOption));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								        PWMx->CTCR |= (PWM_CTCR_MODE((uint32_t)pCounterCfg->CounterOption)) \
							 | 
						||
| 
								 | 
							
								                        | (PWM_CTCR_SELECT_INPUT((uint32_t)pCounterCfg->CountInputSelect));
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       De-initializes the PWM peripheral registers to their
							 | 
						||
| 
								 | 
							
								*                  default reset values.
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_DeInit (LPC_PWM_TypeDef *PWMx)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // Disable PWM control (timer, counter and PWM)
							 | 
						||
| 
								 | 
							
								    PWMx->TCR = 0x00;
							 | 
						||
| 
								 | 
							
								    CLKPWR_ConfigPPWR (CLKPWR_PCONP_PCPWM1, DISABLE);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enable/Disable PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   NewState    New State of this function, should be:
							 | 
						||
| 
								 | 
							
								 *                          - ENABLE: Enable PWM peripheral
							 | 
						||
| 
								 | 
							
								 *                          - DISABLE: Disable PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_Cmd(LPC_PWM_TypeDef *PWMx, FunctionalState NewState)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(NewState));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (NewState == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR   |=  PWM_TCR_PWM_ENABLE;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR &= (~PWM_TCR_PWM_ENABLE) & PWM_TCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enable/Disable Counter in PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   NewState New State of this function, should be:
							 | 
						||
| 
								 | 
							
								 *                          - ENABLE: Enable Counter in PWM peripheral
							 | 
						||
| 
								 | 
							
								 *                          - DISABLE: Disable Counter in PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_CounterCmd(LPC_PWM_TypeDef *PWMx, FunctionalState NewState)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(NewState));
							 | 
						||
| 
								 | 
							
								    if (NewState == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR   |=  PWM_TCR_COUNTER_ENABLE;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR &= (~PWM_TCR_COUNTER_ENABLE) & PWM_TCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Reset Counter in PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ResetCounter(LPC_PWM_TypeDef *PWMx)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    PWMx->TCR |= PWM_TCR_COUNTER_RESET;
							 | 
						||
| 
								 | 
							
								    PWMx->TCR &= (~PWM_TCR_COUNTER_RESET) & PWM_TCR_BITMASK;
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Configures match for PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWM_MatchConfigStruct   Pointer to a PWM_MATCHCFG_Type structure
							 | 
						||
| 
								 | 
							
								*                    that contains the configuration information for the
							 | 
						||
| 
								 | 
							
								*                    specified PWM match function.
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ConfigMatch(LPC_PWM_TypeDef *PWMx, PWM_MATCHCFG_Type *PWM_MatchConfigStruct)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_MATCH_CHANNEL(PWM_MatchConfigStruct->MatchChannel));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_MatchConfigStruct->IntOnMatch));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_MatchConfigStruct->ResetOnMatch));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_MatchConfigStruct->StopOnMatch));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //interrupt on MRn
							 | 
						||
| 
								 | 
							
								    if (PWM_MatchConfigStruct->IntOnMatch == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR |= PWM_MCR_INT_ON_MATCH(PWM_MatchConfigStruct->MatchChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR &= (~PWM_MCR_INT_ON_MATCH(PWM_MatchConfigStruct->MatchChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_MCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //reset on MRn
							 | 
						||
| 
								 | 
							
								    if (PWM_MatchConfigStruct->ResetOnMatch == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR |= PWM_MCR_RESET_ON_MATCH(PWM_MatchConfigStruct->MatchChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR &= (~PWM_MCR_RESET_ON_MATCH(PWM_MatchConfigStruct->MatchChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_MCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //stop on MRn
							 | 
						||
| 
								 | 
							
								    if (PWM_MatchConfigStruct->StopOnMatch == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR |= PWM_MCR_STOP_ON_MATCH(PWM_MatchConfigStruct->MatchChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->MCR &= (~PWM_MCR_STOP_ON_MATCH(PWM_MatchConfigStruct->MatchChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_MCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Configures capture input for PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWM_CaptureConfigStruct Pointer to a PWM_CAPTURECFG_Type structure
							 | 
						||
| 
								 | 
							
								*                    that contains the configuration information for the
							 | 
						||
| 
								 | 
							
								*                    specified PWM capture input function.
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ConfigCapture(LPC_PWM_TypeDef *PWMx, PWM_CAPTURECFG_Type *PWM_CaptureConfigStruct)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_CAPTURE_CHANNEL(PWM_CaptureConfigStruct->CaptureChannel));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_CaptureConfigStruct->FallingEdge));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_CaptureConfigStruct->IntOnCaption));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_FUNCTIONALSTATE(PWM_CaptureConfigStruct->RisingEdge));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (PWM_CaptureConfigStruct->RisingEdge == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR |= PWM_CCR_CAP_RISING(PWM_CaptureConfigStruct->CaptureChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR &= (~PWM_CCR_CAP_RISING(PWM_CaptureConfigStruct->CaptureChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_CCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (PWM_CaptureConfigStruct->FallingEdge == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR |= PWM_CCR_CAP_FALLING(PWM_CaptureConfigStruct->CaptureChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR &= (~PWM_CCR_CAP_FALLING(PWM_CaptureConfigStruct->CaptureChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_CCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (PWM_CaptureConfigStruct->IntOnCaption == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR |= PWM_CCR_INT_ON_CAP(PWM_CaptureConfigStruct->CaptureChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->CCR &= (~PWM_CCR_INT_ON_CAP(PWM_CaptureConfigStruct->CaptureChannel)) \
							 | 
						||
| 
								 | 
							
								                    & PWM_CCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/*********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Read value of capture register PWM peripheral
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   CaptureChannel: capture channel number, should be in
							 | 
						||
| 
								 | 
							
								 *              range 0 to 1
							 | 
						||
| 
								 | 
							
								 * @return      Value of capture register
							 | 
						||
| 
								 | 
							
								 **********************************************************************/
							 | 
						||
| 
								 | 
							
								uint32_t PWM_GetCaptureValue(LPC_PWM_TypeDef *PWMx, uint8_t CaptureChannel)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_CAPTURE_CHANNEL(CaptureChannel));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    switch (CaptureChannel)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								    case 0:
							 | 
						||
| 
								 | 
							
								        return PWMx->CR0;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 1:
							 | 
						||
| 
								 | 
							
								        return PWMx->CR1;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    default:
							 | 
						||
| 
								 | 
							
								        return (0);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Update value for each PWM channel with update type option
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   MatchChannel Match channel
							 | 
						||
| 
								 | 
							
								 * @param[in]   MatchValue Match value
							 | 
						||
| 
								 | 
							
								 * @param[in]   UpdateType Type of Update, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_MATCH_UPDATE_NOW: The update value will be updated for
							 | 
						||
| 
								 | 
							
								 *                  this channel immediately
							 | 
						||
| 
								 | 
							
								 *              - PWM_MATCH_UPDATE_NEXT_RST: The update value will be updated for
							 | 
						||
| 
								 | 
							
								 *                  this channel on next reset by a PWM Match event.
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 *********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_MatchUpdate(LPC_PWM_TypeDef *PWMx, uint8_t MatchChannel, \
							 | 
						||
| 
								 | 
							
								                    uint32_t MatchValue, uint8_t UpdateType)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_MATCH_CHANNEL(MatchChannel));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_MATCH_UPDATE(UpdateType));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    switch (MatchChannel)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								    case 0:
							 | 
						||
| 
								 | 
							
								        PWMx->MR0 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 1:
							 | 
						||
| 
								 | 
							
								        PWMx->MR1 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 2:
							 | 
						||
| 
								 | 
							
								        PWMx->MR2 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 3:
							 | 
						||
| 
								 | 
							
								        PWMx->MR3 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 4:
							 | 
						||
| 
								 | 
							
								        PWMx->MR4 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 5:
							 | 
						||
| 
								 | 
							
								        PWMx->MR5 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    case 6:
							 | 
						||
| 
								 | 
							
								        PWMx->MR6 = MatchValue;
							 | 
						||
| 
								 | 
							
								        break;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // Write Latch register
							 | 
						||
| 
								 | 
							
								    PWMx->LER |= PWM_LER_EN_MATCHn_LATCH(MatchChannel);
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // In case of update now
							 | 
						||
| 
								 | 
							
								    if (UpdateType == PWM_MATCH_UPDATE_NOW)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR |= PWM_TCR_COUNTER_RESET;
							 | 
						||
| 
								 | 
							
								        PWMx->TCR &= (~PWM_TCR_COUNTER_RESET) & PWM_TCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Update value for multi PWM channel with update type option
							 | 
						||
| 
								 | 
							
								 *              at the same time
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   MatchStruct Structure that contents match value of 7 pwm channels
							 | 
						||
| 
								 | 
							
								 * @param[in]   UpdateType Type of Update, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_MATCH_UPDATE_NOW: The update value will be updated for
							 | 
						||
| 
								 | 
							
								 *                  this channel immediately
							 | 
						||
| 
								 | 
							
								 *              - PWM_MATCH_UPDATE_NEXT_RST: The update value will be updated for
							 | 
						||
| 
								 | 
							
								 *                  this channel on next reset by a PWM Match event.
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 *********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_MultiMatchUpdate(LPC_PWM_TypeDef *PWMx, PWM_Match_T *MatchStruct , uint8_t UpdateType)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    uint8_t LatchValue = 0;
							 | 
						||
| 
								 | 
							
								    uint8_t i;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_MATCH_UPDATE(UpdateType));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    //Update match value
							 | 
						||
| 
								 | 
							
								    for(i=0;i<7;i++)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        if(MatchStruct[i].Status == SET)
							 | 
						||
| 
								 | 
							
								        {
							 | 
						||
| 
								 | 
							
								            if(i<4)
							 | 
						||
| 
								 | 
							
								                *((volatile unsigned int *)(&(PWMx->MR0) + i)) = MatchStruct[i].Matchvalue;
							 | 
						||
| 
								 | 
							
								            else
							 | 
						||
| 
								 | 
							
								            {
							 | 
						||
| 
								 | 
							
								                *((volatile unsigned int *)(&(PWMx->MR4) + (i-4))) = MatchStruct[i].Matchvalue;
							 | 
						||
| 
								 | 
							
								            }
							 | 
						||
| 
								 | 
							
								            LatchValue |=(1<<i);
							 | 
						||
| 
								 | 
							
								        }
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    //set update for multi-channel at the same time
							 | 
						||
| 
								 | 
							
								    PWMx->LER = LatchValue;
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // In case of update now
							 | 
						||
| 
								 | 
							
								    if (UpdateType == PWM_MATCH_UPDATE_NOW)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->TCR |= PWM_TCR_COUNTER_RESET;
							 | 
						||
| 
								 | 
							
								        PWMx->TCR &= (~PWM_TCR_COUNTER_RESET) & PWM_TCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								/********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Configure Edge mode for each PWM channel
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMChannel PWM channel, should be in range from 2 to 6
							 | 
						||
| 
								 | 
							
								 * @param[in]   ModeOption PWM mode option, should be:
							 | 
						||
| 
								 | 
							
								 *              - PWM_CHANNEL_SINGLE_EDGE: Single Edge mode
							 | 
						||
| 
								 | 
							
								 *              - PWM_CHANNEL_DUAL_EDGE: Dual Edge mode
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 * Note: PWM Channel 1 can not be selected for mode option
							 | 
						||
| 
								 | 
							
								 *********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ChannelConfig(LPC_PWM_TypeDef *PWMx, uint8_t PWMChannel, uint8_t ModeOption)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_EDGE_MODE_CHANNEL(PWMChannel));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM_CHANNEL_EDGE(ModeOption));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    // Single edge mode
							 | 
						||
| 
								 | 
							
								    if (ModeOption == PWM_CHANNEL_SINGLE_EDGE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->PCR &= (~PWM_PCR_PWMSELn(PWMChannel)) & PWM_PCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    // Double edge mode
							 | 
						||
| 
								 | 
							
								    else if (PWM_CHANNEL_DUAL_EDGE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->PCR |= PWM_PCR_PWMSELn(PWMChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/********************************************************************//**
							 | 
						||
| 
								 | 
							
								 * @brief       Enable/Disable PWM channel output
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMx    PWM peripheral selected, should be LPC_PWM1
							 | 
						||
| 
								 | 
							
								 * @param[in]   PWMChannel PWM channel, should be in range from 1 to 6
							 | 
						||
| 
								 | 
							
								 * @param[in]   NewState New State of this function, should be:
							 | 
						||
| 
								 | 
							
								 *              - ENABLE: Enable this PWM channel output
							 | 
						||
| 
								 | 
							
								 *              - DISABLE: Disable this PWM channel output
							 | 
						||
| 
								 | 
							
								 * @return      None
							 | 
						||
| 
								 | 
							
								 *********************************************************************/
							 | 
						||
| 
								 | 
							
								void PWM_ChannelCmd(LPC_PWM_TypeDef *PWMx, uint8_t PWMChannel, FunctionalState NewState)
							 | 
						||
| 
								 | 
							
								{
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWMx(PWMx));
							 | 
						||
| 
								 | 
							
								    CHECK_PARAM(PARAM_PWM1_CHANNEL(PWMChannel));
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								    if (NewState == ENABLE)
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->PCR |= PWM_PCR_PWMENAn(PWMChannel);
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								    else
							 | 
						||
| 
								 | 
							
								    {
							 | 
						||
| 
								 | 
							
								        PWMx->PCR &= (~PWM_PCR_PWMENAn(PWMChannel)) & PWM_PCR_BITMASK;
							 | 
						||
| 
								 | 
							
								    }
							 | 
						||
| 
								 | 
							
								}
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @}
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								#endif /* _PWM */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/**
							 | 
						||
| 
								 | 
							
								 * @}
							 | 
						||
| 
								 | 
							
								 */
							 | 
						||
| 
								 | 
							
								
							 | 
						||
| 
								 | 
							
								/* --------------------------------- End Of File ------------------------------ */
							 |