English
Language : 

ATMEGA8_08 Datasheet, PDF (188/308 Pages) ATMEL Corporation – 8-bit with 8K Bytes In-System Programmable Flash
Slave Transmitter
Mode
In the Slave Transmitter mode, a number of data bytes are transmitted to a Master Receiver
(see Figure 84). All the status codes mentioned in this section assume that the prescaler bits are
zero or are masked to zero.
Figure 84. Data Transfer in Slave Transmitter Mode
VCC
Device 1
Device 2
SLAVE
MASTER
Device 3 ........ Device n
R1
R2
TRANSMITTER
RECEIVER
SDA
SCL
To initiate the Slave Transmitter mode, TWAR and TWCR must be initialized as follows:
TWAR
value
TWA6
TWA5
TWA4
TWA3
TWA2
Device’s Own Slave Address
TWA1
TWA0 TWGCE
The upper seven bits are the address to which the Two-wire Serial Interface will respond when
addressed by a Master. If the LSB is set, the TWI will respond to the general call address (0x00),
otherwise it will ignore the general call address.
TWCR
value
TWINT
TWEA
TWSTA TWSTO TWWC
TWEN
–
0
1
0
0
0
1
0
TWIE
X
TWEN must be written to one to enable the TWI. The TWEA bit must be written to one to enable
the acknowledgement of the device’s own slave address or the general call address. TWSTA
and TWSTO must be written to zero.
When TWAR and TWCR have been initialized, the TWI waits until it is addressed by its own
slave address (or the general call address if enabled) followed by the data direction bit. If the
direction bit is “1” (read), the TWI will operate in ST mode, otherwise SR mode is entered. After
its own slave address and the write bit have been received, the TWINT Flag is set and a valid
status code can be read from TWSR. The status code is used to determine the appropriate soft-
ware action. The appropriate action to be taken for each status code is detailed in Table 69. The
Slave Transmitter mode may also be entered if arbitration is lost while the TWI is in the Master
mode (see state 0xB0).
If the TWEA bit is written to zero during a transfer, the TWI will transmit the last byte of the trans-
fer. State 0xC0 or state 0xC8 will be entered, depending on whether the Master Receiver
transmits a NACK or ACK after the final byte. The TWI is switched to the not addressed Slave
mode, and will ignore the Master if it continues the transfer. Thus the Master Receiver receives
all “1” as serial data. State 0xC8 is entered if the Master demands additional data bytes (by
transmitting ACK), even though the Slave has transmitted the last byte (TWEA zero and expect-
ing NACK from the Master).
While TWEA is zero, the TWI does not respond to its own slave address. However, the Two-wire
Serial Bus is still monitored and address recognition may resume at any time by setting TWEA.
This implies that the TWEA bit may be used to temporarily isolate the TWI from the Two-wire
Serial Bus.
188 ATmega8(L)
2486T–AVR–05/08