原创 I2C总线在单片机上的实现

2009-8-13 08:55 2034 9 9 分类: MCU/ 嵌入式

摘要:本文介绍了I2C总线的性能、特点以及数据传输和结构,并详细分析了它的应用示例,给出了它在单片机上的具体实现和相应的汇编程序。

9Zf m o V [44606电子园51单片机学习网%rf5~l;t\v d4h

关键词:I2C总线 单片机电子园51单片机学习网4{%A o$Js~z8}vd6m+i

电子园51单片机学习网Ga;V5|%O1\l,O

随着大规模集成电路技术的发展,把CPU和一个单独工作系统所必需的ROM、RAM、I/O端口、A/D、D/A等外围电路集成在一个单片内而制成的单片机或微控制器愈来愈方便。目前,世界上许多公司生产单片机,品种很多。其中包括各种字长的CPU,各种容量的ROM、RAM以及功能各异的I/O接口电路等等,但是,单片机的品种规格仍然有限,所以只能选用某种单片机来进行扩展。扩展的方法有两种:一种是并行总线,另一种是串行总线。由于串行总线的连线少,结构简单,往往不用专门的母板和插座而直接用导线连接各个设备。因此,采用串行线可大大简化系统的硬件设计。PHILIPS公司早在十几年前就推出了 I2C串行总线,利用该总线可实现多主机系统所需的裁决和高低速设备同步等功能。因此,这是一种高性能的串行总线。

;O"U f4l@J'fd F44606电子园51单片机学习网/u$D;m!} d_-P"b

1 I2C总线的硬件结构电子园51单片机学习网,l+y(X7D$i+|%?$z/f


#gVdwn0LS E44606I2C串行总线一般有两根信号线,一根是双向的数据线SDA,另一根是时钟线SCL。所有接到I2C总线设备上的串行数据SDA都接到总线的SDA上,各设备的时钟线SCL接到总线的SCL上。典型的I2C总线结构如图1所示。6136_2009040720084018d2f.gif

xhm B8o@j+e`44606电子园51单片机学习网;mK2TMX(^a6W

为了避免总线信号的混乱,要求各设备连接到总线的输出端时必须是开漏输出或集电极开路输出。设备与总线的接口电路如图2所示。设备上的串行数据线SDA接口电路应该是双向的,输出电路用于向总线上发送数据,输入电路用于接收总线上的数据。而串行时钟线也应是双向的,作为控制总线数据传送的主机,一方面要通过 SCL输出电路发送时钟信号,另一方面还要检测总线上的SCL电平,以决定什么时候发送下一个时钟脉冲电平;作为接受主机命令的从机,要按总线上的SCL 信号发出或接收SDA上的信号,也可以向SCL线发出低电平信号以延长总线时钟信号周期。总线空闲时,因各设备都是开漏输出,上拉电阻Rp使SDA和 SCL线都保持高电平。任一设备输出的低电平都将使相应的总线信号线变低,也就是说:各设备的SDA是“与”关系,SCL也是“与”关系。

O%{~1u'D` ^:a44606

`F0l IZb44606总线对设备接口电路的制造工艺和电平都没有特殊的要求(NMOS、CMOS都可以兼容)。在I2C总线上的数据传送率可高达每秒十万位,高速方式时在每秒四十万位以上。另外,总线上允许连接的设备数以其电容量不超过400pF为限。电子园51单片机学习网5R@v0g mIfya[


GE I;f1_5Fr44606总线的运行(数据传输)由主机控制。所谓主机是指启动数据的传送(发出启动信号)、发出时钟信号以及传送结束时发出停止信号的设备,通常主机都是微处理器。被主机寻访的设备称为从机。为了进行通讯,每个接到I2C总线的设备都有一个唯一的地址,以便于主机寻访。主机和从机的数据传送,可以由主机发送数据到从机,也可以由从机发到主机。凡是发送数据到总线的设备称为发送器,从总线上接收数据的设备被称为接受器。电子园51单片机学习网4`[C3DA8o/Xx4x


&i g{JL6cq%{|44606I2C 总线上允许连接多个微处理器以及各种外围设备,如存储器、LED及LCD驱动器、A/D及D/A转换器等。为了保证数据可靠地传送,任一时刻总线只能由某一台主机控制,各微处理器应该在总线空闲时发送启动数据,为了妥善解决多台微处理器同时发送启动数据的传送(总线控制权)冲突,以及决定由哪一台微处理器控制总线的问题,I2C总线允许连接不同传送速率的设备。多台设备之间时钟信号的同步过程称为同步化。

2t^(`h_&Jk2c44606

Sd[ DM Xo446062 I2C数据传输电子园51单片机学习网(rU/rZr5xQ'A2Q


$b ^*m C'h8t$J d9Os%o44606在I2C 总线传输过程中,将两种特定的情况定义为开始和停止条件(见图3):当SCL保持“高”时,SDA由“高”变为“低”为开始条件;当SCL保持“高”且 SDA由“低”变为“高”时为停止条件。开始和停止条件均由主控制器产生。使用硬件接口可以很容易地检测到开始和停止条件,没有这种接口的微机必须以每时钟周期至少两次对SDA取样,以检测这种变化。电子园51单片机学习网~8]/Qp+JG

电子园51单片机学习网F1Nj#m&x lP\+Y&W6\(m

SDA线上的数据在时钟“高”期间必须是稳定的,只有当SCL线上的时钟信号为低时,数据线上的“高”或“低”状态才可以改变。输出到SDA线上的每个字节必须是8 位,每次传输的字节不受限制,但每个字节必须要有一个应答ACK。如果一接收器件在完成其他功能(如一内部中断)前不能接收另一数据的完整字节时,它可以保持时钟线SCL为低,以促使发送器进入等待状态;当接收器准备好接受数据的其它字节并释放时钟SCL后,数据传输继续进行。I2C数据总线传送时序如图 4所示。

7Kr,YnQju qCM44606

xY t C ]*K44606数据传送具有应答是必须的。与应答对应的时钟脉冲由主控制器产生,发送器在应答期间必须下拉SDA线。当寻址的被控器件不能应答时,数据保持为高并使主控器产生停止条件而终止传输。在传输的过程中,在用到主控接收器的情况下,主控接收器必须发出一数据结束信号给被控发送器,从而使被控发送器释放数据线,以允许主控器产生停止条件。合法的数据传输格式如下:电子园51单片机学习网)fP1Kh,moME N
6136_200904072008402t1MY.gif电子园51单片机学习网'}Xc:Jv4Q G
电子园51单片机学习网qW;NS*v(cT O

    I2C总线在开始条件后的首字节决定哪个被控器将被主控器选择,例外的是“通用访问”地址,它可以在所有期间寻址。当主控器输出一地址时,系统中的每一器件都将开始条件后的前7位地址和自己的地址进行比较。如果相同,该器件即认为自己被主控器寻址,而作为被控接收器或被控发送器则取决于R/W位。

e&Q4@"HL#@o\E6s4g44606电子园51单片机学习网)sG@G:E


csd*Ok5j:k446063 I2C总线的应用电子园51单片机学习网!uQ y i"h~'T


(A%U+|0DG44606I2C总线是各种总线中使用信号线最少,并具有自动寻址、多主机时钟同步和仲裁等功能的总线。因此,使用I2C总线设计计算机系统十分方便灵活,体积也小,因而在各类实际应用中得到广泛应用。下面举二个应用示例。

vwYmpl4vLo44606

J;NKZ'Lr0I `446063.1 伺服控制系统用I2C扩展LCD显示器

1x/B| v7u*a:~s#t,T\J44606

^m0y H@n'n#?t5t9u44606图5是一个伺服系统的结构图。它用8XC752单片机的PWM输出经放大后来驱动电机,电机的转速由测速机测取并直接送到8XC752片内的A/D电路。处理后的有关信息经I2C总线送到LCD驱动芯片PCF8577以驱动64段LCD显示板。

#d/r?1e]#t1Ubt,R1[44606电子园51单片机学习网}%T2Oct$ol

3.2 通用I/O端口作为I2C总线接口电子园51单片机学习网&^ ciVL O;GT


~ O5F'V8A XfG&H_.]X @44606目前,51、96系列的单片机应用很广,但是由于它们都没有I2C总线接口,从而限制了在这些系统中使用具有I2C总线接口的器件。通过对I2C总线时序的分析,可以用51单片机的两根I/O线来实现I2C总线的功能。接I2C总线规定:SCL线和SDA线是各设备对应输出状态相“与”的结果,任一设备都可以用输出低电平的方法来延长SCL的低电平时间,以迫使高速设备进入等待状态,从而实现不同速度设备间的时钟同步。因此,即使时钟脉冲的高、低电平时间长短不一,也能实现数据的可靠传送,可以用软件控制I/O口做I2C接口。下面就是用GMS97C2051的通用I/O口来作为I2C总线接口,并由软件控制实现数据传送的例子,图6为其连线图。电子园51单片机学习网 c8Tu#n[ W


8Ra3eC M Ps44606在单主控器的系统中,时钟线仅由主控器驱动,因此可以用51系列的一根I/O线作为SCL的信号线,将其设备为输出方式,并由软件控制来产生串行时钟信号。在实际系统中使用了P1.3。另一根I/O线P1.2作为I2C总线的串行数据线,可在软件控制下在时钟的低电平期间读取或输出数据。系统传输数据的过程如下:先由单片机发出一个启始数据信号,接着送出要访问器件的7位地址数据,并等待被控器件的应答信号。当收以应答信号后,根据访问要求进行相应的操作。如果是读入数据,则数据线可一直设为输入方式,中间不需要改变SDA线的工作方式,每读入一个字节均应依次检测应答信号;如果是输出数据,则首先将SDA设置为输出方式,当发送完一个字节后,需要改变SDA线为输入方式,此时读入被控器件的应答信号就完成了一个字节的传送。当所有数据传输完毕后,应向SDA发出一个停止信号,以结束该次数据传输。6136_2009040720084030a0t.gif电子园51单片机学习网\.p_Mx {l


-]6{Wf3Q1FEOtrC!j44606下面给出51系列用汇编语言实现启始、停止、读、写、应答的程序,读者也可以根据I2C总线时序在96系列或其它单片机上实现I2C总线接口。电子园51单片机学习网%]S;S(pZx*j2Z


B!J$R(\Nq CQ44606a.启动位程序

'cj,{s)|4IUD`44606电子园51单片机学习网(F5Td:H2qqN/j#c,s/}

ACK:CLR P1.3电子园51单片机学习网\q;mG1^*z;lz O#|

电子园51单片机学习网(] P3c_*Sk

NOP电子园51单片机学习网 d"ZB,u }J


s5r"h8W/yS]'fbE44606NOP

W2P*G%t rr G5~g _44606

Dr Wi0|/Eu Db~44606SETB P1.2

HSsP;k#[Za44606电子园51单片机学习网{O5F o#Ga

NOP

h.z%Oi'b.K/AwC44606

p OR.W Db&`44606NOP电子园51单片机学习网1v h0eC|

电子园51单片机学习网$l#p;X}-G/c i

NOP

j\s(K[?'th:u44606电子园51单片机学习网4AROB\8H:D+X6s

CPL P1.3 ;P1.3=1

]#cp:S&c;TJ|4oI1e44606电子园51单片机学习网 aYp Rb*W

NOP

Qp2Ee4X&fX o3j44606电子园51单片机学习网\dp)c6VXA

NOP

Cw#C2v.?44606电子园51单片机学习网 xRp ]!s+Z3}"P eW-}

NOP

I P'|xfY&C(}44606

u [(x&R-[ ^/| ea44606DENGDAI:JB P1.2,DENGDAI

5SY6e6d|;N k~44606电子园51单片机学习网s!M P+kD6A#V

RET电子园51单片机学习网&XTj&Gj/~

电子园51单片机学习网'PTzapQ6pM5}

b.读数据程序电子园51单片机学习网'H7S)~1~:J})AuI|


Va:UT;Y*^6s{"|44606读字节可以在当前地址读(CURRENT READ),也可以随机读(RANDOM READ),读出数据的最后一个字节后不用加应答信号。

)??5fN,ilmQy_r44606

$c{ {:i'{,bR}44606READ:PUSH 0EH6136_200904072008404Qi8F.gif电子园51单片机学习网R4b r!_` Z


E;DXl[44606CLR P1.4电子园51单片机学习网zF'd+Z,BC6m1j

电子园51单片机学习网*x*F o-}|&~a x8rg

LCALL BSTART ;START电子园51单片机学习网uP g7d.V+n@%J\b


zaw_i44606MOV A,#0A0H ;SEND THE CNOTROL BYTE

(LAV#rut44606电子园51单片机学习网Op?.VCr&j

LCALL SENDBYTE

bS UED'j,~*M44606

/eL9n"V5o[ a44606LCALL ACK电子园51单片机学习网h4bBuU


x y4I P S!V%i u44606MOV A,R1 ;SEND THE ADDRESS

1]+jD m/c44606

@{|A \ XA-w44606LCALL SENDBYTE电子园51单片机学习网R ]3~ l v-J1| A-o

电子园51单片机学习网$WZb DI

LCALL ACK电子园51单片机学习网a`:o"Jq

电子园51单片机学习网4h;Ys8STwW6a

LCALL BSTART ;START

u*c3h.@PY7|4u[G,^44606电子园51单片机学习网 ]F`$u r

MOV A,#0A1H ;SEND THE CNOTROL BYTE电子园51单片机学习网-lp;U#L4E1c?v

电子园51单片机学习网1SP^F#D j r

LCALL SENDBYTE电子园51单片机学习网 C)`4i7K"]Wz^

电子园51单片机学习网a,cH#R.i"Z\/LJC

LCALL ACK电子园51单片机学习网 PN`!Nw%P


LFU2I^A/fx b U4K44606LCALL READBYTE电子园51单片机学习网3d1R,QKq sV

电子园51单片机学习网Yom^`gOh!n

LCALL BSTOP

&CRA#`fd5D\3E$O44606

Gi@RsN44606POP 0EH

)D3y8F%e:k8p D1T0}E44606

5h0l9h#nE:P C44606RET电子园51单片机学习网m5v2nNm9S"vk


(W QA!b q:c(Pj44606送字节程序:电子园51单片机学习网d S8}N5k/jD


AFuDE;k%D)E44606SENDBYTE:PUSH 0EH电子园51单片机学习网,Ar_ibbg

电子园51单片机学习网Vx"BdRT2c

PUSH 00H

^ }fh z:i6v44606电子园51单片机学习网8_WWbb6Nj A

MOV R0,#08H6136_2009040720084050hR3.gif

2Ue4uwH:\W44606电子园51单片机学习网4z3Z j+C?t&N

LOOP1:CLR P1.3

!@)WS(n#|;H44606

mp0QAK44606NOP

3n^ Zh${V.W{{;c44606

K;u6G Y&~l:T0F PD44606NOP

a`:l$lL"A c44606

8tJ*a~ED44606RLC A

HB9C\.vto44606

4PU8V5v@+B/yV44606MOV P1.2,C电子园51单片机学习网D#~8GMZG\

电子园51单片机学习网t3NDZ7T'C9u3N+M

CPL P1.3 ;P1.3=1电子园51单片机学习网O'O r!`V+L


WEo ``'V,Gc,Q44606NOP

9Z4W7L'w \7w B44606

,mr W\!I ONT k44606NOP

un z'oNSM44606

-Fps{:~if},nZ44606DJNZ R0,LOOP1

7Y-_`(rx44606电子园51单片机学习网hZV)J4a1e#} k8O(G#i

POP 00H

8X7Y`5KlHY7\ YP44606

_&xs |7n+je44606POP 0EH

$r \S.xF/H+zg a44606

C(NG7c/`3Uq44606RET电子园51单片机学习网+~/J.Stptg6J:b#R T(g

电子园51单片机学习网3k)Q FBqY[

读字节子程序:

*~L S4| q44606电子园51单片机学习网 kd#QZRrRj

READBYTE:PUSH 0EH电子园51单片机学习网V{5p*J#w5N3{Tj


:N a*F.k'N44606PUSH 00H电子园51单片机学习网 W@9t-do`z$A


G@4vK/m(Tg)Xh44606MOV R0,#08H;READ THE CONTENT电子园51单片机学习网 I,H*@*B I[_


-k[#C*R Bf4UR%o44606CLR A电子园51单片机学习网 n]4Tu6v0Y

电子园51单片机学习网-c] r r%hAkn)j6t

LOOP4:CLR P1.3

8E Kg @ _Dx1M+_44606

.xxs?~9W44606NOP电子园51单片机学习网J!sc-Us|1T


#Hzl:s&`*e44606NOP6136_200904072008406s6KA.gif电子园51单片机学习网1k1j7T!}p&oLxvf

电子园51单片机学习网/s[{n8`~ v

NOP电子园51单片机学习网0O.iPcf%rW

电子园51单片机学习网z8ULZ`]

SETB P1.3 ;P1.3=1

J.ct;G/Vz44606电子园51单片机学习网!i"C4C^A*v,|

MOV C,P1.2

8s1IO$l:P.@lI2U-[44606

2H$Mw#e Z^44606RLC A

K.m}.E {~44606电子园51单片机学习网5o%eq_)yO?,_`

DJNZ R0,LOOP4电子园51单片机学习网Tu Zkp7P


*w7?!WsO U3Y44606MOV R2,A电子园51单片机学习网9CU(x(e cci z @

电子园51单片机学习网Hia.wxHha ?gZ

POP 00H

.v J+[X6BCu8Ed44606电子园51单片机学习网zG r z ^

POP 0EH

r@/h9f @,Bq.B44606

.h9VfrI^$SR44606RET

_%i;?9DHmJX44606

kjT~w,K44606c.写数据程序:电子园51单片机学习网ZOE3v.EE`JXE8\F0y

电子园51单片机学习网\ cIi_ {'~

WRITE:PUSH 0EH电子园51单片机学习网%i9y9nw6\;e


^ qt }:X2C44606CLR P1.4

!n#u p\4R-ee44606

wQ~2b8n/}44606LCALL BSTART电子园51单片机学习网`p(K8_5k x5I

电子园51单片机学习网?,}Y9H {|(y

MOV A,#0A0H电子园51单片机学习网wR_] A q |


/])@H8xYeL44606CLALL SENDBYTE ;SEND THE CONTROL BYTE

J~!xIauss44606电子园51单片机学习网IGZ.k!Y:A\&x

LCALL ACK电子园51单片机学习网 Ex,r F"NP~z%b2M#E


9a+w8C#C e/D:s kp9}j44606MOV A,R1 ;SEND THE ADDRESS

uObxk5BA4y44606

Y/m[%Yp6R!h3d44606LCALL SENDBYTE

/a*I8_ R`44606电子园51单片机学习网{Wlo AJy

LCALL ACK电子园51单片机学习网G+J"I%q_ w`~l#a0?3T

电子园51单片机学习网q_-^ g#p;kXM

MOV A,R2 ;WRITE THE CONTENT

#m;f)Kw[$V+^ gD#}44606电子园51单片机学习网iF&E:lTZW"z;EPQ"^

LCALL SENDBYTE

~I4A?7N7L/Z44606

M7q&TD+xU`44606LCALL ACK

R}FKi,RQ44606电子园51单片机学习网!Uv;M;nr.T E5E

LCALL BSTOP电子园51单片机学习网:r/Vb@ AF8J'H

电子园51单片机学习网CZ ld"t8q }1zu

POP 0EH电子园51单片机学习网-y7a0s'g^


C6PGJ_w ]j}44606RET

-{/J]*aYr44606

;x$?j#Oe7u:K44606连续写的两个字节之间最好是有10ms的延时。当然,也可以进行页写(PAGE WRITE),即一次性连续写8个字节,但采用页写方式时每个字节后要有一个应答信号。电子园51单片机学习网;@@8I4f ?VW-~8f#[.E l/A


.y'u*HlzAW4HY44606d.停止位程序:6136_200904072008407dpK5.gif

E;]I5GQ;V#w^LD44606电子园51单片机学习网A @AlY;C"Ai4wO

BSTOP:CLR P1.3

CwC+P*zc44606

Plt-d)XF d.y44606NOP

;I t'U |{;jT1p:}4ca&|44606

$C+B4ls r2m44606NOP电子园51单片机学习网!}(r7y fe%VL/T


y!lN_3c2B"b'L+zR44606CLR P1.2

BJIl,x,IevI44606电子园51单片机学习网C!L4b)nec Pdu

NOP电子园51单片机学习网D`*Ry4Y)Vr9t#^K

电子园51单片机学习网R`*yZ?6]

NOP

b:a5c7tC7byK44606

F#D]!NQ v f4@(~44606NOP

(ayHV4}2G5S,V-eA{q~44606

R#H?X:wk%j1I(\44606SETB P1.3电子园51单片机学习网N k:o;R| R hv M

电子园51单片机学习网 N0R|$[2[n'~G.^

NOP

?-rGd"X i/{!_44606电子园51单片机学习网%UX!hxBvjI3x%V

NOP

|&m/ays44606

tr;^/A:D2D1m44606NOP

3s$ZB GiG&E_!LN44606电子园51单片机学习网3PJh kt$Z,Sa+~

SETB P1.2电子园51单片机学习网7w!]&Q-b)I


:]#Q*m'l\9VxXh"VX44606RET电子园51单片机学习网 Ps n_X%]*`u0K

PARTNER CONTENT

文章评论0条评论)

登录后参与讨论
EE直播间
更多
我要评论
0
9
关闭 站长推荐上一条 /3 下一条