《I2C总线数字电位器原理及与单片机的接口设计上课讲义.doc》由会员分享,可在线阅读,更多相关《I2C总线数字电位器原理及与单片机的接口设计上课讲义.doc(22页珍藏版)》请在淘文阁 - 分享文档赚钱的网站上搜索。
1、Good is good, but better carries it.精益求精,善益求善。I2C总线数字电位器原理及与单片机的接口设计-I2C总线数字电位器原理及与单片机的接口设计湘潭工学院信息与电气工程系(411201)黄采伦摘要I2C总线数字电位器是Xicor公司推出的数字电位器中较有代表性的一种,它集许多先进特性于一体,倍受使用者瞩目;本文介绍其特性、工作原理及与单片机的接口技术。关键词数字电位器I2C总线单片机程序模块1引言随着I2C总线应用的日益广泛,兼容I2C总线的接口芯片及存储器的品种也越来越多,其中数字电位器以其调节方便、使用寿命长、受物理环境的影响小、性能稳定等特点,已被广
2、大电子工程技术人员所认识;尤其是在音频产品、控制领域等的应用越来越受到人们的重视。I2C总线数字电位器是美国Xicor公司推出的X9系列数字电位器中较有代表性的一种。它是把几个E2POT非易失性数字电位器集成在一起的单片CMOS微电路,具有二线串行I2C总线接口,易于软件控制,可直接读出、写入滑动端位置,可级联使用等先进特性。本文以X9241为例说明。2结构原理X9241内部包括一个I2C接口和四个数字电位器。每个数字电位器由电阻阵列及与之对应的滑动端计数寄存器WCR、四个8位数据寄存器R0R3等部分构成。其引脚配置如图1所示。2.1电阻阵列每个电阻阵列由63个串联连接的分立的电阻段组成。每个
3、电阻阵列的物理终端等效于机械电位器的固定端(VH和VL输入端)。每个阵列的VH和VL以及每个电阻段之间的接点(即抽头)通过FET开关连接滑动输出端VW;而滑动端VW在电阻阵列中的位置由WCR控制。图1X9241引脚配置图其中VW0、VW1、VW2及VW3分别为四个电位器的滑动端;VL0、VL1、VL2及VL3分别为四个电位器的低端;VH0、VH1、VH2及VH3分别为四个电位器的高端;A0、A1、A2及A3为地址线(用来设置从属地址低4位);SDA及SCL分别为串行数据和串行时钟;VCC及VSS分别为电源和地如果将四个电阻阵列中的两个、三个或四个串联起来可构成127、190或253个抽头的数字
4、电位器。X9241电位器电阻阵列的阻值种类根据后缀的不同而不同。当分别为Y、W、U时,则电阻阵列分别为四个2k、四个10k、四个50k的数字电位器;而当为M时,其内部四个数字电位器阻值分别为2k、10k、10k、50k。2.2滑动端计数寄存器WCR滑动端计数寄存器WCR实际上是一个6位带有译码输出的计数器,用来实现选择六十四选一的FET开关的位置,即控制滑动端在电阻阵列中的位置。WCR是一种易失性存贮器,其内容可通过指令改写,上电时装入数据寄存器R0的内容(注意:此值可能与断电时的值不同)。2.3数据寄存器数据寄存器的内容可由用户读出或写入,其内容可传输到滑动计数寄存器WCR以设置滑动端的位置
5、。每个数字电位器有四个8位非易失性数据寄存器R0R3。2.4串行接口X9241支持I2C串行双向总线的定向规约:实际应用时X9241为从器件,由主机启动数据的传输,并为发送和接收操作提供时钟。数据线SDA和时钟线SCL的信号间关系(起始条件、终止条件及应答条件)见图2。3器件寻址及指令结构3.1器件寻址在起始后,主器件输出它所要访问的从器件地址,该地址的格式如下:0101A3A2A1A0对于X9241来说,这个地址的高4位固定为:0101,低4位由物理的器件地址A0A3输入端状态决定。这样,X9241把串行数据流与地址输入端的状态进行比较,若所有位都比较成功,则该器件在总线上作出一个应答响应。
6、3.2指令结构主器件在发送完起始条件及器件地址,且从器件作出应答之后,送到X9241的下一个字节包括指令及寄存器指针的信息。其格式如下:I3I2I1I0P1P0R1R0其中低4位中前两位(R0和R1)指出四个寄存器中的一个,后两位(P0和P1)选择四个电位器中的哪一个;高4位决定指令,X9241共有9条指令见表1。表1X9241指令指令I3I2I1I0P1P0R1R0功能说明ReadWCR10011/01/0读P1、P0指定的滑动端计数寄存器内容WriteWCR10101/01/0写新值到P1、P0指定的滑动端计数寄存器中ReadDataRegister10111/01/01/01/0读P1、
7、P0和R1、R0指定的寄存器内容WriteDataRegister11001/01/01/01/0写新值到P1、P0和R1、R0指定的寄存器中XFTDataRegistertoWCR11011/01/01/01/0传输由P1、P0和R1、R0指定的寄存器内容到与它相关的WCR中XFTWCRtoDataRegister11101/01/01/01/0传输由P1、P0指定的WCR的内容到R1、R0指定的寄存器中GlobalXFTDataRegistertoWCR00011/01/0传输由R1、R0指定的所有四个数据寄存器的内容到与它们相应的WCR中GlobalXFTWCRtoDataRegiste
8、r10001/01/0传输所有WCR中的内容到与它们相应的由R1、R0指定的数据寄存器中Increment/DecrementWiper00101/01/0使能增加/减少由P1、P0指定的滑动端计数寄存器(WCR)的内容9条指令中包括四条两字节指令,四条三字节指令和一条增加/减少指令。(1)两字节指令:这四条两字节指令用作在WCR与数据寄存器中的一个之间交换数据;这种传输可以发生在四个电位器之一与它们的一个辅助寄存器之间,或全局性地发生在所有四个电位器与它们的一个辅助寄存器之间;操作时序见图2(a)。(2)三字节指令:这四条指令是在主机和X9241之间传输数据,无论是主机与一个数据寄存器或是主
9、机直接与WCR间都可以;这些指令是读、写WCR(即读出、写入选定电位器的当前滑动端的位置)或读、写数据寄存器(即读出、写入选定的非易失性寄存器的内容);操作时序见图2(b)。(3)增加/减少指令:这条指令与其它的指令不同,一旦这条指令发出且X9241已用一个应答来响应后,主机才能够以时钟来触发选定的滑动端升或降一个电阻段;这个操作的命令时序见图2(c)。4电位器的串联方式及控制X9241提供一个把阵列串联起来的机构,可以把一个阵列的六十三个电阻元件与一个相邻阵列的电阻元件串联起来,其控制位在三字节的指令中。对于三字节的指令,其数据字节包括用来定义滑动端位置的6位(LSB)加上高2位:CM(串联
10、方式CaseadeMode)和DW(禁止滑动端DisableWipe)。CM位的状态用来使能或禁止串联方式;当WCR的CM位被置为“0”时,则电位器是正常工作方式;当CM位置“1”,则与它相邻的高序号的电位器串联连接。例如电位器WCR1的位7被置为“1”,则POT1与POT2被串联使用。DW位的状态用于使能或禁止滑动端,当WCR的DW位被置为“0”(或“1”)时,则滑动端被使能(或被禁止),禁止时该滑动端是电气上隔离并且是浮空的,当工作于串联方式时,被串联阵列的VH、VL及滑动端VW这三个输出端必须在电气上与外部连接,除了一个滑动端被使能以外,其余的滑动端必须被禁止。用户可以通过改变WCR的内
11、容来改变滑动端的位置。5与GMS90/97系列单片机的接口图3是X9241与GMS90/97系列单片微机之间的一种有代表性的连接,笔者曾将该连接方法成功地用于音频系统和智能仪表中,作为增益反馈电阻,这样可在宽范围内由软件编程来调整放大器的增益。在实际应用系统设计中,采用I2C总线数字电位器可以收到降低成本、简化电路的效果;然而在数字电位器带来硬件设计简化的同时,却增加了软件的工作量,原因是对其访问需要一套严格而复杂的操作;假如有了接口程序模块,使用I2C总线数字电位器就很方便了。为此,本文给出笔者已成功应用的I2C总线数字电位器与GMS90/97系列单片机的接口程序模块,读者几乎不需改动就可采
12、用;该程序模块略加修改还可用于串行E2PROM的读写。在图3的连接中,GMS97C51单片机的时钟为6MHz。由于只连接一片X9241数字电位器,则地址A3A2A1A0=0000,故X9241的器件地址固定为50H。调用时将直接位02H用作滑动端的增减位,命令字节放30H单元,要写入的数据放32H单元;程序执行结束将读出的数据放31H单元。其模块程序清单如下:图3GMS90/97系列单片机与X9241的典型连接E2POT驱动程序模块RW9241:SCLBITP1.4SDABITP1.5INCDECBIT02H;滑动端的增减位DEVICEDATA50H;器件地址COMMANDEQU30H;命令字
13、节RD_DATAEQU31H;读出的数据WR_DATAEQU32H;写入的数据ACALLSTART_IC;置开始MOVA,#DEVICEACALLWR_BYTE;写器件地址MOVA,COMMAND;根据命令及识别字散转SWAPAANLA,#0FHCJNEA,#09H,XRW1;指令的高4位为09H表示R_WCRAJMPR_WCRXRW1:CJNEA,#0AH,XRW2;指令的高4位为0AH表示W_WCRAJMPW_WCRXRW2:CJNEA,#0BH,XRW3;指令的高4位为0BH表示R_ROM(读寄存器)AJMPR_ROMXRW3:CJNEA,#0CH,XRW4;指令的高4位为0CH表示W_
14、ROM(写寄存器)AJMPW_ROMXRW4:CJNEA,#0DH,XRW5;指令的高4位为0DH表示将寄存器中的值传送到WCRAJMPROM_WCRXRW5:CJNEA,#0EH,XRW6;指令的高4位为0EH表示将WCR中的值传送到寄存器AJMPWCR_ROMXRW6:CJNEA,#01H,XRW7;指令的高4位为01H表示全局寄存器中值传送到WCRAJMPA_ROM_WCRXRW7:CJNEA,#08H,XRW8;指令的高4位为08H表示全局WCR中值传送到寄存器AJMPA_WCR_ROMXRW8:CJNEA,#02H,XRW9;指令的高4位为02H表示指定的WCR增/减AJMPINC_
15、DECXRW9:ACALLSTOP_IC;命令执行完毕,STOP并返回RETIR_WCR:MOVA,COMMAND;读WCR子程序ACALLWR_BYTEACALLRD_BYTEMOVRD_DATA,AACALLACK_ICAJMPXRW9W_WCR:MOVA,COMMAND;写WCR子程序ACALLWR_BYTEMOVA,WR_DATAACALLWR_BYTEAJMPXRW9R_ROM:MOVA,COMMAND;读寄存器子程序ACALLWR_BYTEACALLRD_BYTEMOVRD_DATA,AACALLACK_ICAJMPXRW9W_ROM:MOVA,COMMAND;写寄存器子程序ACA
16、LLWR_BYTEMOVA,WR_DATAACALLWR_BYTEAJMPXRW9ROM_WCR:MOVA,COMMAND;寄存器中数据送WCR子程序ACALLWR_BYTEAJMPXRW9WCR_ROM:MOVA,COMMAND;WCR中数据送寄存器子程序CALLWR_BYTEAJMPXRW9A_ROM_WCR:MOVA,COMMAND;全局寄存器中数据送WCR子程序ACALLWR_BYTEAJMPXRW9A_WCR_ROM:MOVA,COMMAND;全局WCR中数据送寄存器子程序ACALLWR_BYTEAJMPXRW9INC_DEC:MOVR7,#63MOVA,COMMAND;指定的WCR
17、增/减子程序ACALLWR_BYTEJBINCDEC,WCRINCCLRSDASETBSCLJMPIDCWCRINC:CLRSCLSETBSDAIDC:CLRSCLSETBSCLDJNZR7,IDCAJMPXRW9START_IC:SETBSDA;开始子程序SETBSCLCLRSDACLRSCLRETWR_BYTE:MOVB,#08;写字节子程序,共写8位WR_BYTE1:CLRSCLRLCA;向左移位至CYMOVSDA,C;数据输出SETBSCLDJNZB,WR_BYTE1CLRSCLSETBSDASETBSCLJBSDA,$;检测X9241E的应答CLRSCLRETRD_BYTE:MOVB,#08;读字节子程序,共读8位RD_BYTE1:SETBSCLMOVC,SDARLCACLRSCLDJNZB,RD_BYTE1RETSTOP_IC:CLRSDA;停止子程序SETBSCLSETBSDACLRSCLCLRSDARETACK_IC:CLRSDA;应答子程序SETBSCLCLRSCLRET参考文献1NonvolatileDigitalPotentiometerDataBook.Xicor.1996.022詹树仁.GMS90及GMS97系列单片机的工作原理及应用.武汉力源电子股份有限公司,1998.083张积东等.单片机51/98开发与应用.北京电子工业出版社,1994.01-
限制150内