515 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			515 lines
		
	
	
		
			24 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /**********************************************************************
 | ||
|  | * $Id$      lpc17xx_qei.c               2010-05-21 | ||
|  | *//**
 | ||
|  | * @file     lpc17xx_qei.c | ||
|  | * @brief    Contains all functions support for QEI firmware library on LPC17xx | ||
|  | * @version  2.0 | ||
|  | * @date     21. May. 2010 | ||
|  | * @author   NXP MCU SW Application Team | ||
|  | * | ||
|  | * Copyright(C) 2010, 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 QEI
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /* Includes ------------------------------------------------------------------- */ | ||
|  | #include "lpc17xx_qei.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 _QEI
 | ||
|  | 
 | ||
|  | /* Private Types -------------------------------------------------------------- */ | ||
|  | /** @defgroup QEI_Private_Types QEI Private Types
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @brief QEI configuration union type definition | ||
|  |  */ | ||
|  | typedef union { | ||
|  |     QEI_CFG_Type bmQEIConfig; | ||
|  |     uint32_t ulQEIConfig; | ||
|  | } QEI_CFGOPT_Type; | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | 
 | ||
|  | /* Public Functions ----------------------------------------------------------- */ | ||
|  | /** @addtogroup QEI_Public_Functions
 | ||
|  |  * @{ | ||
|  |  */ | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Resets value for each type of QEI value, such as velocity, | ||
|  |  *              counter, position, etc.. | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulResetType     QEI Reset Type, should be one of the following: | ||
|  |  *                              - QEI_RESET_POS: Reset Position Counter | ||
|  |  *                              - QEI_RESET_POSOnIDX: Reset Position Counter on Index signal | ||
|  |  *                              - QEI_RESET_VEL: Reset Velocity | ||
|  |  *                              - QEI_RESET_IDX: Reset Index Counter | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_Reset(LPC_QEI_TypeDef *QEIx, uint32_t ulResetType) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_RESET(ulResetType)); | ||
|  | 
 | ||
|  |     QEIx->QEICON = ulResetType; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Initializes the QEI peripheral according to the specified | ||
|  | *               parameters in the QEI_ConfigStruct. | ||
|  |  * @param[in]   QEIx                QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   QEI_ConfigStruct    Pointer to a QEI_CFG_Type structure | ||
|  | *                    that contains the configuration information for the | ||
|  | *                    specified QEI peripheral | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_Init(LPC_QEI_TypeDef *QEIx, QEI_CFG_Type *QEI_ConfigStruct) | ||
|  | { | ||
|  | 
 | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_DIRINV(QEI_ConfigStruct->DirectionInvert)); | ||
|  |     CHECK_PARAM(PARAM_QEI_SIGNALMODE(QEI_ConfigStruct->SignalMode)); | ||
|  |     CHECK_PARAM(PARAM_QEI_CAPMODE(QEI_ConfigStruct->CaptureMode)); | ||
|  |     CHECK_PARAM(PARAM_QEI_INVINX(QEI_ConfigStruct->InvertIndex)); | ||
|  | 
 | ||
|  |     /* Set up clock and power for QEI module */ | ||
|  |     CLKPWR_ConfigPPWR (CLKPWR_PCONP_PCQEI, ENABLE); | ||
|  | 
 | ||
|  |     /* As default, peripheral clock for QEI module
 | ||
|  |      * is set to FCCLK / 2 */ | ||
|  |     CLKPWR_SetPCLKDiv(CLKPWR_PCLKSEL_QEI, CLKPWR_PCLKSEL_CCLK_DIV_1); | ||
|  | 
 | ||
|  |     // Reset all remaining value in QEI peripheral
 | ||
|  |     QEIx->QEICON = QEI_CON_RESP | QEI_CON_RESV | QEI_CON_RESI; | ||
|  |     QEIx->QEIMAXPOS = 0x00; | ||
|  |     QEIx->CMPOS0 = 0x00; | ||
|  |     QEIx->CMPOS1 = 0x00; | ||
|  |     QEIx->CMPOS2 = 0x00; | ||
|  |     QEIx->INXCMP = 0x00; | ||
|  |     QEIx->QEILOAD = 0x00; | ||
|  |     QEIx->VELCOMP = 0x00; | ||
|  |     QEIx->FILTER = 0x00; | ||
|  |     // Disable all Interrupt
 | ||
