可编程数字电位器与AVR单片机的通信说明

发布者:ByteWanderer最新更新时间:2013-12-09 来源: eefocus关键字:可编程数字电位器  AVR单片机  通信说明 手机看文章 扫描二维码
随时随地手机看文章

1 引言

  AVR嵌入式单片机具有丰富的硬件、软件资源,其中的串行I2C接口能满足很多应用场合的要求,两个AVR单片机通过I2C总线直接连接就可实现单片机相互通信;AVR单片机还可以和任何具有I2C总线接口的外设直接连接而无须其它硬件电路支持。而X9221系列可编程数字电位器在智能测试设备上应用非常广泛,通过I2C总线可以简单地构成单片机与各种外设之间乃至与计算机之间的通信,建立友好的人机界面联系。硬件设计简单、灵活,只需要将所有设备的SDA和SCL信号线分别并联在一起并加上拉电阻即可,有助于提高设备的自动化水平、可靠性、稳定性及电气装配的工艺性。AVR单片机和X9221系列可编程数字电位器都有内置的E2ROM单元,可以非常方便地为用户保留一些工艺参数;X9221系列电位器0~63级的变化可以将电位器调节到手动无法实现的平滑级别,调节过程中不会产生噪声且寿命长、不受机械振动污染潮湿影响等。

2 X9221系列数字电位器介绍

2.1电气特性及硬件结构原理

  X9221系列电位器共有15种规格型号,有双列直插DIP20和表面贴装SOIC20两种封装。电源电压民品级、工业级为4.5~5.5V,军品级为2.7~5.5V;一组封装芯片内有两个数字电位器,参见图1,X9221系列电位器封装及引脚功能。内置的E2ROM单元,可以在掉电时将数据很好地保存,上电时自动加载到自己的RAM单元,电位器接口是标准的I2C总线,其中的数据寄存器可通过I2C总线进行读写操作;电位器滑动端(VW0/RW0,VW1/RW1)相当于普通电位器中间抽头,是无摩擦"触点"。

        X9221系列电位器总电阻配置有3种阻值2 kΩ、10kΩ、50kΩ,用户可根据自己的设计需求来选型。每一个芯片有A0~A3四位二进制编程的器件地址以区分I2C总线上接入的不同外设,因此,一条总线上最多可接入16个X9221器件。器件内部有两组类型的寄存器"DATA"和"WCR",他们的访问则由串行数据线上的命令字来确定。电阻阵列通过内部编码可以有64种状态,0~63种状态的连续变化,相当于电位器中心抽头从普通电位器的一端滑动到另一端;所有的寄存器都可以通过I2C总线进行双向操作,即可读可写。

  "在线"实时的调节电位器"中间抽头位置"可以有3种方法:通过I2C总线向WCR寄存器写数据(串行加载)、通过对相应的DATA类寄存器直接写数据(并行加载)、以及增量减量命令(下面会讨论到)直接写数据;概念上电位器"中间抽头位置"可以由"WCR"寄存器来替代,其另一类寄存器可以由"DATA"寄存器来替代。[page]

2.2数字电位器I2C总线时序及指令

2.2.1一般I2C总线通信时序

  X9221系列数字电位器其接口是按标准的I2C总线设计的,因此,硬件连接非常简单,只需把串行时钟线SCL、串行数据线SDA与之对应相连即可。其通信完全符合I2C总线协议要求,串行时钟线SCL、串行数据线SDA按照规定的协议产生一序列脉冲串,进而完成传输一组数据的任务。参见图2 I2C总线通信时序。

        X9221系列数字电位器完全以从机的身份出现在I2C总线上,它不可以主机的身份出现在I2C总线上,也就是说对其寄存器的读写操作都受控于主机,这一点一定要在硬件和软件设计上留意。当主机发出"START"信号后,从机(X9221A)芯片即将拉高SDA线,表明放弃数据线权限由主机控制,主机发送一个字节后再由从机(X9221A)芯片自动拉低SDA线,表明数据收到,如果此时从机将SDA线拉不低,表明从机没有正常接受数据,主机必须启动下一个写周期。可以理解为主机每发送一个字节后都会等待一个ACK回答响应信号,否则,主机认为从机(X9221A)没有正常接收数据。

