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
触发模式位(注意:当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引脚上产生bit27位设置的边沿信号,开始转换0x3当PIO1_5/DIR/CT32B0_CAP0引脚上产生bit27位设置的边沿信号,开始转换
0x4当CT32B0_MAT0产生bit27位设置的边沿信号,开始转换
0x5当CT32B0_MAT1产生bit27位设置的边沿信号,开始转换0x6当CT16B0_MAT0产生bit27位设置的边沿信号,开始转换0x7当CT16B0_MAT1产生bit27位设置的边沿信号,开始转换27EDGE
只有在START位为010~111时,这个位有效00在CAP/MAT引脚上产生上升沿触发转换1在CAP/MAT引脚上产生下降沿触发转换31:28–
保留位,不允许写1到这些位Na
在CR寄存器中,由SEL位选择输入通道,由CLKDIV决定AD时钟,由BURST位控制转换触发模式,CLKS位决定转换精度,START位和EDGE位决定了软件触发模式下的转换模式。
新建一个工程,结构如下图所示:
在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 “lpc11xx.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