微波EDA网,见证研发工程师的成长!
首页 > 研发问答 > 嵌入式设计讨论 > DSP学习交流 > 2812的adc模块

2812的adc模块

时间:10-02 整理:3721RD 点击:
void InitAdc(void)
{
   
        unsigned int i;
       
        AdcRegs.ADCTRL1.bit.RESET=1;
        NOP;
        AdcRegs.ADCTRL1.bit.RESET=0;
       
        AdcRegs.ADCTRL1.bit.SUSMOD=3;
        //仿真暂停时,序列发生器和其他数字电路逻辑立即停止
       
        AdcRegs.ADCTRL1.bit.ACQ_PS=0;
        //采样窗口大小,SOC脉冲宽度为1个ADCLK
       
        AdcRegs.ADCTRL1.bit.CPS=0;
        //核时钟预定标器,等于0,未将时钟进行2分频
       
        AdcRegs.ADCTRL1.bit.CONT_RUN=0;
        //运行于启动/停止模式
       
        AdcRegs.ADCTRL1.bit.SEQ_CASC=1;
        //级联方式
       
        AdcRegs.ADCTRL3.bit.ADCBGRFDN=3;
        for(i=0;i<10000;i++)        NOP;
        AdcRegs.ADCTRL3.bit.ADCPWDN=1;
        for(i=0;i<5000;i++)        NOP;
       
        AdcRegs.ADCTRL3.bit.ADCCLKPS=15;
        //ADCLK=HSPCLK/30
       
        AdcRegs.ADCTRL3.bit.SMODE_SEL=0;
        //采用顺序采样模式
       
        AdcRegs.MAX_CONV.bit.MAX_CONV=15;
        //总共采样16路
       
        AdcRegs.CHSELSEQ1.bit.CONV00=0;
        AdcRegs.CHSELSEQ1.bit.CONV01=1;
        AdcRegs.CHSELSEQ1.bit.CONV02=2;
        AdcRegs.CHSELSEQ1.bit.CONV03=3;
       
        AdcRegs.CHSELSEQ2.bit.CONV04=4;
        AdcRegs.CHSELSEQ2.bit.CONV05=5;
        AdcRegs.CHSELSEQ2.bit.CONV06=6;
        AdcRegs.CHSELSEQ2.bit.CONV07=7;
       
        AdcRegs.CHSELSEQ3.bit.CONV08=8;
        AdcRegs.CHSELSEQ3.bit.CONV09=9;
        AdcRegs.CHSELSEQ3.bit.CONV10=10;
        AdcRegs.CHSELSEQ3.bit.CONV11=11;
       
        AdcRegs.CHSELSEQ4.bit.CONV12=12;
        AdcRegs.CHSELSEQ4.bit.CONV13=13;
        AdcRegs.CHSELSEQ4.bit.CONV14=14;
        AdcRegs.CHSELSEQ4.bit.CONV15=15;
       
        AdcRegs.ADC_ST_FLAG.bit.INT_SEQ1_CLR=1;
        //清除SEQ1中的中断标志位INT_SEQ1
       
        AdcRegs.ADC_ST_FLAG.bit.INT_SEQ2_CLR=1;       
        //清除SEQ2中的中断标志位INT_SEQ2
       
        AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ=0;
        AdcRegs.ADCTRL2.bit.RST_SEQ1=0;
        AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1=1;
        AdcRegs.ADCTRL2.bit.INT_MOD_SEQ1=0;
        AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1=0;
        AdcRegs.ADCTRL2.bit.EXT_SOC_SEQ1=0;
        AdcRegs.ADCTRL2.bit.RST_SEQ2=0;
        AdcRegs.ADCTRL2.bit.SOC_SEQ2=0;
        AdcRegs.ADCTRL2.bit.INT_ENA_SEQ2=0;
        AdcRegs.ADCTRL2.bit.INT_MOD_SEQ2=0;
        AdcRegs.ADCTRL2.bit.EVB_SOC_SEQ2=0;
        AdcRegs.ADCTRL2.bit.SOC_SEQ1=1;
ADCINA0-7,ADCINB0-7,ADCLO 都接DGND,存储ad转换的寄存器值不为0,adcin引脚接0-3V的电压,寄存器的值也不变,是什么原因,求好心人赐教,谢谢!

自己顶起来!

1.没有看到你的全部的程序,你先运行下例程,确定是不是你的DSP的AD模块坏了
2.ADCLO是接模拟地的,

请问nop;在这里表示的是什么意思

看下你的AD结果存在哪里了
取结果是否正确,每个ADC要放到对应通道里
QQ:1448335370 淘宝搜索店铺:蜀山科技

小编好人

请问这个问题小编解决了,我也遇到了,B0的采样结果一直就是这样!

Copyright © 2017-2020 微波EDA网 版权所有

网站地图

Top