cortex m0 lpc1114 adc start位控制轉換
“START位”位于AD模塊控制寄存器bit24~bit26。
位符號值描述復位值7:0SEL選擇哪個引腳用作采集和轉換,當bit0=1,用AD0;當bit1=1,…,當bit7=1,用AD7在軟件控制模式,當(BURST=0),只允許選擇一個引腳,也就是說,這7位當中,只允許有1個位是1
在硬件掃描模式,當(BURST=1),可以允許1個,也可以允許多個甚至允許8個引腳都開啟。如果所有位都是0,將自動使得SEL=0X01,即選擇AD0
0x0015:8CLKDIVAPB時鐘(PCLK)除以(CLKDIV+1)就是AD模塊的時鐘,這個值必須≤4.5MHz。016BURST
觸發(fā)模式位(注意:當BURST=1的時候,AD0INTEN寄存器中的ADGINTEN位必須為0)00軟件控制模式:需要11個時鐘轉換1硬件掃描模式:AD轉換將會按照CLKS位設置的速度重復轉換,掃描所有SEL設置成1的位。首先掃描SEL中最小的設置成1的位,然后掃描再大一些的設置成1的位。在轉換過程中,把此位寫0,可以停止轉換。(注意:如果BRUST=1,START位必須為000,否則將不會開啟轉換。)19:17CLKS
時鐘精度選擇位,精度越高,轉換時間越長0000x011 clocks / 10 bits0x110 clocks / 9 bits0x29 clocks / 8 bits0x38 clocks / 7 bits0x47 clocks / 6 bits0x56 clocks / 5 bits0x65 clocks / 4 bits0x74 clocks / 3 bits23:20–
保留位,禁止給這些位寫1Na26:24START
當BURST=0,這些位控制軟件控制轉換方式00x0沒有開始0x1開始轉換0x2當PIO0_2/SSEL/CT16B0_CAP0引腳上產(chǎn)生bit27位設置的邊沿信號,開始轉換0x3當PIO1_5/DIR/CT32B0_CAP0引腳上產(chǎn)生bit27位設置的邊沿信號,開始轉換
0x4當CT32B0_MAT0產(chǎn)生bit27位設置的邊沿信號,開始轉換
0x5當CT32B0_MAT1產(chǎn)生bit27位設置的邊沿信號,開始轉換0x6當CT16B0_MAT0產(chǎn)生bit27位設置的邊沿信號,開始轉換0x7當CT16B0_MAT1產(chǎn)生bit27位設置的邊沿信號,開始轉換27EDGE
只有在START位為010~111時,這個位有效00在CAP/MAT引腳上產(chǎn)生上升沿觸發(fā)轉換1在CAP/MAT引腳上產(chǎn)生下降沿觸發(fā)轉換31:28–
保留位,不允許寫1到這些位Na
在CR寄存器中,由SEL位選擇輸入通道,由CLKDIV決定AD時鐘,由BURST位控制轉換觸發(fā)模式,CLKS位決定轉換精度,START位和EDGE位決定了軟件觸發(fā)模式下的轉換模式。
新建一個工程,結構如下圖所示:
在adc.h中,加入以下代碼:
#ifndef __NXP_ADC_H
#define __NXP_ADC_H
#define Vref 3300
extern void ADC_Init(uint8_t Channel);
extern uint32_t ADC_Read(uint8_t Channel);
#endif
在adc.c文件中,加入以下代碼:
#include “l(fā)pc11xx.h”
#include “adc.h”
void ADC_Init(uint8_t Channel)
{
if(Channel>7) return;
LPC_SYSCON->PDRUNCFG &= ~(0x1<<4); // ADC模塊上電
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<13); // 使能ADC時鐘
LPC_SYSCON->SYSAHBCLKCTRL |= (1<<16); // 使能IOCON時鐘
switch(Channel)
{
case 0: // 通道0配置 set channel 0
LPC_IOCON->R_PIO0_11 &= ~0x07; //
LPC_IOCON->R_PIO0_11 |= 0x02; // 把P0.11引腳設置為AD0功能
LPC_IOCON->R_PIO0_11 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->R_PIO0_11 &= ~(1<<7) ; // 模擬輸入模式
break;
case 1: // 通道1配置 set channel 1
LPC_IOCON->R_PIO1_0 &= ~0x07; //
LPC_IOCON->R_PIO1_0 |= 0x02; // 把P1.0引腳設置為AD1功能
LPC_IOCON->R_PIO1_0 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->R_PIO1_0 &= ~(1<<7) ; // 模擬輸入模式
break;
case 2: // 通道2配置 set channel 2
LPC_IOCON->R_PIO1_1 &= ~0x07; //
LPC_IOCON->R_PIO1_1 |= 0x02; // 把P1.1引腳設置為AD2功能
LPC_IOCON->R_PIO1_1 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->R_PIO1_1 &= ~(1<<7) ; // 模擬輸入模式
break;
case 3: // 通道3配置 set channel 3
LPC_IOCON->R_PIO1_2 &= ~0x07; //
LPC_IOCON->R_PIO1_2 |= 0x02; // 把P1.2引腳設置為AD3功能
LPC_IOCON->R_PIO1_2 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->R_PIO1_2 &= ~(1<<7) ; // 模擬輸入模式
break;
case 4: // 通道4配置 set channel 4
LPC_IOCON->SWDIO_PIO1_3 &= ~0x07; //
LPC_IOCON->SWDIO_PIO1_3 |= 0x02; // 把P1.3引腳設置為AD4功能
LPC_IOCON->SWDIO_PIO1_3 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->SWDIO_PIO1_3 &= ~(1<<7) ; // 模擬輸入模式
break;
case 5: // 通道5配置 set channel 5
LPC_IOCON->PIO1_4 &= ~0x07; //
LPC_IOCON->PIO1_4 |= 0x01; // 把P1.4引腳設置為AD5功能
LPC_IOCON->PIO1_4 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->PIO1_4 &= ~(1<<7) ; // 模擬輸入模式
break;
case 6: // 通道6配置 set channel 6
LPC_IOCON->PIO1_10 &= ~0x07; //
LPC_IOCON->PIO1_10 |= 0x01; // 把P1.10引腳設置為AD6功能
LPC_IOCON->PIO1_10 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->PIO1_10 &= ~(1<<7) ; // 模擬輸入模式
break;
case 7: // 通道7配置 set channel 7
LPC_IOCON->PIO1_11 &= ~0x07; //
LPC_IOCON->PIO1_11 |= 0x01; // 把P1.11引腳設置為AD7功能
LPC_IOCON->PIO1_11 &= ~(3<<3) ; // 去掉上拉和下拉電阻
LPC_IOCON->PIO1_11 &= ~(1<<7) ; // 模擬輸入模式
break;
default:break;
}
LPC_SYSCON->SYSAHBCLKCTRL &= ~(1<<16); // 關閉IOCON時鐘
LPC_ADC->CR = (1< (24<<8); /* bit15:bit8 把采樣時鐘頻率設置為2MHz 50/(24+1)*/ } uint32_t ADC_Read(uint8_t Channel) { uint32_t adc_value=0; LPC_ADC->CR |= (1<<24); // 啟動轉換 while((LPC_ADC->DR[Channel]&0x80000000)==0); adc_value = (LPC_ADC->DR[Channel]>>6)&0x3FF; adc_value = (adc_value*Vref)/1024; // 轉換為真正的電壓值 retur