2.2.2 X9221指令表

  表1是X9221所有指令说明,其中前4种指令的正常执行需要在串行数据线上至少有3个步骤:①通过数据线写从机地址;②写指令;③写数据。才能完成一个寄存器的读或写,这4种指令适用于X9221三字节时序格式操作。如果是写在WCR类型的寄存器中,掉电后数据丢失,写在DATA类型的寄存器中,掉电后数据存在其中;全局转换的4种指令的正常执行需要在串行数据线上至少有2个步骤:①通过数据线写从机地址、②写指令,才能完成所有寄存器之间的数据交换,适用于X9221两字节时序格式操作;最后一种"+/-"指令相当于"在线"上下调节电位器中间抽头,比较直观,很好理解。"+/-"指令仅访问WCR类型寄存器,且只是写操作,如果数据线SDA保持高电平,下一个时钟信号SCL周期到来,WCR寄存器数据"+1"。如果数据线SDA保持低电平,下一个时钟信号SCL周期到来,WCR寄存器数据"-1"。然而,不管哪种命令,只要写DATA类型的寄存器(芯片内的E2ROM存储单元),写操作要花费大约10 ms时间才能完成,在设计通信软件时一定要特别留意。

3 AVR系列单片机与数字电位器硬件和软件设计

3.1 X9221数字电位器与AVR系列单片机硬件接口

  X9221数字电位器与AVR系列单片机硬件接口如图3所示。硬件连接非常简单,只需将所有设备串行数据线SDA、串行时钟线SCL相连接并接10 kΩ左右的上拉电阻即可。连接在I2C总线上的逻辑电平为"线与"逻辑关系,只要有一个设备将其拉低,总线上即出现低电平,当所有设备总线都悬挂起时呈现高阻状态。主机发送模式就是向其中一个外设写入数据,首先产生一个启动信号"START","START"发送成功后才向外设发送设备地址,地址发送成功后,再发送数据,数据可以是1~N个字节,所有数据发送完成,最后发送"STOP"完成主机写的过程。主机接收模式也是一样的,过程类似。对X9221来说地址发送完成后,必须发送指令模式,告诉X9221目前将做什么,指令的含义上面已提到,指令模式后是一组数据,其它过程一样。

        为了使I2C总线处于正常状态,所有总线上的设备必须加电,如果有一个设备没有加电,总线将处于不正常工作状态。在总线上有几个设备同时欲将发送数据时,竞争中某主机发现仲裁失败后,应立即回到从机状态或放弃总线请求,保证获取总线控制权的主机正常发送数据;不同的主机有不同的总线时钟频率,通过SCL信号"线与"来保证,即高电平为高电平中最短的,低电平为低电平中最长的,也就是说协议"照顾"了速度最慢的设备;集结在总线上所有的传送必须包含相同数目的数据包,否则,多主机系统中仲裁结果无法定义,这在设计上要特别注意。

3.2 X9221数字电位器与AVR系列单片机通信软件设计

  下面是一个通过查询由atmega16单片机向X9221发送数据的例程,在这个例程中需要注意的是TWINT标志利用软件写"1"进行清零(清除硬件置位标志),而当前发送完成后由硬件自动将TWINT标志置"1",TWINT标志是不能通过硬件清零的;每次通过检查TWINT标志判断当前发送是否完成,通过读取状态寄存器TWSR的值判断发送的数据是否正确。[page]

START:
LDI R16,$A4;设置AVR单片机I2C总线控制寄存器
OUT TWCR,R16;软件清除TWINT标志WAIT1:
IN R16,TWCR;读取控制寄存器TWCR
SBRS R16,7;等待硬件置位TWINT标志
RJMP WAIT1;TWINT标志没置位,循环检查等待
IN R16,TWSR;读取状态寄存器TWSR
ANDI R16,$F8;屏蔽无效位
CPI R16,$08:检查"START"信号是否发送成功
BRNE ERROR;"START"信号发送未成功,转入出错处理
LDI R16,$56;发送X9221器件地址56="5"器件标识,"6"器件地址
OUT TWDR,R16
LDI R16,$84
OUT TWCR,R16;软件清除TWINT标志
IN R16,TWSR
ANDI R16,$F8
CPI R16,$18;检查X9221器件地址是否发送成功
BRNE ERROR;X9221器件地址发送未成功,转入出错处理
LDI R16,$2F;设置所发送的数据(0~63有效,例中为47)
OUT TWDR,R16;数据输出到数据寄存器TWDR
LDI R16,$84
OUT TWCR,R16;软件清除TWINT标志;检查数据"2F"是否发送完成,类似于上述循环继续
.
.
LDI R16,$94;发送"STOP"信号,一次\'$2F\'数据发送完成
OUT TWCR,R16
ERROR:···;出错处理过程
END

  在此例程中,器件的地址对X9221来说为56,其中"5"是器件本身固有的以区别于其它类型的设备,而"6"是设计硬件时规定的,可以是"0~F"任何十六进制数值;例程中AVR单片机仅作为主机使用且向X9221发送数据,其实从X9221中读取当前数据也是一样的。本例程采用查询方式,程序显得繁琐,但是如果采用中断方式的话,程序就会显得简单多,只要标志SREG寄存器中"I"位和I2C总线控制寄存器中的"TEWIE"置"1",即中断使能有效,当"TWINT"标志置"1"立即产生中断请求,表明完成当前数据发送完成,可以准备下一个字节数据发送或停止发送等操作。

