The disk_write function is called to write data to the sector(s) of storage device.
DRESULT disk_write ( BYTE pdrv, /* [IN] Physical drive number */ const BYTE* buff, /* [IN] Pointer to the data to be written */ DWORD sector, /* [IN] Sector number to write from */ UINT count /* [IN] Number of sectors to write */ );
The specified memory address is not that always aligned to word boundary because the argument is defined as BYTE*. For more information, refer to the description of disk_read function.
Generally, a multiple sector write request (count > 1) must not be split into single sector transactions to the storage device, or the file write throughput will be drastically decreased.
FatFs expects delayed write function of the disk control layer. The write operation to the media does not need to be completed at return from this function by what write operation is in progress or data is only stored into the write-back cache. But write data on the buff is invalid after return from this function. The write completion request is done by CTRL_SYNC command of disk_ioctl function. Therefore, if a delayed write function is implemented, the write throughput of the filesystem will be improved.
Remarks: Application program MUST NOT call this function, or FAT structure on the volume can be collapsed.
This function is not needed when FF_FS_READONLY == 1.