本帖最后由 pla155 于 2019-8-6 08:15 编辑
7 ]& K$ O3 W1 G+ D6 G% f( {9 Z
( \3 S. r) L9 C* hIIC总体特征 Ø SDA和SCL都是双向线路,通过一个电流源或上拉电阻连接到正的电源电压。 Ø 当总线空闲时这两条线路都是高电平。 Ø 连接到总线的器件输出级必须是漏极开路或集电极开路才能执行线与的功能。 Ø 总线上数据的传输速率在标准模式下可达100kbit/s,在快速模式下可达400kbit/s,在高速模式下可达3.4Mbit/s。 Ø 在SCL线是高电平期间SDA线上的数据必须保持稳定。 Ø 在SCL线是低电平期间SDA线的高或低电平状态可以改变。 Ø 在SCL线是高电平期间SDA线从高电平向低电平切换表示起始信号。 Ø 在SCL线是高电平期间SDA线从低电平向高电平切换表示停止信号。 Ø 发送到SDA线上的每个字节必须为8位。 Ø 首先传输的是数据的最高位。 Ø 每次传输可以发送的字节数量不受限制。 Ø 每个字节传输后必须从机需给一个响应位。 Ø 响应时钟脉冲SCL由主机产生。 Ø 在响应的时钟脉冲期间主机释放SDA线(高电平)。 Ø 在响应的时钟脉冲期间从机需将SDA线拉低并保持稳定。 Ø 如果从机不能立刻接收或发送下数据字节,可以使时钟线SCL保持低电平迫使主机进入等待状态。当从机准备好后,应该释放时钟线SCL。
# w0 q; ?4 y& I4 C' o1 \第一个字节的位定义 第一个字节的头7位组成了从机地址。最低位LSB是第8位它决定了报文的方向。最低位是0 表示主机写信息到被选中的从机,最低位是1 表示主机向从机读信息。 6 F. O4 u% f3 F* x
0 R K, G8 c/ v9 Q. X4 s
对应这个驱动芯片,也就是很简单的三个函数。
/ f, F- _: o" b, E& i2 _( {$ z启动总线函数
; z8 X+ E, g+ ~: h+ A// extern void IIC_START( void );
# ?2 f9 U" t: ]* D( Z/ H$ J RSEG ?PR?IIC_START?IIC) e. ~4 y* o- l$ }
IIC_START:
1 B/ e* P% ?1 h7 I3 D SETB IIC_SDA
& ~) K/ c# ?, I/ c7 _0 p. H m_IIC_CLK$ Q+ ~) D1 o/ p5 k7 U) w$ ?3 K/ T' a
SETB IIC_SCL
0 R0 f R+ |2 I* L m_IIC_CLK
+ I3 v1 h' W& h( I4 \4 K CLR IIC_SDA
# v" M1 w* i. O m_IIC_CLK
6 F4 Z' ]- k4 O! M: n. B CLR IIC_SCL+ n* x& f% p4 {; N& x7 m& r; i* H
RET2 R2 |: z% w+ S1 u
;---------------------------------------
7 z9 f m* p$ V' X3 P: L: I7 [: ^: k0 u0 g0 i& Y
4 R0 v( l. L8 r& e; [) o$ [1 Q8 J' R结束总线函数
& ?9 G* }/ L4 D g// extern void IIC_STOP( void );" z. I' y& `8 B; ~# _* U, l
RSEG ?PR?IIC_STOP?IIC
7 H0 j; ]/ W9 T3 @: ~9 AIIC_STOP:% m4 U$ N+ X7 J* ]5 c. i
CLR IIC_SDA
3 Z. u7 q0 b" b; V! z1 h m_IIC_CLK
9 t ]4 P% w, r( A1 ^ SETB IIC_SCL
: t. ]7 {+ r* i m_IIC_CLK. q' B7 C: l+ Z. ^' y: l, _
SETB IIC_SDA+ q6 W6 Z3 X. f, v! r
m_IIC_CLK1 r/ }+ y( V' }- j3 }. M, v
m_IIC_CLK5 ?# |/ @! M3 E# @) d' p
RET
3 v4 B) c$ L& [& h, x;-------------------------------------------------------------------------------
: Q; p; c. C9 F* C7 l# k发送数据函数$ _1 }. h7 E1 c6 Y( F
// extern bit IIC_WriteByte( unsigned char cDATA );4 {6 @& V3 h' Y( ?- x: a
RSEG ?PR?_IIC_WriteByte?IIC
: \8 W& G6 z; M/ l4 l* k_IIC_WriteByte:
; e) I& M( y9 {: h1 [ MOV A , R7
3 d& t2 @$ a. N9 F3 {) G) T0 L$ x MOV R7 , #008H
/ o8 ?; a, A3 f9 s0 PJP0_IIC_WriteByte:
5 k: w* V% g& Z2 ?4 Q( G' R) N RLC A ; 首先传输的是数据的最高位
; O* K3 b; }# C& k MOV IIC_SDA , C
3 z. d7 M- A3 `7 J2 @' G3 K m_IIC_CLK
7 O- Y: i" k) N% a! c9 a& b SETB IIC_SCL1 q* l. g& A+ u* |
m_IIC_CLK
% Y7 T! `( I7 X; a! Q; g CLR IIC_SCL+ c0 [* [5 W) |. h) a' Z' P: ]/ V
DJNZ R7 , JP0_IIC_WriteByte
9 ~% y% a( ~% }3 Q, L ;在响应的时钟脉冲期间主机释放SDA线(高电平)! z. D2 L6 U" |$ y, h
m_IIC_CLK
6 s& `* S! I& @" j+ r+ ~2 e) E& | SETB IIC_SDA
, F2 p3 x% Q2 n: T m_IIC_CLK; ?" `" j) p0 F6 M8 L
SETB IIC_SCL
2 c# @4 D2 L6 T# y- t( j1 F# h m_IIC_CLK
- z5 n8 p5 U" t9 G7 _$ x6 @ ; 每个字节传输后必须从机需给一个响应位
; W: ~( t+ ]! B5 t MOV C , IIC_SDA
* U% m9 b5 e5 T3 l CLR IIC_SCL$ P: } J* I& `0 J) c
RET' m6 Y8 x# Q, g8 m
7 L+ F1 [& `8 h6 w# ?
6 D# o9 O- ]6 w) v Z3 ]% q& V1 o% j. x6 v& E, E
首先启动IIC总线,然后按照要求发送控制字和数据,最后释放总线。(高电平)
8 q* [5 b6 m) ? |