4 X9221可编程数字电位器在半导体专用设备一些应用研究

4.1用于测量微小电压变化

  图4是微小电压测量电路模型,用于芯片键合设备中去检测吸头上是否有芯片吸附以及吸头是否堵塞、或者芯片是否丢失等现象。当内径为大约0.1~0.15 mm的吸头去吸附一个小芯片时,如果芯片较透明,光敏传感器检测出来的电压变化较小,一般在10~50 mV间;同样当吸头吸附一个小芯片时,气路真空的压力也会产生变化,这种压力的变化以传感器电压变化输出。为了改变电位器"中间抽头"以便与传感器检测输入电压相匹配,计算机通过RS232接口向单片机发送数据,单片机收到数据后转发给X9221可编程数字电位器以改变基准电压值。比较基准电压U∑+按下式确定:

        U∑+是LM393运放同相输入端电压(在这种状态下,考虑到前级传感器输出基本上处于放大状态,所用传感器电源电压为+5 V,最高输出电压按3.5 V计算)

  N是0~63共64种状态变化值,那么,当U∑+从0~3.5 V变化时,最小分辨率可以达到55 mV左右,用手工进行一般电位器调节达到这样的分辨率是难以掌控的。

  基准电压(即U∑+)通过机器的人机界面可以"直接调节",如果将电位器数值进行标定,随时还可以看到当前的基准电压大小。传感器输出电压与基准电压比较,使电压比较器输出反应当前的状态,不同的时刻高低电平代表不同的意义,如"吸头阻塞"、"芯片丢片"、"真空不足"等。

4.2测量微小电流变化

  图5是微小电流测量电路模型,用于引线键合设备中去检测断线、连线、短路等情况,被测器件是一个半导体元件,当在焊盘上键合上一根金线时,通过检测漏电流来判断这条金线与芯片键合过程中是否存在"断线"、"连线"、"短路"等情况。计算机通过界面操作发送指令以改变X9221可编程数字电位器的阻值,进而改变电压源的放大倍数以改变加在被测元件的电压,从而达到适应不同品种的半导体器件性能要求。

        设:信号源的输出为Us,运放LM324输出为U0,X9221电阻为Rx,被测元件阻抗为Rz,被测元件流过的漏电流为I0,则用以下两个表达即可表达它们之间的关系:

 

        通过主机界面改变Rx可编程电阻值,即可以改变U0,U0的改变等于改变了I0,而I0的改变等于改变了流过被测器件的最大允许电流,从而保护了被测器件不会因为检测漏电流而损坏,通过检测被测器件上施加的电压和U0之差值即可判断漏电流大小,从而检测金线是否与被测器件焊盘点键合上。I0是根据不同器件在工艺参数上需要经常调节的量,以适应不同场合的要求。

5 结束语

  可编程数字电位器的最大优点在于直接可以和带有I2C总线单片机相连而无需特殊设计,上位机可以随机读取电位器当前设定值。利用它的这些优点,可以提高设备仪器的智能化水平,特别是在带有I2C总线的嵌入式单片机中应用十分灵活简单。随着电子技术的飞速发展,人们对设备、仪器以及家用电器的追求已不再仅仅满足功能使用上,而是在产品应用的人性化上要求越来越高,由于大多数自动化设备上,都具有友好的人机界面,人们通过计算机界面想完成所有操作,比如调节一个电位器以调节电流、电压或者电机速度、转矩、频率等物理量,利用可编程数字电位器完全可以通过界面完成。适时采用可编程数字电位器不但可以降低成本、简化电路设计、提高可靠性,而且可以使设计更加人性化。另外,AVR单片机可以通过JTAG接口完成仿真调试、下载程序;片内有FLASH和E2ROM存储单元,有标准的串行接口、I2C总线接口、SPI接口增强了其硬件功能;支持C语言编程,便于掌握C语言者无需太多地了解硬件就能进行一些编程。本文探讨了AVR单片机、X9221可编程数字电位器及其接口和软件编程的一些实际应用,许多问题是笔者在应用中的经验,可能会有些错误,希望读者批评指正。

