Board logo

标题: DSP2812的ADC排序器工作模式 [打印本页]

作者: look_w    时间: 2017-11-18 13:01     标题: DSP2812的ADC排序器工作模式

按照一次转换通道个数分为:同步工作模式(Simultaneous sampling)、顺寻工作模式(sequential sampling),


同步顺寻

同步工作模式:对AB两组中相同偏移量的2个通道同时转换。

顺寻工作模式:转换器对AB两组中的通道按照排序器中定义的排列顺寻转换。

同步工作模式:SEQ1或者SEQ2或者SEQ在对通道转换时,一次转换两个。
顺序工作模式:SEQ1或者SEQ2或者SEQ在对通道转换时,一次只能转换一个通道。



双排序器、级联排序器

双排序器:SEQ1、SEQ2是两个排序器。SEQ1、SEQ2独立工作。可以让SEQ1工作在同步模式下,也可以让SEQ1工作在顺序模式下。SEQ2同样如此。SEQ1工作在同步模式下,对ADCINA和ADCNIB相同偏移通道同步采样,结果放在Result0,Result1中。

排序器SEQ1:

    union ADCCHSELSEQ1_REG ADCCHSELSEQ1; // Channel select sequencing control 1
    union ADCCHSELSEQ2_REG ADCCHSELSEQ2;

ADCCHSELSEQ1、ADCCHSELSEQ2都是16bit的寄存器。

每个寄存器器变量分4section,2个分了8section

排序器2:

    union ADCCHSELSEQ3_REG ADCCHSELSEQ3; // Channel select sequencing control 3
    union ADCCHSELSEQ4_REG ADCCHSELSEQ4; // Channel select sequencing control 4

ADCCHSELSEQ3、ADCCHSELSEQ4都是16bit的寄存器变量。

每个寄存器器变量有4个section。

排序器SEQ1有8个section,排序器SEQ2有8个section

section中数字含义:每个section中填写的是模拟输入通道的编号。最大的通道编号是:16,所以每个section需要4bit。


级联排序器:两个排序器合二为一,组成一个排序器,SEQ由16个section构成。CONV00--CONV15单排续器可以使用EVA、EVB、软件、外部引脚GPIO/XINT2_ADCSOC引脚触发。

双排序器:SEQ1由8个section构成:CONV00-CONV07SEQ2由8个section构成:CONV08-CONV15

相当于两个独立的排序器,SEQ1排序器启动由EVA启动;SEQ2排序器由EVB启动。

通道转换顺序如何确定?

CONV00:中放置的通道第一个被转换,紧接着CONV01中放置的通道被转换,--》CONV02中放置的通道编号的通道被转换。

不论是在双排序,还是单排序,因为SEQ1级别比SEQ2级别高,首先转换完SEQ1的section放置通道编号,然后转换SEQ2中放置的通道编号。

同步模式和顺序模式的区别在于:转换结果在结果寄存器中的放置不同。

只要是同步模式,不论是单排序器还是级联排序器,结果寄存器中的数存放顺序是:RESULT0中存放ADCINA0,RESULT1中存放ADCINB0。
顺序工作模式:RESULT0中存放ADCINA0数值,RESULT1中存放ADCINA1数值....

顺序排序,result0中放置conv00中通道的结果,result1中放置conv01中通道的结果,以此类推...

级联排序:result0中放置conv00中A组的通道结果,result1中放置conv00中B组的通道结果,

ADC转换之前需要配置寄存器,设置转换的通道个数、对那些通道转换、转换次序。

EX转换的通道个数:AdcRegs.ADCMAXCONV.all = 0x0001;       //转换两个通道

EX要进行转换的通道、转换次序:


转换如何开始?

接收到SOC信号之后,ADCASEQSR的SEQ_CNTRAdcRegs.ADCMAXCONV中获得需要转换的通道个数,完成一个减小1;直到SEQ_CNTR中的数字变为0.


转换结束了会发生什么?

如果ADCTRL1的CONT_RUN1,转换重新开始,ADCASEQSRSEQ_CNTRAdcRegs.ADCMAXCONV中获得需要转换的通道个数,....

问题是:必须在第二个转换开始之前,从结果寄存器中取走第一次转换的结果;防止第一次转换结果被覆盖。

如果ADCTRL1的CONT_RUN0,转换停止,SEQ_CNTR保持0.

问题是:排序指针停留在最后一个section,必须使用ADCTRL2RST_SEQ2或者RST_SEQ1位复位排序器。

ADCASEQSR的SEQ_CNTR位在每次变为0,中断标志为都会置位,用户可以在中断响应函数中手动对ADCTRL2的RST_SEQ2或者RST_SEQ1位复位。


转换的最大通道数


级联排序器同步工作模式:(级联同步)

级联排续器顺序工作模式:(级联顺序)

双排序器同步工作模式:(双排序器同步)

双排序器顺序工作模式:(双排序顺序)

双排序器or单排续器影响MAXCONV中设置的数值。

双排序器中的数值=要转换的通道数/2-1

单排续器最大转换通道数值:要转换的通道数-1


单排续器还是双排序器,在ADC控制寄存器1中SEQ_CASC位设置。
同步工作模式还是顺序工作模式在ADC控制寄存器3中的SMODE SEL位设置。默认状况下,ADC工作在双排序器、顺序工作模式。
转换结果:取决于同步模式or顺序模式。
双排序器工作在同步模式下,SEQ1的MAXCONV中存放的数值是0x0033(110011),SEQ1的转换最大通道数是(4-1)对,SEQ2转换的最大通道数是(4-1)




欢迎光临 电子技术论坛_中国专业的电子工程师学习交流社区-中电网技术论坛 (http://bbs.eccn.com/) Powered by Discuz! 7.0.0