2.99.20 SDHCx_DmaSetup Function

C

/* x = SDHC instance number (x is applicable only on devices with more than one instances of SDHC) */

void SDHCx_DmaSetup (
	uint8_t* buffer,
	uint32_t numBytes,
	SDHC_DATA_TRANSFER_DIR direction
)

Summary

Sets up the DMA for data tranfers.

Description

The client of the SDHC PLIB must set up the DMA before initiating a data transfer.

Precondition

SDHCx_Initialize() must have been called first for the associated instance.

Parameters

ParamDescription
bufferPointer to the read or write buffer (depending on the direction argument)
numBytesNumber of bytes to read or write
directionDirection of the data transfer, SDHC_DATA_TRANSFER_DIR_READ or SDHC_DATA_TRANSFER_DIR_WRITE.

Returns

None.

Example

uint8_t readBuffer[512];
SDHC_DataTransferFlags transferFlags;

transferFlags.isDataPresent = true;
transferFlags.transferDir = SDHC_DATA_TRANSFER_DIR_READ;
transferFlags.transferType = SDHC_DATA_TRANSFER_TYPE_SINGLE;

// Set up the DMA to read 512 btyes of data
SDHC1_DmaSetup(readBuffer, 512, SDHC_DATA_TRANSFER_DIR_READ);

// Send command to read one block of data from SD card starting at block address 100
SDHC1_CommandSend(17, 100, SDHC_CMD_RESP_R1, transferFlags);

Remarks

None.