|  |     QEIx->QEIIEC = QEI_IECLR_BITMASK; | ||
|  |     // Clear all Interrupt pending
 | ||
|  |     QEIx->QEICLR = QEI_INTCLR_BITMASK; | ||
|  |     // Set QEI configuration value corresponding to its setting up value
 | ||
|  |     QEIx->QEICONF = ((QEI_CFGOPT_Type *)QEI_ConfigStruct)->ulQEIConfig; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       De-initializes the QEI peripheral registers to their | ||
|  | *                  default reset values. | ||
|  |  * @param[in]   QEIx    QEI peripheral, should be LPC_QEI | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_DeInit(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  | 
 | ||
|  |     /* Turn off clock and power for QEI module */ | ||
|  |     CLKPWR_ConfigPPWR (CLKPWR_PCONP_PCQEI, DISABLE); | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*****************************************************************************//**
 | ||
|  | * @brief        Fills each QIE_InitStruct member with its default value: | ||
|  | *               - DirectionInvert = QEI_DIRINV_NONE | ||
|  | *               - SignalMode = QEI_SIGNALMODE_QUAD | ||
|  | *               - CaptureMode = QEI_CAPMODE_4X | ||
|  | *               - InvertIndex = QEI_INVINX_NONE | ||
|  | * @param[in]    QIE_InitStruct Pointer to a QEI_CFG_Type structure | ||
|  | *                    which will be initialized. | ||
|  | * @return       None | ||
|  | *******************************************************************************/ | ||
|  | void QEI_ConfigStructInit(QEI_CFG_Type *QIE_InitStruct) | ||
|  | { | ||
|  |     QIE_InitStruct->CaptureMode = QEI_CAPMODE_4X; | ||
|  |     QIE_InitStruct->DirectionInvert = QEI_DIRINV_NONE; | ||
|  |     QIE_InitStruct->InvertIndex = QEI_INVINX_NONE; | ||
|  |     QIE_InitStruct->SignalMode = QEI_SIGNALMODE_QUAD; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Check whether if specified flag status is set or not | ||
|  |  * @param[in]   QEIx        QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulFlagType  Status Flag Type, should be one of the following: | ||
|  |  *                          - QEI_STATUS_DIR: Direction Status | ||
|  |  * @return      New Status of this status flag (SET or RESET) | ||
|  |  **********************************************************************/ | ||
|  | FlagStatus QEI_GetStatus(LPC_QEI_TypeDef *QEIx, uint32_t ulFlagType) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_STATUS(ulFlagType)); | ||
|  |     return ((QEIx->QEISTAT & ulFlagType) ? SET : RESET); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Get current position value in QEI peripheral | ||
|  |  * @param[in]   QEIx    QEI peripheral, should be LPC_QEI | ||
|  |  * @return      Current position value of QEI peripheral | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_GetPosition(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     return (QEIx->QEIPOS); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set max position value for QEI peripheral | ||
|  |  * @param[in]   QEIx        QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulMaxPos    Max position value to set | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetMaxPosition(LPC_QEI_TypeDef *QEIx, uint32_t ulMaxPos) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     QEIx->QEIMAXPOS = ulMaxPos; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set position compare value for QEI peripheral | ||
|  |  * @param[in]   QEIx        QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   bPosCompCh  Compare Position channel, should be: | ||
|  |  *                          - QEI_COMPPOS_CH_0: QEI compare position channel 0 | ||
|  |  *                          - QEI_COMPPOS_CH_1: QEI compare position channel 1 | ||
|  |  *                          - QEI_COMPPOS_CH_2: QEI compare position channel 2 | ||
|  |  * @param[in]   ulPosComp   Compare Position value to set | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetPositionComp(LPC_QEI_TypeDef *QEIx, uint8_t bPosCompCh, uint32_t ulPosComp) | ||
|  | { | ||
|  |     uint32_t *tmp; | ||
|  | 
 | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_COMPPOS_CH(bPosCompCh)); | ||
|  |     tmp = (uint32_t *) (&(QEIx->CMPOS0) + bPosCompCh * 4); | ||
|  |     *tmp = ulPosComp; | ||
|  | 
 | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Get current index counter of QEI peripheral | ||
|  |  * @param[in]   QEIx        QEI peripheral, should be LPC_QEI | ||
|  |  * @return      Current value of QEI index counter | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_GetIndex(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     return (QEIx->INXCNT); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set value for index compare in QEI peripheral | ||
|  |  * @param[in]   QEIx        QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulIndexComp     Compare Index Value to set | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetIndexComp(LPC_QEI_TypeDef *QEIx, uint32_t ulIndexComp) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     QEIx->INXCMP = ulIndexComp; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set timer reload value for QEI peripheral. When the velocity timer is | ||
|  |  *              over-flow, the value that set for Timer Reload register will be loaded | ||
|  |  *              into the velocity timer for next period. The calculated velocity in RPM | ||
|  |  *              therefore will be affect by this value. | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   QEIReloadStruct QEI reload structure | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetTimerReload(LPC_QEI_TypeDef *QEIx, QEI_RELOADCFG_Type *QEIReloadStruct) | ||
|  | { | ||
|  |     uint64_t pclk; | ||
|  | 
 | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_TIMERRELOAD(QEIReloadStruct->ReloadOption)); | ||
|  | 
 | ||
|  |     if (QEIReloadStruct->ReloadOption == QEI_TIMERRELOAD_TICKVAL) { | ||
|  |         QEIx->QEILOAD = QEIReloadStruct->ReloadValue - 1; | ||
|  |     } else { | ||
|  |         pclk = (uint64_t)CLKPWR_GetPCLK(CLKPWR_PCLKSEL_QEI); | ||
|  |         pclk = (pclk /(1000000/QEIReloadStruct->ReloadValue)) - 1; | ||
|  |         QEIx->QEILOAD = (uint32_t)pclk; | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Get current timer counter in QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @return      Current timer counter in QEI peripheral | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_GetTimer(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     return (QEIx->QEITIME); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Get current velocity pulse counter in current time period | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @return      Current velocity pulse counter value | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_GetVelocity(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     return (QEIx->QEIVEL); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Get the most recently measured velocity of the QEI. When | ||
|  |  *              the Velocity timer in QEI is over-flow, the current velocity | ||
|  |  *              value will be loaded into Velocity Capture register. | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @return      The most recently measured velocity value | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_GetVelocityCap(LPC_QEI_TypeDef *QEIx) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     return (QEIx->QEICAP); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set Velocity Compare value for QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulVelComp       Compare Velocity value to set | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetVelocityComp(LPC_QEI_TypeDef *QEIx, uint32_t ulVelComp) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     QEIx->VELCOMP = ulVelComp; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Set value of sampling count for the digital filter in | ||
|  |  *              QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulSamplingPulse Value of sampling count to set | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_SetDigiFilter(LPC_QEI_TypeDef *QEIx, uint32_t ulSamplingPulse) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     QEIx->FILTER = ulSamplingPulse; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Check whether if specified interrupt flag status in QEI | ||
|  |  *              peripheral is set or not | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulIntType       Interrupt Flag Status type, should be: | ||
|  |                                 - QEI_INTFLAG_INX_Int: index pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_TIM_Int: Velocity timer over flow interrupt | ||
|  |                                 - QEI_INTFLAG_VELC_Int: Capture velocity is less than compare interrupt | ||
|  |                                 - QEI_INTFLAG_DIR_Int: Change of direction interrupt | ||
|  |                                 - QEI_INTFLAG_ERR_Int: An encoder phase error interrupt | ||
|  |                                 - QEI_INTFLAG_ENCLK_Int: An encoder clock pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_POS0_Int: position 0 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS1_Int: position 1 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS2_Int: position 2 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_REV_Int: Index compare value is equal to the current | ||
|  |                                                         index count interrupt | ||
|  |                                 - QEI_INTFLAG_POS0REV_Int: Combined position 0 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS1REV_Int: Combined position 1 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS2REV_Int: Combined position 2 and revolution count interrupt | ||
|  |  * @return      New State of specified interrupt flag status (SET or RESET) | ||
|  |  **********************************************************************/ | ||
|  | FlagStatus QEI_GetIntStatus(LPC_QEI_TypeDef *QEIx, uint32_t ulIntType) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_INTFLAG(ulIntType)); | ||
|  | 
 | ||
|  |     return((QEIx->QEIINTSTAT & ulIntType) ? SET : RESET); | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Enable/Disable specified interrupt in QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulIntType       Interrupt Flag Status type, should be: | ||
|  |  *                              - QEI_INTFLAG_INX_Int: index pulse was detected interrupt | ||
|  |  *                              - QEI_INTFLAG_TIM_Int: Velocity timer over flow interrupt | ||
|  |  *                              - QEI_INTFLAG_VELC_Int: Capture velocity is less than compare interrupt | ||
|  |  *                              - QEI_INTFLAG_DIR_Int: Change of direction interrupt | ||
|  |  *                              - QEI_INTFLAG_ERR_Int: An encoder phase error interrupt | ||
|  |  *                              - QEI_INTFLAG_ENCLK_Int: An encoder clock pulse was detected interrupt | ||
|  |  *                              - QEI_INTFLAG_POS0_Int: position 0 compare value is equal to the | ||
|  |  *                                                      current position interrupt | ||
|  |  *                              - QEI_INTFLAG_POS1_Int: position 1 compare value is equal to the | ||
|  |  *                                                      current position interrupt | ||
|  |  *                              - QEI_INTFLAG_POS2_Int: position 2 compare value is equal to the | ||
|  |  *                                                      current position interrupt | ||
|  |  *                              - QEI_INTFLAG_REV_Int: Index compare value is equal to the current | ||
|  |  *                                                      index count interrupt | ||
|  |  *                              - QEI_INTFLAG_POS0REV_Int: Combined position 0 and revolution count interrupt | ||
|  |  *                              - QEI_INTFLAG_POS1REV_Int: Combined position 1 and revolution count interrupt | ||
|  |  *                              - QEI_INTFLAG_POS2REV_Int: Combined position 2 and revolution count interrupt | ||
|  |  * @param[in]   NewState        New function state, should be: | ||
|  |  *                              - DISABLE | ||
|  |  *                              - ENABLE | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_IntCmd(LPC_QEI_TypeDef *QEIx, uint32_t ulIntType, FunctionalState NewState) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_INTFLAG(ulIntType)); | ||
|  |     CHECK_PARAM(PARAM_FUNCTIONALSTATE(NewState)); | ||
|  | 
 | ||
|  |     if (NewState == ENABLE) { | ||
|  |         QEIx->QEIIES = ulIntType; | ||
|  |     } else { | ||
|  |         QEIx->QEIIEC = ulIntType; | ||
|  |     } | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Sets (forces) specified interrupt in QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulIntType       Interrupt Flag Status type, should be: | ||
|  |                                 - QEI_INTFLAG_INX_Int: index pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_TIM_Int: Velocity timer over flow interrupt | ||
|  |                                 - QEI_INTFLAG_VELC_Int: Capture velocity is less than compare interrupt | ||
|  |                                 - QEI_INTFLAG_DIR_Int: Change of direction interrupt | ||
|  |                                 - QEI_INTFLAG_ERR_Int: An encoder phase error interrupt | ||
|  |                                 - QEI_INTFLAG_ENCLK_Int: An encoder clock pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_POS0_Int: position 0 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS1_Int: position 1 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS2_Int: position 2 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_REV_Int: Index compare value is equal to the current | ||
|  |                                                         index count interrupt | ||
|  |                                 - QEI_INTFLAG_POS0REV_Int: Combined position 0 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS1REV_Int: Combined position 1 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS2REV_Int: Combined position 2 and revolution count interrupt | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_IntSet(LPC_QEI_TypeDef *QEIx, uint32_t ulIntType) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_INTFLAG(ulIntType)); | ||
|  | 
 | ||
|  |     QEIx->QEISET = ulIntType; | ||
|  | } | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Clear (force) specified interrupt (pending) in QEI peripheral | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulIntType       Interrupt Flag Status type, should be: | ||
|  |                                 - QEI_INTFLAG_INX_Int: index pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_TIM_Int: Velocity timer over flow interrupt | ||
|  |                                 - QEI_INTFLAG_VELC_Int: Capture velocity is less than compare interrupt | ||
|  |                                 - QEI_INTFLAG_DIR_Int: Change of direction interrupt | ||
|  |                                 - QEI_INTFLAG_ERR_Int: An encoder phase error interrupt | ||
|  |                                 - QEI_INTFLAG_ENCLK_Int: An encoder clock pulse was detected interrupt | ||
|  |                                 - QEI_INTFLAG_POS0_Int: position 0 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS1_Int: position 1 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_POS2_Int: position 2 compare value is equal to the | ||
|  |                                                         current position interrupt | ||
|  |                                 - QEI_INTFLAG_REV_Int: Index compare value is equal to the current | ||
|  |                                                         index count interrupt | ||
|  |                                 - QEI_INTFLAG_POS0REV_Int: Combined position 0 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS1REV_Int: Combined position 1 and revolution count interrupt | ||
|  |                                 - QEI_INTFLAG_POS2REV_Int: Combined position 2 and revolution count interrupt | ||
|  |  * @return      None | ||
|  |  **********************************************************************/ | ||
|  | void QEI_IntClear(LPC_QEI_TypeDef *QEIx, uint32_t ulIntType) | ||
|  | { | ||
|  |     CHECK_PARAM(PARAM_QEIx(QEIx)); | ||
|  |     CHECK_PARAM(PARAM_QEI_INTFLAG(ulIntType)); | ||
|  | 
 | ||
|  |     QEIx->QEICLR = ulIntType; | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /*********************************************************************//**
 | ||
|  |  * @brief       Calculates the actual velocity in RPM passed via velocity | ||
|  |  *              capture value and Pulse Per Round (of the encoder) value | ||
|  |  *              parameter input. | ||
|  |  * @param[in]   QEIx            QEI peripheral, should be LPC_QEI | ||
|  |  * @param[in]   ulVelCapValue   Velocity capture input value that can | ||
|  |  *                              be got from QEI_GetVelocityCap() function | ||
|  |  * @param[in]   ulPPR           Pulse per round of encoder | ||
|  |  * @return      The actual value of velocity in RPM (Round per minute) | ||
|  |  **********************************************************************/ | ||
|  | uint32_t QEI_CalculateRPM(LPC_QEI_TypeDef *QEIx, uint32_t ulVelCapValue, uint32_t ulPPR) | ||
|  | { | ||
|  |     uint64_t rpm, clock, Load, edges; | ||
|  | 
 | ||
|  |     // Get current Clock rate for timer input
 | ||
|  |     clock = (uint64_t)CLKPWR_GetPCLK(CLKPWR_PCLKSEL_QEI); | ||
|  |     // Get Timer load value (velocity capture period)
 | ||
|  |     Load  = (uint64_t)(QEIx->QEILOAD + 1); | ||
|  |     // Get Edge
 | ||
|  |     edges = (uint64_t)((QEIx->QEICONF & QEI_CONF_CAPMODE) ? 4 : 2); | ||
|  |     // Calculate RPM
 | ||
|  |     rpm = ((clock * ulVelCapValue * 60) / (Load * ulPPR * edges)); | ||
|  | 
 | ||
|  |     return (uint32_t)(rpm); | ||
|  | } | ||
|  | 
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | #endif /* _QEI */
 | ||
|  | 
 | ||
|  | /**
 | ||
|  |  * @} | ||
|  |  */ | ||
|  | 
 | ||
|  | /* --------------------------------- End Of File ------------------------------ */ | ||
|  | 
 |