

## I<sup>2</sup>C Configuration and Protocol

(With modifications by Melinda Agyekum and Steven Nowick)

Presenter: Eugene Ho

Title: "Serial Interfaces, Part Deux- I<sup>2</sup>C and SPI"

Date: December 4, 2002

Website:

http://www.stanford.edu/class/ee281/presentations/aut2002/eugeneho-serialcomm.ppt



## What is I<sup>2</sup>C?



Serial Interfaces, part two

- Shorthand for an "Inter-integrated circuit" bus
- Developed by Philips Semiconductor for TV sets in the 1980's
- I<sup>2</sup>C devices include EEPROMs, thermal sensors, and real-time clocks
- Used as a control interface to signal processing devices that have separate data interfaces, e.g. RF tuners, video decoders and encoders, and audio processors.
- I<sup>2</sup>C bus has three speeds:
  - Slow (under 100 Kbps)
  - Fast (400 Kbps)
  - High-speed  $(3.4 \text{ Mbps}) I^2 C \text{ v.2.0}$
- Limited to about 10 feet for moderate speeds















- 1. Master sends start condition (S) and controls the clock signal
- 2. Master sends a unique 7-bit slave device address
- 3. Master sends read/write bit (R/W) 0 slave receive, 1 slave transmit
- 4. Slave with matching 7-bit device address always sends acknowledge bit (ACK)
- 5. Transmitter (slave or master) transmits 1 byte of data



## I<sup>2</sup>C Protocol (cont.)





- 6. Receiver issues an ACK bit for the byte received
- 7. Repeat 5 and 6 if more bytes need to be transmitted
- 8. Master always sends stop condition (P)

a. For write transaction (master transmitting), master issues stop condition (P) after last byte of data.

b. For read transaction (master receiving), master does not acknowledge final byte, just issues stop condition (P) to tell the slave the transmission is done









Serial Interfaces, part two

- "Clock stretching" when the receiver needs more time to process a bit, it can pull SCL low to keep it from going high a bit longer. This technique is called clock stretching . On SDL low, the transmitter can send its next data value, but this value will not be interpreted as a valid data symbol by the receiver until after the slave is ready to release SCL to go high.
- "General call" broadcast addresses every device on the bus
- 10-bit extended addressing for new designs. 7-bit addresses all exhausted







Serial Interfaces, part two

## I<sup>2</sup>C:

 <u>http://www-us2.semiconductors.philips.com/</u> <u>acrobat/various/</u>

<u>I2C\_BUS\_SPECIFICATION\_1995.pdf</u>

- http://www.esacademy.com/faq/i2c/index.htm
- <u>http://www.embedded.com/story/</u> OEG20020528S0057