C8051F020中的ADC应用要素_单片机论文
关键词:片上系统(soc) a/d转换(adc) 特殊功能寄存器(sfr)
c8051f020(简称f020)是美国德州cygnal公司推出的一种混合信号soc型8位单片机。它属于c8051f系列中的f02x子系列。其性能价格比在目前应用领域极具竞争力。f020具有8路12位a/d转换(简称adc)接口和8路8位在线可编程(isp)的adc电路,片上的特殊功能寄存器(简称sfr)有15个与adc的控制相关,它们是:
amux0sl——amux0通道选择寄存器,复位值为00000000;
max0cf——amux0配置寄存器,复位值为00000000;
adc0cf——adc0配置寄存器,复位值为11111000;
adc0cn——adc0控制寄存器,复位值为00000000;
adc0h——adc0数据字msb寄存器,复位值为00000000;
adc0l——adc0数据字lsb寄存器,复位值为00000000;
adc0gth——adc0下限数据高字节寄存器,复位值为11111111;
adc0gtl——adc0下限数据低字节寄存器,复位值为11111111;
adc0lth——adc0上限数据高字节寄存器,复位值为00000000;
adc0ltl——adc0上限数据低字节寄存器,复位值为00000000;
amx1sl——amux1通道选择寄存器,复位值为00000000;
adc1cn——adc1控制寄存器,复位值为00000000;
adc1cf——adc1配置寄存器,复位值为11111000;
adc1——adc1数据字寄存器,复位值为00000000;
ref0cn——基准电压控制寄存器,复位值为00000000。
adc是混合信号控制器的重要功能,如欲在应用编程中得心应手,就必须对其相关的要素有较清晰的整体认识。
1 adc的精度与通道
f020采用tqfp100封装,芯片引脚有8个(引脚18~25)专用于模拟输入,是8路12位adc的输入端。每路12位的转换精度都是其自身的±1lsb(最低位)。实际上,对于12位逐次逼近寄存器型(sar)adc只有1个,在它与各输入端之间有1个具有9通道输入的多路选择开关(可配置模拟多路开关amux)。amux的第9通道连接温度传感器。在f020中,12位adc称为adc0,另有8路8位在系统可编程(isp)的adc电路称为adc1。其8个外接引脚与p1口复用,片内结构与adc0相近,只是转换的位数为8位,转换精度为8位的±1lsb。
adc0端口的每一对均可用编程设置成为分别地单端输入或差分输入。差分输入时的端口配对为0-1、2-3、4-5、6-7,此设置由通道选择寄存器amux0sl的低4位和通道配置寄存器amux0cf的低4位确定。在amx0cf中,位3~0各对应2个引脚通道。位值=0,表示是独立的单端输入(复位值均为单端输入);位值=1,表示是差分输入对。对应amx0cf选差分输入时,amux0sl中只有在选双数(含0)通道时才有效(注:amux0sl低4位为1xxx时,不论amx0cf低4位为何值,均选温度传感器)。
将ref0cn的位3置“1”时,允许使用温度传感器;置“0”时,温度传感器的输出为高阻态。温度传感器的值可用于修正参数的非线性或记录、调整与温度相关的数据。
2 adc的速率与启动
c8051f系列单片机中adc的速率都是可用编程设置的,但最少要用16个系统时钟。一般在转换之前还自动加上3个系统时钟的跟踪/保持捕获时间(>1.5μs)。设置f020内adc速率的方法是通过配置寄存器adcxcf(x为0或1)的位7~3来进行的,其复位值为11111(位7~3=sysclk/clk sar-1)。
一般在启动adc之前都要处于跟踪方式,控制寄存器adcxcn的位6如果为“0”,则一直处于跟踪方式(此时启动4种启动方式都可比跟踪启动快3个系统时钟);如为“1”,则有4种跟踪启动方式可选择,即对adcxcn中的位3~2赋值:00为向adbusy写1时跟踪(软件命令);01为定时器3溢出跟踪;10为cnvstr上升沿跟踪(外部信号);11为定时器2溢出跟踪。
复位时,adcxcn的位7为0,处于关断状态。每次转换结束时,adcxcn的位5为“1”,位4(忙标志)的下降沿触发结构中断,也可用软件查询这些状态位。
3 adc的基准与增益
f020的片内有1个1.2v、15×10 -6/℃的带隙电压基准发生器和1个两倍增益的输出缓冲器。2.4v的基准电压(vref)可通过外引脚分别接入adc0、adc1和dac中。vref对外带载能力为200μa(建议在驱动外部负载时,对地接1个负载电阻)。adc使用偏置时,必须将参考源控制寄存器refccn中的位1置“1”;如果“0”,则关闭内部偏压,此时可通过vref引脚(引脚12)使用外部基准电压,外部基准电压必须小于vav±0.3v(还要大于1v)。不用adc,也不用dac时,可将refxcn的位0置“0”,使缓冲放大器处于省电方式(输出为高阻态)。
设置ref0cn的位4为“0”时,adc0用vref偏置,为“1”时,用dac0输出偏置;设置ref0cn的位3为“0”时,adc1用vref偏置,为“1”时,用av+偏置。
在f020的adc电路中,输入多路选择开关amux后面都带有1个可用编程设置增益的内部放大器(pga)。当各模拟通道之间输入的电压信号范围差距较大时,或需要放大一个具有较大直流偏移的信号时(在差分输入方式,dac可用于提供直流偏移)显得尤为有用。设置的方式是配置adcxcf中的位2~0(000对应pga的增益为1;001对应为2;010对应为4;011对应为8;10x对应为16、11x对应为0.5)。这里的增益对温度传感器信号也起作用。当增益为1时,vtemp=0.002 86(v/℃)(tempc) ℃+0.776v。
4 adc的数据与控制
对应单端输入,adc结果数据字格式为:0v——0000,vref——0fff或fff0。
对应差分输入,adc结果数据字格式为2的补码:vref——07ff,0——0000,-vref——f800或8000。
将adcxcn的位0置“0”可使结果右对齐;置“1”可使结果左对齐。当差分输入时,右对齐产生的多余高位是符号扩展位。
c8051f系列单片机内还设有数据相关窗口中断发生器或称可编程窗口检测器,也叫adc上(下)限数据寄存器adc0g(l)th(l),用后台方式监视一个关键电压。当转换数据位于规定的窗口之内(或之外)时,向控制器申请转换结束中断。要求在窗口之内中断时,上限寄存器lt装入高位窗口数,下限寄存器gt装入低位窗口数;若要求在窗口之外中断时,则在下限寄存器gt中装入高位窗口数,在上限寄存器lt中装入下限窗口数。
复位时,adc部分的状态为:内部电压基准缓冲器关闭、内部偏压关闭、内部传感器关闭、adc禁止、转换结果数据寄存器右对齐、12位的端口均为单端输入、端口指向ain0、sar转换33个系统时钟、内部放大器增益为1、下限数据寄存器为ffffh、上限数据寄存器为0000h。
综合f020中与adc相关的各要素,要想正确应用adc功能,应按下列顺序编程:设置参考电压>设置允许adc>设置跟踪(启动)方式>设定数据对齐>配置通道>选择通道>设置转换时钟和增益>设定窗口检测上、下限>启动转换。操作sfr的顺序(以12位为例)为:ref0ch>adc0cn>amx0c>amux0sl>adc0cf>adc0gth>adc0gtl>adc0lth>adc0ltl>adc0cn或其它启动方式。