User manual

Table Of Contents
Zynq-7000 AP SoC Technical Reference Manual www.xilinx.com 374
UG585 (v1.11) September 27, 2016
Chapter 13: SD/SDIO Controller
If the Block Count Enable bit in the Transfer Mode register is set to 1, the total data length can
be designated by the Block Count register and the descriptor table. These two parameters shall
indicate same data length. However, transfer length is limited by the 16-bit Block Count register.
If the Block Count Enable bit in the Transfer Mode register is set to 0, the total data length is
designated not by Block Count register, but the descriptor table. In this case, if the ADMA reads
more data than the length programmed in the descriptor from the SD card, the operation is
aborted asynchronously and the extra read data is discarded when the ADMA is completed.
5. Set the argument value to the Argument register.
6. Set the value to the Transfer Mode register. The host driver determines Multi/Single Block Select,
Block Count Enable, Data Transfer Direction, Auto CMD12 Enable and DMA Enable. Multi/Single
Block Select and Block Count Enable are determined according to SDIO register map.
7. Set the value to the Command register.
Note: When writing to the upper byte [3] of the Command register, the SD command is issued
and DMA is started.
8. Wait for the command complete interrupt.
9. Write a 1 to the Command Complete bit in the Normal Interrupt Status register to clear this bit.
10. Read the Response register and get the necessary information from the issued command.
11. Wait for the transfer complete interrupt and ADMA error interrupt.
12. If the Transfer Complete is set to 1, go to Step (13). If the ADMA Error Interrupt is set to 1, go to
Step (14).
13. Write a 1 to the Transfer Complete Status bit in the Normal Interrupt Status register to clear this
bit.
14. Write a 1 to the ADMA Error Interrupt Status bit in the Error Interrupt Status register to clear this
bit.
15. Abort ADMA operation. SD card operation should be stopped by issuing an abort command. If
necessary, the host driver checks the ADMA Error Status register to detect why the ADMA error
is generated.
Note: Step (3) and Step (4) can be executed simultaneously. Step (6) and Step (7) can also be
executed simultaneously.
Note: During ADMA2 operation, the controller will not generate a DMA interrupt if the INT attribute
is set along with NOP, RSVD, or LINK attribute.
13.3.5 Abort Transaction
An abort transaction is performed using CMD12 for a SD memory card and by using CMD52 for a
SDIO card. There are two cases where the HD needs to do an abort transaction:
When the HD stops infinite block transfers.
When the HD stops transfers while a multiple block transfer is executing.
There are two ways to issue an abort command. The first is an asynchronous abort. The second is a
synchronous abort. In an asynchronous abort sequence, the HD can issue an abort command at
anytime unless the Command Inhibit (CMD) bit in the Present State register is set to 1. In a
synchronous abort, the HD issues an abort command after the data transfer stopped via the Stop At
Block Gap Request bit in the Block Gap Control register.