Continue to Site

Welcome to EDAboard.com

Welcome to our site! EDAboard.com is an international Electronics Discussion Forum focused on EDA software, circuits, schematics, books, theory, papers, asic, pld, 8051, DSP, Network, RF, Analog Design, PCB, Service Manuals... and a whole lot more! To participate you need to register. Registration is free. Click here to register now.

How I2C stop condition is achieved after acknowledgement

Status
Not open for further replies.

Richa Verma

Newbie level 5
Newbie level 5
Joined
Jun 9, 2014
Messages
10
Helped
0
Reputation
0
Reaction score
0
Trophy points
1
Visit site
Activity points
72
please help me out in understanding how STOP condition will occur after ACK arrives on SDA line.

After data transmission, ACK occupies SDA line for one clock pulse and data on SDA line, along with ACK, changes when clock is low.(as shown in fig below)

__ _ _ _ _ __ __
SCL __| |__| |__| |__| |__
____ ____ _ _ _ ___
SDA |__| |_ _ _ |_______|

STT < DATA > ACK STP

STT: START
STP: STOP


condition of start bit: SDA line changes from HIGH to LOW level when SCL is HIGH
condition of stop bit: SDA line changes from LOW to HIGH when SCL is HIGH
ACK : SDA at LOW level for one clock cycle(data changes when SCL is at LOW level)

Does SDA remain at LOW level till SCL becomes HIGH(as shown in fig), now SDA will change from LOW to HIGH to attain STOP condition. If so, then ACK will not be of one clock pulse width!

If SDA need not to be stretched till SCL becomes HIGH, then how STOP condition can be achieved?

Thanks in advance!
 

Check this timing diagram...you will get some idea... project3_html_m1e3890dc.gif
 

Status
Not open for further replies.

Similar threads

Part and Inventory Search

Welcome to EDABoard.com

Sponsor

Back
Top