# Philips Semiconductors I<sup>2</sup>C Handbook



Quick Overview of general purpose I<sup>2</sup>C Logic Devices

2H 2004

## I<sup>2</sup>C Bus Technical Overview

The I<sup>2</sup>C (Inter-Integrated Circuit) Bus is a two-wire, low to medium speed, communication bus (a path for electronic signals) developed by Philips Semiconductors in the early 1980s. I<sup>2</sup>C was created to reduce the manufacturing costs of electronic products. It provides a low-cost, but powerful, chip-to-chip communication link within these products. Initial applications for I<sup>2</sup>C included volume and contrast control in radios and televisions. Over the past decade, I<sup>2</sup>C has expanded its communications role to include a wide range of applications. Today, I<sup>2</sup>C can be found in a wide variety of computer, industrial, entertainment, medical, and military systems, with almost unlimited growth potential.

#### **Industry Standard**

The "I<sup>2</sup>C Bus Specification," published by Philips Semiconductor, provides a communication protocol definition of the signal activity on the I<sup>2</sup>C Bus. This specification helps instruct semiconductor device manufacturers, and electronic product developers, in the correct use of the technology. The specification is freely available on the Internet (www.semiconductors.philips.com/buses/i2c/).

#### Low Cost

Prior to I<sup>2</sup>C, chip-to-chip communications used many wires in a parallel interface, often requiring ICs (integrated circuits) to have 24, 28, or more pins. Many of these pins were used for inter-chip addressing, selection, control, and data transfers. In a parallel interface, 8 data bits are typically transferred from a sender IC to a receiver IC in a single operation.

I<sup>2</sup>C performs chip-to-chip communications using only two wires in a serial interface, allowing ICs to communicate with fewer pins. The two wires in the I<sup>2</sup>C Bus are called Clock (SCL) and Data (SDA). These two wires carry addressing, selection, control, and data, one bit at a time. The SDA wire carries the data, while the SCL wire synchronizes the sender and receiver during the transfer. ICs that use the I<sup>2</sup>C Bus can perform the same function as their larger parallel interface counterparts, but with far fewer pins. This greatly reduces the size and cost of ICs based on the I<sup>2</sup>C Bus.







A second savings from the two-wire I<sup>2</sup>C Bus design is in printed circuit board (PCB) size and costs. With ICs based on the I<sup>2</sup>C Bus needing far fewer wires (copper traces) for inter-chip communications, circuit boards using I<sup>2</sup>C ICs are greatly reduced in size, complexity, and cost.

#### **More Power**

Although cost savings alone would be enough to make the I<sup>2</sup>C Bus a success, its developers were also charged with creating a powerful communication link. I<sup>2</sup>C meets this challenge by supporting several powerful features.

#### Courtesy of www.mcc-us.com



#### **Master-Slave Hierarchy**

One I<sup>2</sup>C Master, Multiple Slaves

I<sup>2</sup>C devices are classified as master or slave. A device that initiates a message is called a master, while a device that responds to a message is called a slave. A device can be master-only, slave-only, or switch between master and slave, as the application requires.

#### **Multiple Devices**

I<sup>2</sup>C can connect many ICs on just two-wires. Each I<sup>2</sup>C slave device has its own unique slave address. When a master sends a message, it includes the slave address at the beginning of the message. All devices on the bus hear the message, but only the slave that recognizes its own address participates in the transfer.

#### Multi-Master Support

I<sup>2</sup>C also supports multiple master devices on the bus at the same time, a powerful feature that optimizes bus use by keeping bus message traffic to a minimum. To support multiple masters, I<sup>2</sup>C must resolve signal conflicts, should two or more master devices try to talk on the bus at the same time. This feat, called bus arbitration loss detection, allows a master to detect when its bus signals are conflicting with those of another master. A master that detects arbitration loss terminates its use of the bus, allowing the message generated by another master to cross the bus unharmed.



#### Summary