关键字:可编程数字电位器  AVR单片机  通信说明 引用地址:可编程数字电位器与AVR单片机的通信说明

上一篇:基于AVR单片机的轻触式单键开关电路设计
下一篇:基于AVR单片机的数字滤波器滤除工频干扰的快速算法

推荐阅读最新更新时间:2024-03-16 13:31

AVR单片机串口的波特率设置
公司有一款产品要实现通过串口更新开机画面的功能。产品用的是AVR的ATmega8单片机,配有两个通用同步和异步串行接收器和转发器(USART) 。在芯片的数据文档里给出了波特率寄存器UBRR的值的计算公式。 可是实际测试才发现,就算出的值根本不能用。也就是说,用算出的值发出的波特率根本不是想要的波特率。百思不得其解,只好上网搜搜看有没有收获。果然,网上有个仁兄的症状和我一样,也是波特率不对。看了后面的回答,觉得有一个挺靠谱的,大概是说,在用了AVR的内部RC振荡器的情况下,实际波特率会和计算值有偏差。因为芯片的内部RC振荡器频率不像外部晶振的频率那么稳定。 在不增加外部晶振的情况下,如何解决问题呢?在网没有找到什么方法,只好
[单片机]
基于AVR单片机的数控移相信号发生器设计
1 前 言 移相信号发生器属于信号源的一个重要组成部分,但传统的模拟移相有许多不足,如移相输出波形易受输入波形的影响,移相角度与负载的大小和性质有关,移相精度不高,分辨率较低等。而且,传统的模拟移相不能实现任意波形的移相,这主要是因为传统的模拟移相由移相电路的幅相特性所决定,对于方波、三角波、锯齿波等非正弦信号各次谐波的相移、幅值衰减不一致,从而导致输出波形发生畸变。目前利用DDS技术产生信号源的方法得到了广泛的应用,但是专用DDS芯片由于采用特定的集成工艺,内部数字信号抖动很小,不可以输出高质量的模拟信号。随着现代电子技术的发展,特别是随单片机和可编程技术的发展而兴起的数字移相技术却很好地解决了这一问题。在众多的单片机之中,AV
[单片机]
基于<font color='red'>AVR单片机</font>的数控移相信号发生器设计
win7下avr单片机开发环境的搭建
操作系统:win7 professional x86 开发软件:avr studio 4.19 首先下载avr studio 4.19,因为貌似这是atmel官方最后支持jtag ice的开发环境。而且也就只有这个4的版本才支持win7,正好本人有个jtag,所以果断选择这个版本了。 相关软件下载地址: http://www.mcuzone.com/down/List.asp?SB=1012 貌似这个里面有很多常见的工具下载。 刚开始我是用的avr studio 4.19+WinAVR-20100110这个环境搭建的开发环境。 但是问题出现了,编译文件时出现了找不到编译器。出现如下的错误: make: Makefile
[单片机]
win7下<font color='red'>avr单片机</font>开发环境的搭建
AVR单片机、数据采集模块与控制电路设计的智能控制系统
  引言   现场总线作为生产过程自动化发展的重点,对推动自动化技术起到巨大的推动作用,是现代化工业的标志。MODBUS作为现场总线的一种通信协议,它实现了PLC控制器、工控仪表与设备间的通讯和信息交换。具有MODBUS功能的工控仪表虽然应用比较广泛,但是工控仪表和PLC控制器价格较高并且没有形成自主知识产权的产品,阻碍了它的进一步发展。本文从这个问题着手,设计基于MODBUS协议的单片机控制系统,设计合理,价格低廉,自主性强,在工业控制领域具有广泛的应用前景。   1 系统总体设计   系统中计算机PC作为主机,AVR单片机作为从机,采用RS-485工业现场总线通信。由于计算机的串口采用RS232总线标准,因此在主机的串行通
