disk_read

The disk_read function reads data from the storage device.

DRESULT disk_read (
  BYTE pdrv,     /* [IN] Physical drive number */
  BYTE* buff,    /* [OUT] Pointer to the read data buffer */
  DWORD sector,  /* [IN] Start sector number */
  UINT count     /* [IN] Number of sectros to read */
);

Parameters

pdrv
Specifies the physical drive number.
buff
Pointer to the byte array to store the read data. The size of data to be read is sector size * count bytes.
sector
Specifies the start sector number in logical block address (LBA).
count
Specifies number of sectors to read. FatFs specifis with 1 to 128.

Return Value

RES_OK (0)
The function succeeded.
RES_ERROR
Any hard error occured during the read operation and could not recover it.
RES_PARERR
Invalid parameter.
RES_NOTRDY
The disk drive has not been initialized.

Description

The memory address specified by buff is not that always aligned to word boundary because the type of argument is defined as BYTE*. The misaligned read/write request can occure at direct transfer. If the bus architecture, especially DMA controller, does not allow misaligned memory access, it should be solved in this function. There are some workarounds described below to avoid this issue.

Generally, a multiple sector transfer request must not be split into single sector transactions to the storage device, or you will not get good read throughput.

Return