The I<sup>2</sup>C Bus is a time-proven, industry standard, communication protocol used in a wide variety of electronic products. I<sup>2</sup>C is found in products we use every day, like cellular and conventional telephones, computers, and ATMs (automatic teller machines). Its low cost and powerful features make I<sup>2</sup>C ideal for low to medium speed chip-to-chip communications.

I<sup>2</sup>C is supported by a large and growing number of semiconductor and system manufacturers. These companies offer a variety of electronic devices, including memories, input and output devices, sensors of many types, real-time clocks, displays, data entry devices, and much more. I<sup>2</sup>C is an effective technology that can lower product costs and increase product performance.

#### Courtesy of www.mcc-us.com

### Philips I<sup>2</sup>C Logic Products

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

- A/D and D/A Conversion
- Bus Master 8-bit parallel to I<sup>2</sup>C protocol
- Bus repeater, hubs and expansion
- Jumper and DIP switch replacement
- Power, dim and blink LEDs
- General Purpose I/O expansion
- Bus isolation and extension
- Bus multiplexing
- Non-volatile storage -Serial EEPROMs
- System monitoring (temperature/voltage)
- Voltage Level Translations

### **Advanced Family Features:**

- 400 kHz I<sup>2</sup>C operation
- 2.3 to 5.5 V operating supply voltage
- -40 to +85 °C operating temperature
- I<sup>2</sup>C and SMBus compatibility
- Hardware address pins (A<sub>0</sub>, A<sub>1</sub>, A<sub>2</sub>)
- DIP, SO, SSOP, QSOP, TSSOP and
- **HVQFN** packages
- High volume process manufacturing www.semiconductors.philips.com/logic/i2c

## I<sup>2</sup>C Analog to Digital Converter



-Converts signals from digital to analog and analog to digital

- -4 channel Analog to Digital converter
- -1 channel Digital to Analog converter
- -Internal oscillator

-Power On Reset (POR)

#### PCF8591, 100 kHz 4 channel 8 bit ADC

### Parallel Bus to I<sup>2</sup>C Bus Controller



–Serves as an interface between most standard 8-bit parallel-bus microcontrollers/microprocessors and the serial I<sup>2</sup>C bus.

–Allows the parallel bus system to communicate bi-directionally with the I<sup>2</sup>C bus.

-Provides both master and slave functions.

–Communication with the I<sup>2</sup>C bus is carried out on a byte-wise basis using interrupt or polled handshake.

–Controls all the I<sup>2</sup>C bus specific sequences, protocol, arbitration and timing.

-Internal oscillator (PCA9564)

- PCA9564, 400 kHz Parallel Bus to I<sup>2</sup>C Bus Controller
- PCF8584, 100 kHz Parallel Bus to I<sup>2</sup>C Bus Controller

### I<sup>2</sup>C Bus Repeater, Hub and Extenders



-Bi-directional I<sup>2</sup>C drivers, enable designers to isolate the I<sup>2</sup>C bus capacitance, accommodating more I<sup>2</sup>C devices or a longer bus length.

-400 pF load allowed on each segment.

-Different voltages (3.3 V or 5.0 V) allowed on each segment.

-Devices transparent to bus arbitration and contention protocols in a multi-master environment.

-P82B96 allows twisted pair, differential transmission or Opto-Electrical isolation of the I<sup>2</sup>C Bus

- PCA9510/11/12/13/14, I<sup>2</sup>C Hot Swap Bus Buffer
- PCA9515/15A/17, I<sup>2</sup>C Bus Repeater
- PCA9516/16A, 5-Channel I<sup>2</sup>C Hub
- PCA9518, Expandable 5-Channel I<sup>2</sup>C Hub
- P82B96, Dual Bi-Directional Bus Buffer
- P82B715, I<sup>2</sup>C Bus Extender

### I<sup>2</sup>C EEPROM based DIP Switches



-Replacement for jumpers or dip switches.

-I<sup>2</sup>C controlled integrated EEPROM and Multiplexer eliminates need to open equipment to modify jumpers/dip switches by hand.

-Multiplex between the default values or the setting stored in the onboard I<sup>2</sup>C EEPROM register and programmed from the I<sup>2</sup>C bus.

