301 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
		
		
			
		
	
	
			301 lines
		
	
	
		
			11 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
|   | /**********************************************************************
 | |||
|  | * $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<EFBFBD> | |||
|  | * 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<<n))
 | |||
|  | /** When 1, enables the global DONE flag in ADDR to generate an interrupt */ | |||
|  | #define ADC_INTEN_GLOBAL		((1UL<<8))
 | |||
|  | 
 | |||
|  | /*********************************************************************//**
 | |||
|  |  * Macro defines for ADC Data register | |||
|  |  **********************************************************************/ | |||
|  | /** When DONE is 1, this field contains result value of ADC conversion */ | |||
|  | #define ADC_DR_RESULT(n)		(((n>>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_ */
 | |||
|  | 
 | |||
|  | /**
 | |||
|  |  * @} | |||
|  |  */ | |||
|  | 
 |