## ATmega48P/88P/168P/328P

the Master to switch between Slaves, Master Transmitter mode and Master Receiver mode without losing control over the bus.

Table 19-3. Status codes for Master Receiver Mode

| Status Code<br>(TWSR)<br>Prescaler Bits<br>are 0 | Status of the 2-wire Serial Bus<br>and 2-wire Serial Interface<br>Hardware | Application Software Response |         |     |           |          |                                                                                                        |
|--------------------------------------------------|----------------------------------------------------------------------------|-------------------------------|---------|-----|-----------|----------|--------------------------------------------------------------------------------------------------------|
|                                                  |                                                                            | To/from TWDR                  | To TWCR |     |           |          |                                                                                                        |
|                                                  |                                                                            |                               | STA     | STO | TWIN<br>T | TWE<br>A | Next Action Taken by TWI Hardware                                                                      |
| 0x08                                             | A START condition has been transmitted                                     | Load SLA+R                    | 0       | 0   | 1         | Х        | SLA+R will be transmitted<br>ACK or NOT ACK will be received                                           |
| 0x10                                             | A repeated START condition has been transmitted                            | Load SLA+R or                 | 0       | 0   | 1         | Х        | SLA+R will be transmitted                                                                              |
|                                                  |                                                                            | Load SLA+W                    | 0       | 0   | 1         | Х        | ACK or NOT ACK will be received SLA+W will be transmitted Logic will switch to Master Transmitter mode |
| 0x38                                             | Arbitration lost in SLA+R or NOT ACK bit                                   | No TWDR action or             | 0       | 0   | 1         | Х        | 2-wire Serial Bus will be released and not addressed                                                   |
|                                                  |                                                                            | No TWDR action                | 1       | 0   | 1         | Х        | Slave mode will be entered A START condition will be transmitted when the bus becomes free             |
| 0x40                                             | SLA+R has been transmitted;<br>ACK has been received                       | No TWDR action or             | 0       | 0   | 1         | 0        | Data byte will be received and NOT ACK will be returned                                                |
|                                                  |                                                                            | No TWDR action                | 0       | 0   | 1         | 1        | Data byte will be received and ACK will be returned                                                    |
| 0x48                                             | SLA+R has been transmitted;                                                | No TWDR action or             | 1       | 0   | 1         | Х        | Repeated START will be transmitted                                                                     |
|                                                  | NOT ACK has been received                                                  | No TWDR action or             | 0       | 1   | 1         | Х        | STOP condition will be transmitted and TWSTO Flag will be reset                                        |
|                                                  |                                                                            | No TWDR action                | 1       | 1   | 1         | Х        | STOP condition followed by a START condition will be transmitted and TWSTO Flag will be reset          |
| 0x50                                             | Data byte has been received;<br>ACK has been returned                      | Read data byte or             | 0       | 0   | 1         | 0        | Data byte will be received and NOT ACK will be returned                                                |
|                                                  |                                                                            | Read data byte                | 0       | 0   | 1         | 1        | Data byte will be received and ACK will be returned                                                    |
| 0x58                                             | Data byte has been received;<br>NOT ACK has been returned                  | Read data byte or             | 1       | 0   | 1         | X        | Repeated START will be transmitted                                                                     |
|                                                  |                                                                            | Read data byte or             | 0       | 1   | 1         | X        | STOP condition will be transmitted and TWSTO Flag will be reset                                        |
|                                                  |                                                                            | Read data byte                | 1       | 1   | 1         | Х        | STOP condition followed by a START condition will be transmitted and TWSTO Flag will be reset          |