-The non-volatile I<sup>2</sup>C EEPROM register values stay resident even when the device is powered down

- PCA8550, 4-bit Multiplexed/1-bit Latched 5-bit EEPROM
- PCA9559, 5-bit Multiplexed/1-bit Latched 6-bit EEPROM
- PCA9560, Dual 5-bit Multiplexed/1-bit Latched EEPROM
- PCA9561, Quad 6-bit Multiplexed EEPROM

# I<sup>2</sup>C LED Dimmers/Blinkers



-Used for general-purpose LED dimming and blinking. -Internal oscillator, no external components required. -Two user definable blink rates and duty cycles.

-Single transmission to turn LEDs on, off, or blink at one of the two programmable blink rates.

-I<sup>2</sup>C/SMBus not tied up by sending repeated transmissions to blink LEDs.

-Hardware Reset pin.

-High current open drain outputs.

-PCA953x Dimmers vary between 160 Hz and 1.6 seconds

-PCA955x Blinkers vary between 40 Hz and 6.4 seconds

- PCA9530/50, 2-Bit I<sup>2</sup>C/SMBus LED Controller
- PCA9533/53, 4-bit I<sup>2</sup>C/SMBus LED Controller
- PCA9531/51, 8-bit l<sup>2</sup>C/SMBus LED Controller
- PCA9532/52, 16-bit I<sup>2</sup>C/SMBus LED Controller

# I<sup>2</sup>C General Purpose Quasi I/O



-Used for general-purpose input and output (GPIO) extension from the I<sup>2</sup>C/SMBus.

-Connect parallel I/O to the serial I<sup>2</sup>C/SMBus and provide expansion capability for the I/O controller Hub (South Bridge).

-One registers for Quasi Output (upper transistor on for one/half clock cycle):

-Input or Output (value)

-Devices may have Interrupt output pin.

- PCA9500, 8-bit GPIO w/ 2kbit EEPROM
- PCA9501, 8-bit GPIO w/2kbit EEPROM & Interrupt
- PCA9558, 8-bit GPIO w/5-bit DIP Switch & 2kbit EEPROM
- PCF8574/74A, 8-bit I<sup>2</sup>C I/O Port with Interrupt
- PCF8575/75C, 16-bit I<sup>2</sup>C I/O Port with Interrupt

# I<sup>2</sup>C General Purpose True I/O



-Used for general-purpose input and output (GPIO) extension from the I<sup>2</sup>C/SMBus.

-Connect parallel I/O to the serial I<sup>2</sup>C/SMBus and provide expansion capability for the I/O controller Hub. Four sets of registers for true outputs (push-pull outputs):

- -Configuration (Input or Output)
- -Input (Read I/O value)
- -Output (Force output value)
- -Polarity (active high or low)
- PCA9534/54/54A, 8-bit I<sup>2</sup>C and SMBus I/O Port with Int
- PCA9535/55, 16-bit I<sup>2</sup>C and SMBus I/O Port with Interrupt
- PCA9536, 4-bit I<sup>2</sup>C and SMBus I/O Port
- PCA9537, 4-bit I<sup>2</sup>C and SMBus I/O Port with Int & Reset
- PCA9538, 8-bit I<sup>2</sup>C and SMBus I/O Port with Int & Reset
- PCA9539, 16-bit I<sup>2</sup>C and SMBus I/O Port with Int & Reset
- PCA9557, 8-bit I<sup>2</sup>C and SMBus I/O Port with Reset

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



-The SCL/SDA upstream channel fans out to multiple SCx/SDx channels that are selected by the programmable control register.

-The Multiplexers can select none or only one SCx/SDx channels at a time.

-Applications include:

-Address conflict resolution (e.g., SPD EEPROMs on DIMMs).

-I<sup>2</sup>C sub-branch isolation

-l<sup>2</sup>C bus level shifting (e.g., individual SCx/SDx

channels at 5.0 V, 3.3 V, 2.5 V or 1.8 V).

-Interrupt logic provides flag to master

