(dri (a) I/O pin set to be an output with "0" written to it (b) I/O pin set to be an input Figure 9-1 Implementation of open-drain outputs. the clock line is released by the receiver. The open-drain feature is also needed if this PIC will ever become an I<sup>2</sup>C slave to another PIC, in which case it must relinquish control of the SCL line. Figure 9-2 also illustrates that the first eight data bits on the SDA line are sent by the transmitter, whereas the ninth acknowledge bit is a response by the receiver. For example, when the PIC sends out a chip address, it is the transmitter, while every other chip on the I<sup>2</sup>C bus is a receiver. During the acknowledge bit time, the addressed chip is the only one that drives the SDA line, pulling it low in response to the master's pulse on SCL, acknowledging the reception of its chip address. When the byte transfer represents data being returned to the PIC from a peripheral chip, it is the peripheral chip that drives the eight data bits in response to the clock pulses from the PIC. In this case, the acknowledge bit is driven in a special way by the PIC, which is serving as receiver but also as bus master. If the peripheral chip is one that can send the contents of successive internal addresses back to the PIC (e.g., a serial EEPROM), then the PIC completes the reception of each byte and signals a request for the next byte by pulling the SDA line low in acknowledgment. After any number of bytes have been received in this way from the peripheral, the PIC can signal the peripheral to stop any further transfers by *not* pulling the SDA line low in acknowledgment. Figure 9-2 Byte transfe Figure 9-2 also illust of the clock. When the s it initiates the new bit in that bit on the SDA line When the PIC mast it changes SDA after dri it changes SCL and SD<sub>i</sub> I<sup>2</sup>C bus transfers or either another START of the SDA and the SCL litiates a transfer with the in Figure 9-3a. Likewise both SDA and SCL initiathese occurrences are exconsist of a change in the of a byte transfer. The PIC I<sup>2</sup>C bus m slave address followed t transmitted on the bus w sequent bytes will be se The I<sup>2</sup>C bus standa with what looks like a r plus a second 8-bit addiperipheral chips to be d chips having an I<sup>2</sup>C intenot be discussed here. The functions of th peripheral chip. For a pe the PIC will typically we address. Subsequent by the consecutive addresss A message string for begins with a 2-byte me