MSP430 模数转换模块--ADC12MSP430 单片机的 ADC12 模块是一个 12 位精度的 A/D 转换模块, 他具有高速度,通用性等特点大部分都内置了 ADC模块.而有些不带ADC模块的片子,也可通过利用内置的模拟比较器来实现AD的转换在系列产品中,我们可以通过以下列表来简单地认识他们的 ADC 功能实现系列型号ADC 功能实现转换精度MSP430X1XX2比较器实现10位MSP430F13XADC 模块12 位MSP430F14XADC 模块12 位MSP430F43XADC 模块12 位MSP430F44XADC 模块12 位MSP430X32XADC 模块14位从以下ADC12结构图中可以看出,ADC12模块中是由以下部分组成:输入的16路模拟开关,ADC内部电压 参考源,ADC12内核,ADC时钟源部分,采集与保持/触发源部分,ADC数据输出部分,ADC控制寄存器等组 成输入的 16 路模拟开关16路模拟开关分别是由IC外部的8路模拟信号输入和内部4路参考电源输入及1路内部温度传感器源及 AVCC-AVSS/2电压源输入外部8路从A0-A7输入,主要是外部测量时的模拟变量信号。
内部4路分别是V eref+ ADC内部参考电源的输出正端,Vref-/Veref- ADC内部参考电源负端(内部/外部)1路AVCC-AVSS /2电压源和1路内部温度传感器源片内温度传感器可以用于测量芯片上的温度,可以在设计时做一些有 用的控制;在实际应用时用得较多而其他电源参考源输入可以用作ADC12的校验之用,在设计时可作自 身校准ADC 内部电压参考源ADC电压参考源是用于给ADC12内核作为一个基准信号之用的,这是ADC必不可少的一部分在ADC12模 块中基准电压源可以通过软件来设置6种不同的组合 AVCC(Vr+), Vref+,Veref+,AVSS(Vr-),Vref-/Vere f-ADC12 内核ADC12的模块内核是共用的,通过前端的模拟开关来分别来完成采集输入ADC12是一个精度为12位的AD C内核,1位非线性微分误差,1位非线性积分误差内核在转换时会参用到两个参考基准电压,一个是参 考相对的最大输入最大值,当模拟开关输出的模拟变量大于或等于最大值时ADC内核的输出数字量为满量 程,也就是Oxfff;另一个则是最小值,当模拟开关输出的模拟变量大小或等于最大值时ADC内核的输出 数字量为最低量程,也就是0x00。
而这两个参考电压是可以通过软件来编程设置的ADC 时钟源部分ADC12的时钟源分有ADC12OSC,ACLK,MCLK,SMCLK通过编程可以选择其中之一时钟源,同时还可以适当 的分频采集与保持,触发源部分ADC12模块中有着较好的采集与保持电路,采用不的设置有着灵活的应用关于这方面的详情请参考手册 上的寄存器说明,此部分我们日后再作补上ADC 数据输出部分ADC内核在每次完成转换时都会将相应通道上的输出结果存贮到相应用通道缓冲区单元中,共有16个通道 缓冲单元同时16个通道的缓冲单元有着相对应的控制寄存器,以实现更灵活的控制ADC 控制寄存器ADC12CTL0 转换控制寄存器 0ADC12CTL1 转换控制寄存器 1ADC12IE 中断使能寄存器ADC12IFG 中断标志寄存器ADC12IV 中断向量寄存器ADC12MEM0-15 存储控制寄存器 0-15ADC12MCTL0-15 存储控制寄存器 0-15MSP430 ADC12 模块结构图ADC'2D Vk—ACLK—MCLK—SMCLKELI「目REFON INCHx=0Af1 o 1 D 1 D +1 Q o 1 1 nV o 11Sample Tmer:4 .' W24-■ ADC12SCAyCtxw/nTL.^>/ / *X**x**x**x**x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x**x**x**x**x**x**x*/ ///表区unsigned char number_table[]={'0','1','2','3','4','5','6','7','8','9'};unsigned char display_buffer[]={0x00,0x00,0x00,0x00,0xff};//*******************波特率***********300 600 1200 2400 4800 9600 19200 38400 76800 115200const //************************************[0]**[1]**[2]*[3]**[4]**[5]***[6]***[7]****[8]***[9]*unsigned char BaudrateUBR0[] ={0x6D,0x36,0x1B,0x0D,0x06,0x03, 0xA0, 0xD0, 0x68, 0x45};unsigned const char BaudrateUBR1[] ={0x00,0x00,0x00,0x00,0x00,0x00, 0x01, 0x00, 0x00, 0x00};unsigned const char BaudrateUMCTL[]={0x22,0xD5,0x03,0x6B,0x6F,0x4A, 0xC0, 0x40, 0x40, 0x4A};unsigned char timp;//变量区unsigned int ADC0 ;//子程序声明void init (void); //初始化void ADC12setup(void); //ADC12 初始化void BaudrateSetup(unsigned char U0); //UART0 初始化void data_converter(unsigned char *p,unsigned int vaule); //数据变换void send_data(unsigned char *p); //串行口发送数组/ / *X**x**x**x**x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x**x**x**x**x**x**x*/ / >|S >|S >|S >|S >|S >|S >|S >|S >|Svoid main(void){init();// 主循环for (;;){LPM0;ADC12CTL0 |= ADC12SC; //sampling open,AD转换完成后(ADC12BUSY=0),ADC12SC 自动复位 ;while((ADC12IFG & BIT0) == 0); //等转换结束ADC0 = ADC12MEM0; //读转换数据值,同时清ADC12IFG0标志data_converter(display_buffer,ADC0); //数据变换//发送数据send_data(display_buffer);/ / *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x**x**x*/ / >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|Svoid init(void){WDTCTL = WDTPW + WDTHOLD; // 停止 WDTP1DIR=0x01;P1OUT=0x0f; //LED 设置BaudrateSetup(6);ADC12setup();_EINT(); // 全局中断使能}/ / *X**X**X**X**X* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x**x**x**x**x* / / ✓r* ✓r* |S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S >|S//串口接收中断,退出LPMO模式.#pragma vector=USART0RX_VECTOR__interrupt void usart0_rx (void){LPM0_EXIT;}/ / *X**X**X**X**X* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x* *x**x**x**x**x* / / ✓r* ✓r* |S >|S >|S >|S >。