52
JN-DS-JN5142 1v0
© NXP Laboratories UK 2012
15.4 Slave Two-wire Serial Interface
When operating as a slave device, the interface does not provide a clock signal, although it may drive the clock signal
low if it is required to apply clock stretching.
Only transfers whose address matches the value programmed into the interface‟s address register are accepted. The
interface allows both 7 and 10 bit addresses to be programmed, but only responds with an acknowledge to a single
address. Addresses defined as “reserved” will not be responded to, and should not be programmed into the address
register. A list of reserved addresses is shown in Table 9.
Address
Name
Behaviour
0000 000
General Call/Start Byte
Ignored
0000 001
CBUS address
Ignored
0000 010
Reserved
Ignored
0000 011
Reserved
Ignored
0000 1XX
Hs-mode master code
Ignored
1111 1XX
Reserved
Ignored
1111 0XX
10-bit address
Only responded to if 10 bit address
set in address register
Table 9 : List of two-wire serial interface reserved addresses
Data transfer is controlled from the processor bus interface at a byte level, with the processor responsible for taking
write data from a receive buffer and providing read data to a transmit buffer when indicated. A series of interrupt
status bits are provided to control the flow of data.
For writes, in to the slave interface, it is important that data is taken from the receive buffer by the processor before
the next byte of data arrives. To enable this, the interface may be configured to work in two possible backoff modes:
Not Acknowledge mode
– where the interface returns a Not Acknowledge (NACK) to the master if more data
is received before the previous data has been taken. This will lead to the termination of the current data
transfer.
Clock Stretching mode
– where the interface holds the clock line low until the previous data has been taken.
This will occur after transfer of the next data but before issuing an acknowledge
For reads, from the slave interface, the data may be preloaded into the transmit buffer when it is empty (i.e. at the
start of day, or when the last data has been read), or fetched each time a read transfer is requested. When using data
preload, read data in the buffer must be replenished following a data write, as the transmit and received data is
contained in a shared buffer. The interface will hold the bus using clock stretching when the transmit buffer is empty.
Interrupts may be triggered when:
Data Buffer read data is required
– a byte of data to be read should be provided to avoid the interface from
clock stretching
Data Buffer read data has been taken
– this indicates when the next data may be preloaded into the data
buffer
Data Buffer write data is available
– a byte of data should be taken from the data buffer to avoid data backoff
as defined above
The last data in a transfer has completed
– i.e. the end of a burst of data, when a Stop or Restart is seen
A protocol error has been spotted on the interface