- PCA9540B, 1 to 2-Channel Multiplexer
- PCA9541, 2 to 1 Master Selector with Int Logic & Reset
- PCA9542A, 1 to 2-Channel Multiplexer with Interrupt Logic
- PCA9544A, 1 to 4-Channel Multiplexer with Interrupt Logic
- PCA9547, 1 to 8-Channel Multiplexer with Reset

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



-The SCL/SDA upstream channel fans out to multiple SCx/SDx channels that are selected by the programmable control register.

-The Switches can select individual SCx/SDx channels one at a time, all at once or in any combination through I<sup>2</sup>C commands.

-Applications include:

-Address conflict resolution (e.g., SPD EEPROMs on DIMMs).

-I<sup>2</sup>C sub-branch isolation

-I<sup>2</sup>C bus level shifting (e.g., individual SCx/SDx channels at 5.0 V, 3.3 V, 2.5 V or 1.8 V).

-Hardware Reset provides a means of resetting the bus should it hang up, without rebooting the entire system.

PCA9543A, 1 to 2-Channel Switch with Int Logic and Reset

• PCA9545A, 1 to 4-Channel Switch with Int Logic and Reset

- PCA9546A, 1 to 4-Channel Switch with Reset
- PCA9548A, 1 to 8-Channel Switch with Reset

# I<sup>2</sup>C Serial EEPROM

| Address<br>pointer                 | POR                               | Supply |
|------------------------------------|-----------------------------------|--------|
| 256<br>Byte<br>E <sup>2</sup> PROM | I <sup>2</sup> C-bus<br>interface | SCL    |
|                                    | Sub<br>address<br>decoder         |        |

-Wide voltage range minimizes the number of EEPROMs that need to be in inventory -I<sup>2</sup>C bus is used to read and write information to and from the memory

-Wide voltage range of 2.5 to 5.5V

- -1,000,000 read and write cycles
- -10 year data retention
  - PCA24S08, 1024 x 8-bit EEPROM with security
  - PCF8581(C), 128 x 8-bit CMOS EEPROM
- PCF8582C-2, 256 x 8-bit CMOS EEPROM
- PCF8594C-2, 512 x 8-bit CMOS EEPROM
- PCF8598C-2, 1024 x 8-bit CMOS EEPROM
- PCF85102C-2, 256 x 8-bit CMOS EEPROM
- PCF85103C-2, 256 x 8-bit CMOS EEPROM
- PCF85116-3, 2048 x 8-bit CMOS EEPROM

### I<sup>2</sup>C Temperature and Voltage Sensors



-Hardware monitors use the I<sup>2</sup>C bus to report temperature and/or voltage.

-Some of the temperature monitors include analog input or external sense pins that allow external transistors/diodes to be located in external components (e.g., processors) that sense the temperature much more accurately than if the sensor was mounted externally on the package.

- NE1617A, I<sup>2</sup>C Temperature Monitor
- NE1618, High Accuracy I<sup>2</sup>C Temperature Monitor
- NE1619, I<sup>2</sup>C Temperature and Voltage Monitor
- LM75A, ± 2 °C Digital Temp Sensor and Thermal Watchdog™
- SA56004-X, ±1 °C Accurate, Remote/Local Digital Temperature Sensor with Over Temperature Alarms
- SE95, ± 1 °C Digital Temp Sensor and Thermal Watchdog™

## I<sup>2</sup>C Voltage Level Translator



–Voltage translation between any voltage from 1.0 V to 5.0 V  $\,$ 

-Open drain on both sides with no drive

-Bi-directional with no direction pin

-Reference voltage clamps the input voltage with low propagation delay

–Used for bi-directional translation of I<sup>2</sup>C buses at 3.3V and/or 5 V to the processor I<sup>2</sup>C port at 1.2 V or 1.5 V or any voltage in-between

-BiCMOS process provides excellent ESD performance

- GTL2000, 20-bit Bi-directional Level Translator
- GTL2002, 2-bit Bi-directional Level Translator
- GTL2010, 10-bit Bi-directional Level Translator