如果缓存功能被使能(DBUF=1),那么某个选定通道上的8个或者10个连续的转换结果会填满数据缓存,当满数据缓存,当缓存被填满时,EOC(转换结束)标志被置位,如果EOCIE位已被置位,则会产生一个中断,然后一个新的转换自动开始。如果某个数据缓存寄存器在被读走之前被覆盖,OVR标志将置1。 上面是数据手册中,介绍的ADC连续转换的功能介绍;用到内部缓存区; 问题是: 1,应该是单片机内部只有10个缓存区,STM8S105;只能对一个通道做连续转换并且缓存10个转换结果。??是不是这样理解; 2,如果是上面的理解正确;如果我想在缓存满后,停止这个通道转换,并且转换到另一个通道? |
测试标签123
IAR FOR ARM和IAR FOR STM8无法共存,
STM8L052,液晶内部电源怎么用?
STM8S103飞线外接芯片,I2C不能得到slaveAddress应答,通讯失败。
STM8S105C6T6 UART2串口,能接收数据,不能发送数据
STM8S105K4 串口2 无奇偶校验,也能接收 偶校验的 数据
在STM8S的IAP使用中断和APP使用中断问题
STM8L151 SMBUS设计
STM8S103F复位异常
STM8L的LCD调试时不亮
通过反复试验得到了一个比较好用的带缓存,带平均滤波的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;
}