F2812 ADC采样顺序
F2812的ADC有16个输入通道,哪一个通道的采样优先级高呢?如果需要对多个信号进行采样,ADC输入选择排序通道寄存器ADCCHSELSEQ,只是选择了对哪个通道进行了采样,怎么对这些输入信号进行优先级划定呢? 你在配置的时候可以设置转换顺序啊 可以设置串行转换和并行转换 void InitAdc(void){
unsigned int i;
AdcRegs.ADCTRL1.bit.RESET=1;//ADC软件复位,改位被置为1后立即自动清零,ADC需要3个周期的复位时间
for(i=0;i<13;i++) NOP; //必须等待12个周期以使复位有效
// AdcRegs.ADCTRL1.bit.RESET=0;//
AdcRegs.ADCTRL1.bit.SUSMOD=3;//11仿真挂起时,立即停止排序器和其他逻辑
AdcRegs.ADCTRL1.bit.ACQ_PS=5;//采样窗口大小
AdcRegs.ADCTRL1.bit.CPS=0; //内核时钟预分频器 0:F=CLK/1 1:F=CLK/2
AdcRegs.ADCTRL1.bit.CONT_RUN=0;//连续运行位 0:启动/停止模式1:连续运行模式
AdcRegs.ADCTRL1.bit.SEQ_CASC=1;//级联排序器工作模式位 0:SEQ1和SEQ2是作为两个对多可选择8个排序器
// 1:SEQ1和SEQ2作为一个最多可选择16个通道的排序器运行
AdcRegs.ADCTRL3.bit.ADCBGRFDN=3;
for(i=0;i<10000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCPWDN=1;//ADC内核模拟电路上电
for(i=0;i<5000;i++) NOP;
AdcRegs.ADCTRL3.bit.ADCCLKPS=10;//内核时钟分频HSPCLK/+1)]
AdcRegs.ADCTRL3.bit.SMODE_SEL=0;//0:连续采样 1:并发采样模式
AdcRegs.MAX_CONV.bit.MAX_CONV=1;//转换8个通道
AdcRegs.CHSELSEQ1.bit.CONV00=0;//设置ADCINA0和ADCINB0的转换
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; //级联排序器的EVB SOC的使能位
AdcRegs.ADCTRL2.bit.RST_SEQ1=0; //排序器1复位位
AdcRegs.ADCTRL2.bit.INT_ENA_SEQ1=1;//SEQ1中断使能位
AdcRegs.ADCTRL2.bit.INT_MOD_SEQ1=0;//中断方式控制位。0:INT SEQ1在每个SEQ1排序结束时都被置位 1:在每两个SEQ1排序结束时才被置位
AdcRegs.ADCTRL2.bit.EVA_SOC_SEQ1=0;//禁止EVA触发启动SEQ1
AdcRegs.ADCTRL2.bit.EXT_SOC_SEQ1=0;//禁止外部信号启动SEQ1
AdcRegs.ADCTRL2.bit.RST_SEQ2=0; //禁止SEQ2复位位
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; //启动SEQ1的转换触发S/W--软件向该位写1
}
我用过的代码 并行方式下的 一次转换A0和BO通道
AdcRegs.CHSELSEQ1.bit.CONV00=0;在并行下表示一次转换A0和B0
如果在串行下只能转换A0 转换顺序接着往下写 zhangmangui 发表于 2013-9-23 22:45 static/image/common/back.gif
void InitAdc(void)
{
unsigned int i;
如果采用串行转换的方式,A0、A1、A2、A3都需要被采样时,先对哪个输入通道进行采样呢?是由ADCCHSELSEQ寄存器决定的吗?即如果
AdcRegs.CHSELSEQ1.bit.CONV00=0;
AdcRegs.CHSELSEQ1.bit.CONV01=1;
AdcRegs.CHSELSEQ1.bit.CONV02=2;
AdcRegs.CHSELSEQ1.bit.CONV03=3;
则采样的顺序为A0、A1、A2、A3,
如果 AdcRegs.CHSELSEQ1.bit.CONV00=3;
AdcRegs.CHSELSEQ1.bit.CONV01=2;
AdcRegs.CHSELSEQ1.bit.CONV02=1;
AdcRegs.CHSELSEQ1.bit.CONV03=0;
则采样的顺序为A3、A2、A1、A0
这样理解对吗? simale 发表于 2013-9-24 09:16 static/image/common/back.gif
如果采用串行转换的方式,A0、A1、A2、A3都需要被采样时,先对哪个输入通道进行采样呢?是由ADCCHSELSEQ ...
嗯( ⊙ o ⊙ )是的
记得AdcRegs.MAX_CONV.bit.MAX_CONV=7;//15;
改过来决定多少个 simale 发表于 2013-9-24 09:16 static/image/common/back.gif
如果采用串行转换的方式,A0、A1、A2、A3都需要被采样时,先对哪个输入通道进行采样呢?是由ADCCHSELSEQ ...
你的理解是对的。
页:
[1]