1509|0

3836

帖子

19

TA的资源

纯净的硅(中级)

楼主
 

msp430内部含有ADC12模块程序实现 [复制链接]

程序主要实现的是一个比较通用的初始化程序,内容如下:

char ADC12Init(char n,char channels[],char rep)
{
    if(n>15)
        return 0;
    //SHT0_0
    ADC12CTL0 = ADC12ON + MSC + SHT0_0 + REFON + REF2_5V;// 开启ad,参考电压2.5v
    ADC12CTL1 = SHP + ADC12SSEL_3;                  //Use sampling timer, SMCLK

    for(int i = 0;i < n;i++)
    {
        if(channels[i] >= 0x80)
            return 0;
        *(char*)(ADC12MCTL0_ + i) = channels[i];    //每个MCTL设置
    }
    *(char*)(ADC12MCTL0_ + n - 1) |= EOS;           //序列结束

    if(rep != 0)                                  //多次转换
    {
        ADC12CTL1 |= CONSEQ_3;
    }
    else
    {
        ADC12CTL1 |= CONSEQ_1;
    }

    ADC12IE = 1<<(n-1);                                 // Enable ADC12IFG.n-1
    return 1;
}
程序先判断n 通道总数是否超过了可用的个数,超过则返回零然后设置ADC12CTL0和ADC12CTL1中不需要特殊设置的部分,然后在设置通道模式(根据rep参数的值);for循环设置的是每个存储寄存器的设置ADC12MCTLx ;*(char*)(ADC12MCTL0_ + n - 1) |= EOS; //序列结束 这句加入序列结束标志;最后设置中断寄存器并返回成功设置标志。其中比较特殊的是ADC12MCTL0_,这个是430提供的头文件中定义的ADC12MCTL0的地址值,以其为指针首址操作ADCMCTLx寄存器,从而利用循环设置寄存器的内容,大量减少了代码行数。

参数channels[]是每个存储寄存器的设置(除EOS位之外的),含义如下:

channels[]:对应通道设置,高四位,参考源选择;
低四位,通道选择。具体如下:
SREFx Bits
6-4
Select reference
000 VR+ = AVCC and VR. = AVSS
001 VR+ = VREF+ and VR. = AVSS
010 VR+ = VeREF+ and VR. = AVSS
011 VR+ = VeREF+ and VR. = AVSS
100 VR+ = AVCC and VR. = VREF./ VeREF.
101 VR+ = VREF+ and VR. = VREF./ VeREF.
110 VR+ = VeREF+ and VR. = VREF./ VeREF.
111 VR+ = VeREF+ and VR. = VREF./ VeREF.
INCHx Bits
3-0
Input channel select
0000 A0
0001 A1
0010 A2
0011 A3
0100 A4
0101 A5
0110 A6
0111 A7
1000 VeREF+
1001 VREF./VeREF.
1010 Temperature sensor
1011 (AVCC – AVSS) / 2
1100 (AVCC – AVSS) / 2
1101 (AVCC – AVSS) / 2
1110 (AVCC – AVSS) / 2
1111 (AVCC – AVSS) / 2
这是从用户指南里复制来的,每一位和ADC12MCTLx的意义相同(去掉EOS位),所以可用宏定义来制定这个参数,如:

char channels[3];
channels[0] = SREF_1+INCH_0;
channels[1] = SREF_1+INCH_1;
channels[2] = SREF_1+INCH_2;
ADC12Init(3,channels,1);
这是3个通道A0-A2采样,多次采样。

启动转换函数:

void ADC12Start()
{
    ADC12CTL0 |= ENC;
    ADC12CTL0 |= ADC12SC;
}
ADC初始化完成后,调用此函数开始AD转换,转换完成后(一个序列通道,如:刚才的0-2),程序自动进入AD中断,用户需要在这里为自己的函数添加处理逻辑;这里只存储了转化的结果:

#pragma vector=ADC_VECTOR
__interrupt void ADC12ISR (void)
{
    static int i;
    results[0][i] = ADC12MEM0;                // Move results, IFG is cleared
    results[1][i] = ADC12MEM1;                // Move results, IFG is cleared
    results[2][i] = ADC12MEM2;                // Move results, IFG is cleared
    i++;
    if(i>31)                                  //多次转换时 转换次数
    {
        //多次重复采样时,在这里方处理函数
        ADC12CTL0 &=~ ENC;                      //停止转换
        i=0;
    }

}
该程序实现的是多次A0-A2 32次转换,把结果存入results数组。单次时,仅仅采样一次(A0-A2)可用自己更改处理函数。

程序部分就完成了,调用时注意要自己实现处理逻辑或存储逻辑。

 
点赞 关注

回复
举报
您需要登录后才可以回帖 登录 | 注册

随便看看
查找数据手册?

EEWorld Datasheet 技术支持

相关文章 更多>>
关闭
站长推荐上一条 1/9 下一条

 
EEWorld订阅号

 
EEWorld服务号

 
汽车开发圈

About Us 关于我们 客户服务 联系方式 器件索引 网站地图 最新更新 手机版

站点相关: 国产芯 安防电子 汽车电子 手机便携 工业控制 家用电子 医疗电子 测试测量 网络通信 物联网

北京市海淀区中关村大街18号B座15层1530室 电话:(010)82350740 邮编:100190

电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2025 EEWORLD.com.cn, Inc. All rights reserved
快速回复 返回顶部 返回列表