[单片机]
由<font color='red'>AVR单片机</font>、数据采集模块与控制电路设计的智能控制系统
AVR单片机对挖掘机器人的控制设计
引言 挖掘机的出现使人类从繁重的体力劳动中解脱出来,然而传统的挖掘机操作复杂,对操作者的技能要求很高。人们一直谋求更省力、更高效率和更能实现精确轨迹的挖掘作业模式。随着微电子技术的进一步发展,集成电路的集成度和性能提高、价格下降,以微处理器为基础,实现挖掘机的机电一体化、机器人化、智能化进程,已经成为工程项目施工管理的一个重要研究课题与发展方向。本文以挖掘机器人为例,设计一种基于AVR单片机的挖掘机器人控制系统。 1 总体方案设计 挖掘机器人由挖掘机器人本体机械系统、红外传感器组成的传感器系统、直流电机驱动系统、以AVR单片机为核心的控制系统等四部分组成,其基本结构如图1所示。 图1 挖掘机器人的基本结构 挖掘机器人的
[单片机]
<font color='red'>AVR单片机</font>对挖掘机器人的控制设计
AVR单片机控制舵机
什么是舵机: 舵机如下所示: 有三根线,一般依次是地,电源(5V左右),信号(信号的幅值 =3.3V),不清楚各个脚打开舵机一测量就知道了。 2. 其工作原理是: 控制信号由接收机的通道进入信号调制芯片,获得直流偏置电压。它内部有一个基准电路,产生周期为20ms,宽度为1.5ms的基准信号,将获得的直流偏置电压与电位器的电压比较,获得电压差输出。最后,电压差的正负输出到电机驱动芯片决定电机的正反转。当电机转速一定时,通过级联减速齿轮带动电位器旋转,使得电压差为0,电机停止转动。当然我们可以不用去了解它的具体工作原理,知道它的控制原理就够了。就象我们使用晶体管一样,知道可以拿它来做开关管或放大管就行了,至于管内
[单片机]
<font color='red'>AVR单片机</font>控制舵机
感应式电能表的智能化改进
现在使用的电能表可分为三种形式,即感应式电能表、脉冲电能表和电子电能表。感应式电能表由于价格低廉、计量准确而得到广泛使用。它利用金属铝转盘中的感应电流与通有交流电流的固定线圈的磁场相互作用来产生驱动力矩以驱动铝盘旋转,从而得到累计消耗的电能。但感应式电能表由于自身无防盗电功能,随着电力事业的发展,这一缺点给电力部门带来的损失日益突现出来。因此,在感应式电能表的基础上加装防盗电功能,具有一定的现实意义。 1 感应式电能表盗电现象分析 在感应式电能表的使用中,常见的盗电方式有以下几种: (1)在电能表的内部断开电压扣,使得固定线圈内无交流电流通过而不产生磁场,从而使铝盘不能旋转,并最终导致电能表不能对累计消耗的电能进行
[单片机]
感应式电能表的智能化改进
AVR单片机的RTOS-AVRX应用
引 言   随着技术的发展,嵌入式系统的设计及应用对人们的生活产生了很大的影响,并将逐渐改变人们未来的生活方式。在特定的操作系统上开发应用程序,可以使开发人员忽略掉很多底层硬件细节,使得应用程序调试更方便、易于维护、开发周期缩短并且降低开发成本,因而嵌入式操作系统深得开发人员的青睐。   AVR微处理器是Atmel公司开发的8位嵌入式RISC处理器,它具有高性能、高保密性、低功耗、非易失性等优点,而且程序存储器和数据存储器可独立编址,并具有独立访问的哈佛结构。AVR单片机内核有丰富的指令集,通过32个通用寄存器直接与逻辑运算单元相连接,允许在一个周期内一条单一指令访问两个独立的寄存器,这样的结构使代码的执行效率比传统的复杂指令集
[单片机]
小广播
添点儿料...
无论热点新闻、行业分析、技术干货……
设计资源 培训 开发板 精华推荐

最新单片机文章
何立民专栏 单片机及嵌入式宝典

北京航空航天大学教授,20余年来致力于单片机与嵌入式系统推广工作。

换一换 更多 相关热搜器件
随便看看
电子工程世界版权所有 京B2-20211791 京ICP备10001474号-1 电信业务审批[2006]字第258号函 京公网安备 11010802033920号 Copyright © 2005-2024 EEWORLD.com.cn, Inc. All rights reserved