/********************************************************************** * $Id$ lpc43xx_adc.h 2011-06-02 *//** * @file lpc43xx_adc.h * @brief Contains all macro definitions and function prototypes * support for ADC firmware library on lpc43xx * @version 1.0 * @date 02. June. 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 ----------------------------------------------------------- */ /** @defgroup ADC ADC (Analog to Digital Converter) * @ingroup LPC4300CMSIS_FwLib_Drivers * @{ */ #ifndef lpc43xx_ADC_H_ #define lpc43xx_ADC_H_ /* Includes ------------------------------------------------------------------- */ #include "LPC43xx.h" #include "lpc_types.h" #ifdef __cplusplus extern "C" { #endif /* Private macros ------------------------------------------------------------- */ /** @defgroup ADC_Private_Macros ADC Private Macros * @{ */ /* -------------------------- BIT DEFINITIONS ----------------------------------- */ /*********************************************************************//** * Macro defines for ADC control register **********************************************************************/ /** Selects which of the AD0.0:7 pins is (are) to be sampled and converted */ #define ADC_CR_CH_SEL(n) ((1UL << n)) /** The APB clock (PCLK) is divided by (this value plus one) * to produce the clock for the A/D */ #define ADC_CR_CLKDIV(n) ((n<<8)) /** Repeated conversions A/D enable bit */ #define ADC_CR_BURST ((1UL<<16)) /** number of accuracy bits */ #define ADC_CR_BITACC(n) (((n)<<17)) /** ADC convert in power down mode */ #define ADC_CR_PDN ((1UL<<21)) /** Start mask bits */ #define ADC_CR_START_MASK ((7UL<<24)) /** Select Start Mode */ #define ADC_CR_START_MODE_SEL(SEL) ((SEL<<24)) /** Start conversion now */ #define ADC_CR_START_NOW ((1UL<<24)) /** Start conversion when the edge selected by bit 27 occurs on CTOUT_15 */ #define ADC_CR_START_CTOUT15 ((2UL<<24)) /** Start conversion when the edge selected by bit 27 occurs on CTOUT_8 */ #define ADC_CR_START_CTOUT8 ((3UL<<24)) /** Start conversion when the edge selected by bit 27 occurs on ADCTRIG0 */ #define ADC_CR_START_ADCTRIG0 ((4UL<<24)) /** Start conversion when the edge selected by bit 27 occurs on ADCTRIG1 */ #define ADC_CR_START_ADCTRIG1 ((5UL<<24)) /** Start conversion when the edge selected by bit 27 occurs on Motocon PWM output MCOA2 */ #define ADC_CR_START_MCOA2 ((6UL<<24)) /** Start conversion on a falling edge on the selected CAP/MAT signal */ #define ADC_CR_EDGE ((1UL<<27)) /*********************************************************************//** * Macro defines for ADC Global Data register **********************************************************************/ /** When DONE is 1, this field contains result value of ADC conversion */ #define ADC_GDR_RESULT(n) (((n>>4)&0xFFF)) /** These bits contain the channel from which the LS bits were converted */ #define ADC_GDR_CH(n) (((n>>24)&0x7)) /** This bit is 1 in burst mode if the results of one or * more conversions was (were) lost */ #define ADC_GDR_OVERRUN_FLAG ((1UL<<30)) /** This bit is set to 1 when an A/D conversion completes */ #define ADC_GDR_DONE_FLAG ((1UL<<31)) /** This bits is used to mask for Channel */ #define ADC_GDR_CH_MASK ((7UL<<24)) /*********************************************************************//** * Macro defines for ADC Interrupt register **********************************************************************/ /** These bits allow control over which A/D channels generate * interrupts for conversion completion */ #define ADC_INTEN_CH(n) ((1UL<>6)&0x3FF)) /** These bits mirror the OVERRRUN status flags that appear in the * result register for each A/D channel */ #define ADC_DR_OVERRUN_FLAG ((1UL<<30)) /** This bit is set to 1 when an A/D conversion completes. It is cleared * when this register is read */ #define ADC_DR_DONE_FLAG ((1UL<<31)) /*********************************************************************//** * Macro defines for ADC Status register **********************************************************************/ /** These bits mirror the DONE status flags that appear in the result * register for each A/D channel */ #define ADC_STAT_CH_DONE_FLAG(n) ((n&0xFF)) /** These bits mirror the OVERRRUN status flags that appear in the * result register for each A/D channel */ #define ADC_STAT_CH_OVERRUN_FLAG(n) (((n>>8)&0xFF)) /** This bit is the A/D interrupt flag */ #define ADC_STAT_INT_FLAG ((1UL<<16)) /*********************************************************************//** * Macro defines for ADC Trim register **********************************************************************/ /** Offset trim bits for ADC operation */ #define ADC_ADCOFFS(n) (((n&0xF)<<4)) /** Written to boot code*/ #define ADC_TRIM(n) (((n&0xF)<<8)) /* ------------------- CHECK PARAM DEFINITIONS ------------------------- */ /** Check ADC parameter */ #define PARAM_ADCx(n) (((uint32_t *)n)==((uint32_t *)LPC_ADC0) || ((uint32_t *)n)==((uint32_t *)LPC_ADC1)) /** Check ADC state parameter */ #define PARAM_ADC_START_ON_EDGE_OPT(OPT) ((OPT == ADC_START_ON_RISING)||(OPT == ADC_START_ON_FALLING)) /** Check ADC state parameter */ #define PARAM_ADC_DATA_STATUS(OPT) ((OPT== ADC_DATA_BURST)||(OPT== ADC_DATA_DONE)) /** Check ADC rate parameter */ #define PARAM_ADC_RATE(rate) ((rate>0)&&(rate<=200000)) /** Check ADC bits accuracy parameter */ #define PARAM_ADC_BITSACC(x) ((x>=3)&&(x<=10)) /** Check ADC channel selection parameter */ #define PARAM_ADC_CHANNEL_SELECTION(SEL) ((SEL == ADC_CHANNEL_0)||(ADC_CHANNEL_1)\ ||(SEL == ADC_CHANNEL_2)|(ADC_CHANNEL_3)\ ||(SEL == ADC_CHANNEL_4)||(ADC_CHANNEL_5)\ ||(SEL == ADC_CHANNEL_6)||(ADC_CHANNEL_7)) /** Check ADC start option parameter */ #define PARAM_ADC_START_OPT(OPT) ((OPT == ADC_START_CONTINUOUS)||(OPT == ADC_START_NOW)\ ||(OPT == ADC_START_ON_CTOUT15)||(OPT == ADC_START_ON_CTOUT8)\ ||(OPT == ADC_START_ON_ADCTRIG0)||(OPT == ADC_START_ON_ADCTRIG1)\ ||(OPT == ADC_START_ON_MCOA2)) /** Check ADC interrupt type parameter */ #define PARAM_ADC_TYPE_INT_OPT(OPT) ((OPT == ADC_ADINTEN0)||(OPT == ADC_ADINTEN1)\ ||(OPT == ADC_ADINTEN2)||(OPT == ADC_ADINTEN3)\ ||(OPT == ADC_ADINTEN4)||(OPT == ADC_ADINTEN5)\ ||(OPT == ADC_ADINTEN6)||(OPT == ADC_ADINTEN7)\ ||(OPT == ADC_ADGINTEN)) /** * @} */ /* Public Types --------------------------------------------------------------- */ /** @defgroup ADC_Public_Types ADC Public Types * @{ */ /*********************************************************************//** * @brief ADC enumeration **********************************************************************/ /** @brief Channel Selection */ typedef enum { ADC_CHANNEL_0 = 0, /*!< Channel 0 */ ADC_CHANNEL_1, /*!< Channel 1 */ ADC_CHANNEL_2, /*!< Channel 2 */ ADC_CHANNEL_3, /*!< Channel 3 */ ADC_CHANNEL_4, /*!< Channel 4 */ ADC_CHANNEL_5, /*!< Channel 5 */ ADC_CHANNEL_6, /*!< Channel 6 */ ADC_CHANNEL_7 /*!< Channel 7 */ }ADC_CHANNEL_SELECTION; /** @brief Type of start option */ typedef enum { ADC_START_CONTINUOUS =0, /*!< Continuous mode */ ADC_START_NOW, /*!< Start conversion now */ ADC_START_ON_CTOUT15, /*!< Start conversion when the edge selected * by bit 27 occurs on CTOUT_15 */ ADC_START_ON_CTOUT8, /*!< Start conversion when the edge selected * by bit 27 occurs on CTOUT_8 */ ADC_START_ON_ADCTRIG0, /*!< Start conversion when the edge selected * by bit 27 occurs on ADCTRIG0 */ ADC_START_ON_ADCTRIG1, /*!< Start conversion when the edge selected * by bit 27 occurs on ADCTRIG1 */ ADC_START_ON_MCOA2 /*!< Start conversion when the edge selected * by bit 27 occurs on Motocon PWM output MCOA2 */ } ADC_START_OPT; /** @brief Type of edge when start conversion on the selected CAP/MAT signal */ typedef enum { ADC_START_ON_RISING = 0, /*!< Start conversion on a rising edge *on the selected CAP/MAT signal */ ADC_START_ON_FALLING /*!< Start conversion on a falling edge *on the selected CAP/MAT signal */ } ADC_START_ON_EDGE_OPT; /** @brief* ADC type interrupt enum */ typedef enum { ADC_ADINTEN0 = 0, /*!< Interrupt channel 0 */ ADC_ADINTEN1, /*!< Interrupt channel 1 */ ADC_ADINTEN2, /*!< Interrupt channel 2 */ ADC_ADINTEN3, /*!< Interrupt channel 3 */ ADC_ADINTEN4, /*!< Interrupt channel 4 */ ADC_ADINTEN5, /*!< Interrupt channel 5 */ ADC_ADINTEN6, /*!< Interrupt channel 6 */ ADC_ADINTEN7, /*!< Interrupt channel 7 */ ADC_ADGINTEN /*!< Individual channel/global flag done generate an interrupt */ }ADC_TYPE_INT_OPT; /** @brief ADC Data status */ typedef enum { ADC_DATA_BURST = 0, /*Burst bit*/ ADC_DATA_DONE /*Done bit*/ }ADC_DATA_STATUS; /** * @} */ /* Public Functions ----------------------------------------------------------- */ /** @defgroup ADC_Public_Functions ADC Public Functions * @{ */ /* Init/DeInit ADC peripheral ----------------*/ void ADC_Init(LPC_ADCn_Type *ADCx, uint32_t rate, uint8_t bits_accuracy); void ADC_DeInit(LPC_ADCn_Type *ADCx); /* Enable/Disable ADC functions --------------*/ void ADC_BurstCmd(LPC_ADCn_Type *ADCx, FunctionalState NewState); void ADC_PowerdownCmd(LPC_ADCn_Type *ADCx, FunctionalState NewState); void ADC_StartCmd(LPC_ADCn_Type *ADCx, uint8_t start_mode); void ADC_ChannelCmd (LPC_ADCn_Type *ADCx, uint8_t Channel, FunctionalState NewState); /* Configure ADC functions -------------------*/ void ADC_EdgeStartConfig(LPC_ADCn_Type *ADCx, uint8_t EdgeOption); void ADC_IntConfig (LPC_ADCn_Type *ADCx, ADC_TYPE_INT_OPT IntType, FunctionalState NewState); /* Get ADC information functions -------------------*/ uint16_t ADC_ChannelGetData(LPC_ADCn_Type *ADCx, uint8_t channel); FlagStatus ADC_ChannelGetStatus(LPC_ADCn_Type *ADCx, uint8_t channel, uint32_t StatusType); uint32_t ADC_GlobalGetData(LPC_ADCn_Type *ADCx); FlagStatus ADC_GlobalGetStatus(LPC_ADCn_Type *ADCx, uint32_t StatusType); /** * @} */ #ifdef __cplusplus } #endif #endif /* lpc43xx_ADC_H_ */ /** * @} */