protegemed, aquisição via A/D simples utilizando interrupção do timer

Dependencies:   EthernetInterface NTPClient mbed-rtos mbed

Fork of ptgm_semDMA by Marcelo Rebonatto

Committer:
rebonatto
Date:
Tue Jan 05 11:47:35 2016 +0000
Revision:
0:fac116e94d44
Vers?o est?vel sem DMA e FFT. 128 amostras.

Who changed what in which revision?

UserRevisionLine numberNew contents of line
rebonatto 0:fac116e94d44 1 /*
rebonatto 0:fac116e94d44 2 * adc.c
rebonatto 0:fac116e94d44 3 *
rebonatto 0:fac116e94d44 4 * Created on: 02/07/2011
rebonatto 0:fac116e94d44 5 * Author: francisco
rebonatto 0:fac116e94d44 6 */
rebonatto 0:fac116e94d44 7
rebonatto 0:fac116e94d44 8 #include <LPC17xx.h>
rebonatto 0:fac116e94d44 9 #include "adc.h"
rebonatto 0:fac116e94d44 10
rebonatto 0:fac116e94d44 11 void init_adc(int adc_clk)
rebonatto 0:fac116e94d44 12 {
rebonatto 0:fac116e94d44 13 // Turn on power to ADC block
rebonatto 0:fac116e94d44 14 LPC_SC->PCONP |= PCADC;
rebonatto 0:fac116e94d44 15
rebonatto 0:fac116e94d44 16 // Turn on ADC peripheral clock
rebonatto 0:fac116e94d44 17 LPC_SC->PCLKSEL0 &= ~(3 << PCLK_ADC);
rebonatto 0:fac116e94d44 18 LPC_SC->PCLKSEL0 |= (ADC_CCLK << PCLK_ADC); //CLK/8
rebonatto 0:fac116e94d44 19
rebonatto 0:fac116e94d44 20 unsigned int clkdiv = (SystemCoreClock/1)/65;
rebonatto 0:fac116e94d44 21 clkdiv = clkdiv/adc_clk;
rebonatto 0:fac116e94d44 22
rebonatto 0:fac116e94d44 23 LPC_ADC->ADCR &= ~(ADC_OPERATIONAL|ADC_CLKDIV(255));
rebonatto 0:fac116e94d44 24 LPC_ADC->ADCR |= (ADC_OPERATIONAL|ADC_CLKDIV(clkdiv));
rebonatto 0:fac116e94d44 25
rebonatto 0:fac116e94d44 26 //NVIC_EnableIRQ(ADC_IRQn);
rebonatto 0:fac116e94d44 27 }
rebonatto 0:fac116e94d44 28
rebonatto 0:fac116e94d44 29 void setup_start(int mode,int edge)
rebonatto 0:fac116e94d44 30 {
rebonatto 0:fac116e94d44 31 LPC_ADC->ADCR |= mode;
rebonatto 0:fac116e94d44 32 }
rebonatto 0:fac116e94d44 33
rebonatto 0:fac116e94d44 34 void select_channels(int adc_ch)
rebonatto 0:fac116e94d44 35 {
rebonatto 0:fac116e94d44 36 LPC_ADC->ADCR &= ~(ADC_CH_0|ADC_CH_1|ADC_CH_2|ADC_CH_3|ADC_CH_4|ADC_CH_5|ADC_CH_6|ADC_CH_7);
rebonatto 0:fac116e94d44 37 LPC_ADC->ADCR |= adc_ch;
rebonatto 0:fac116e94d44 38
rebonatto 0:fac116e94d44 39 LPC_ADC->ADINTEN |= (1U<<8);//adc_ch;
rebonatto 0:fac116e94d44 40
rebonatto 0:fac116e94d44 41 if(adc_ch&ADC_CH_0)
rebonatto 0:fac116e94d44 42 {
rebonatto 0:fac116e94d44 43 LPC_PINCON->PINSEL1 |= 1U<<14;
rebonatto 0:fac116e94d44 44 LPC_PINCON->PINMODE1 |= 2U<<14;
rebonatto 0:fac116e94d44 45 }
rebonatto 0:fac116e94d44 46 if(adc_ch&ADC_CH_1)
rebonatto 0:fac116e94d44 47 {
rebonatto 0:fac116e94d44 48 LPC_PINCON->PINSEL1 |= 1U<<16;
rebonatto 0:fac116e94d44 49 LPC_PINCON->PINMODE1 |= 2U<<16;
rebonatto 0:fac116e94d44 50 }
rebonatto 0:fac116e94d44 51 if(adc_ch&ADC_CH_2)
rebonatto 0:fac116e94d44 52 {
rebonatto 0:fac116e94d44 53 LPC_PINCON->PINSEL1 |= 1U<<18;
rebonatto 0:fac116e94d44 54 LPC_PINCON->PINMODE1 |= 2U<<18;
rebonatto 0:fac116e94d44 55 }
rebonatto 0:fac116e94d44 56 if(adc_ch&ADC_CH_3)
rebonatto 0:fac116e94d44 57 {
rebonatto 0:fac116e94d44 58 LPC_PINCON->PINSEL1 |= 1U<<20;
rebonatto 0:fac116e94d44 59 LPC_PINCON->PINMODE1 |= 2U<<20;
rebonatto 0:fac116e94d44 60 }
rebonatto 0:fac116e94d44 61 if(adc_ch&ADC_CH_4)
rebonatto 0:fac116e94d44 62 {
rebonatto 0:fac116e94d44 63 LPC_PINCON->PINSEL3 |= 3U<<28;
rebonatto 0:fac116e94d44 64 LPC_PINCON->PINMODE3 |= 2U<<28;
rebonatto 0:fac116e94d44 65 }
rebonatto 0:fac116e94d44 66 if(adc_ch&ADC_CH_5)
rebonatto 0:fac116e94d44 67 {
rebonatto 0:fac116e94d44 68 LPC_PINCON->PINSEL3 |= 3U<<30;
rebonatto 0:fac116e94d44 69 LPC_PINCON->PINMODE3 |= 2U<<30;
rebonatto 0:fac116e94d44 70 }
rebonatto 0:fac116e94d44 71 if(adc_ch&ADC_CH_6)
rebonatto 0:fac116e94d44 72 {
rebonatto 0:fac116e94d44 73 LPC_PINCON->PINSEL0 |= 2U<<6;
rebonatto 0:fac116e94d44 74 LPC_PINCON->PINMODE0 |= 2U<<6;
rebonatto 0:fac116e94d44 75 }
rebonatto 0:fac116e94d44 76 if(adc_ch&ADC_CH_7)
rebonatto 0:fac116e94d44 77 {
rebonatto 0:fac116e94d44 78 LPC_PINCON->PINSEL0 |= 2U<<4;
rebonatto 0:fac116e94d44 79 LPC_PINCON->PINMODE0 |= 2U<<4;
rebonatto 0:fac116e94d44 80 }
rebonatto 0:fac116e94d44 81 }