STM8S105的连续ADC转换模式怎么理解?
如果缓存功能被使能(DBUF=1),那么某个选定通道上的8个或者10个连续的转换结果会填满数据缓存,当满数据缓存,当缓存被填满时,EOC(转换结束)标志被置位,如果EOCIE位已被置位,则会产生一个中断,然后一个新的转换自动开始。如果某个数据缓存寄存器在被读走之前被覆盖,OVR标志将置1。上面是数据手册中,介绍的ADC连续转换的功能介绍;用到内部缓存区;
问题是: 1,应该是单片机内部只有10个缓存区,STM8S105;只能对一个通道做连续转换并且缓存10个转换结果。??是不是这样理解;
2,如果是上面的理解正确;如果我想在缓存满后,停止这个通道转换,并且转换到另一个通道?
转换完这一次后紧接着转换下一次
通过反复试验得到了一个比较好用的带缓存,带平均滤波的ADC读取方法,提供出来给各位参考。各位大侠欢迎拍砖。
u16 adc_trans(u8 channel)
{
u8 k = 0;
u32 sum_adc = 0;
u16 sum;
ADC_CSR = channel; //选择通道
ADC_CR2|=0x08; // 数据排列,右对齐
//ADC_TDRL=0x20; //初始化ADC程序
ADC_CR1|=0x01|0x02; //将CR1寄存器的最低位置1开启adc转换,开启连续转换
ADC_CR3|=0X80;
for(k=0;k<200;k++); //延时一段时间,至少7uS,保证ADC模块的上电完成
ADC_CR1|=0x01; //再次将CR1寄存器的最低位置1,开启AD转换
while((ADC_CSR & 0x80)!=0x80);// 等待转换结束
//sum = ADC_DR;//直接读取16位数据
ADC_CSR&=(~0x80); //软件清零 转换结束 标志位
ADC_CR1 &= (~0x03); //停止转换
sum_adc = ADC_DB0R + ADC_DB1R + ADC_DB2R + ADC_DB3R + ADC_DB4R + ADC_DB5R + ADC_DB6R + ADC_DB7R + ADC_DB8R + ADC_DB9R;
sum = sum_adc / 10;
return sum;
} 帮顶................
页:
[1]