684
SAM4CP [DATASHEET]
43051E–ATPL–08/14
3.
4.
5.
6.
7.
8.
9.
Start the transfer by setting the PDC TXTEN bit.
Wait for the PDC ENDTX Flag either by using the polling method or ENDTX interrupt.
Disable the PDC by setting the PDC TXTDIS bit.
Wait for the TXRDY flag in TWI_SR.
Set the STOP bit in TWI_CR.
Write the last character in TWI_THR.
(Optional) Wait for the TXCOMP flag in TWI_SR before disabling the peripheral clock if required.
Data Receive with the PDC
The PDC transfer size must be defined with the buffer size minus 2. The two remaining characters must be managed
without PDC to ensure that the exact number of bytes are received regardless of system bus latency conditions
encountered during the end of buffer transfer period.
In slave mode, the number of characters to receive must be known in order to configure the PDC.
1.
Initialize the receive PDC (memory pointers, transfer size - 2).
2.
Configure the master (DADR, CKDIV, MREAD = 1, etc.).
3.
Set the PDC RXTEN bit.
4.
(Master Only) Write the START bit in the TWI_CR to start the transfer.
5.
Wait for the PDC ENDRX Flag either by using polling method or ENDRX interrupt.
6.
Disable the PDC by setting the PDC RXTDIS bit.
7.
Wait for the RXRDY flag in TWI_SR.
8.
Set the STOP bit in TWI_CR.
9.
Read the penultimate character in TWI_RHR.
10. Wait for the RXRDY flag in TWI_SR.
11. Read the last character in TWI_RHR.
12. (Optional) Wait for the TXCOMP flag in TWI_SR before disabling the peripheral clock if required.
34.7.3.8 SMBUS Quick Command (Master Mode Only)
The TWI interface can perform a Quick Command:
1.
Configure the master mode (DADR, CKDIV, etc).
2.
Write the MREAD bit in the TWI_MMR at the value of the one-bit command to be sent.
3.
Start the transfer by setting the QUICK bit in the TWI_CR.
Figure 34-15. SMBUS Quick Command
TXCOMP
TXRDY
Write QUICK command in TWI_CR
TWD
A
S
DADR
R/W
P