MAX11800–MAX11803
master-generated 9th clock pulse if the previous byte is
successfully received. Monitoring ACK allows for detec-
tion of unsuccessful data transfers. An unsuccessful
data transfer occurs if a receiving device is busy or if a
system fault has occurred. In the event of an unsuc-
cessful data transfer, the bus master retries communica-
tion. The master pulls down SDA during the 9th clock
cycle to acknowledge receipt of data when the
MAX11801/MAX11803 are in read mode. An acknowl-
edge is sent by the master after each read byte to allow
data transfer to continue. A not-acknowledge is sent
when the master reads the final byte of data from the
MAX11801/MAX11803, followed by a STOP condition.
Write Data Format
A minimum write sequence to the MAX11801/
MAX11803 includes transmission of a START condition,
the slave address with the R/W bit set to 0, 1 byte of
data to select the internal register address pointer, 1
byte of data written to the selected register, and a
STOP condition. Figure 25 illustrates the proper frame
format for writing 1 byte of data to the MAX11801/
MAX11803. Figure 26 illustrates the frame format for
writing N-bytes of data to the MAX11801/MAX11803.
The slave address with the R/W bit set to 0 indicates
that the master intends to write data to the
MAX11801/MAX11803. The MAX11801/MAX11803
acknowledge receipt of the address byte during the
master-generated 9th SCL pulse.
The second byte transmitted from the master config-
ures the MAX11801/MAX11803’s internal register
address pointer. The pointer tells the MAX11801/
MAX11803 where to write the next byte of data. Note
that the MAX11801/MAX11803 use a 7-bit register
pointer format, and the selection should be left-justified
within the register byte (the last bit in the register byte is
a don’t care). An acknowledge pulse is sent by the
MAX11801/MAX11803 upon receipt of the address
pointer data.
The third byte sent to the MAX11801/MAX11803 contains
the data that is written to the chosen register. An
acknowledge pulse from the MAX11801/MAX11803 sig-
nals receipt of the data byte. The MAX11801/
MAX11803 do not support autoincrement in write
mode. However, by repeating multiple register address
byte + data byte pairs (bytes 2 and 3 in Figure 25) the
user can perform multiple register writes within a single
transfer. There is no limit as to how many registers
the user can write with a single command sequence,
but only commands listed as “pairable” can be
sequenced in this manner. For example, the I2C master
can perform multiple register writes to set up all required
conversion options and then issue a separate I2C com-
mand to start a conversion process. Figure 26 illustrates
how to write to multiple registers with one frame. The
master signals the end of transmission by issuing a
STOP condition. Register addresses greater than 0x0B
are reserved. Do not write to these addresses.
Low-Power, Ultra-Small Resistive Touch-Screen
Controllers with I2C/SPI Interface
42
______________________________________________________________________________________
START
WRITE ADDRESS
BYTE 1: DEVICE ADDRESS
WRITE REGISTER NUMBER
BYTE 2: REG NUMBER = N
WRITE DATA
BYTE 3: REG(N)[7:0] DATA
STOP
W
N3 N2 N1 N0
X
D
N4
1
0
1
0
A1 A0
N5
N6
Z
X
D
Z
WRITE DATA
BYTE 5: REG(Z)[7:0] DATA
WRITE REGISTER NUMBER
BYTE 4: REG NUMBER = Z
SDA
SCL
A
AA
A
ACKNOWLEDGE GENERATED BY I2C MASTER
ACKNOWLEDGE GENERATED BY MAX11801/MAX11803
Figure 26. I2C Multiple Write Sequence
SCL
W
N3 N2 N1 N0
X
D
START
SDA
WRITE ADDRESS
BYTE 1: DEVICE ADDRESS
WRITE REGISTER NUMBER
BYTE 2: FIRST REG NUMBER = N
WRITE DATA
BYTE 3: REG(N)[7:0] DATA
STOP
N4
1
0
1
0
A1
A0
N5
N6
AA
A
ACKNOWLEDGE GENERATED BY I2C MASTER
ACKNOWLEDGE GENERATED BY MAX11801/MAX11803
Figure 25. I2C Single Write Sequence