The f_lseek function moves the file read/write pointer of an open file object. It can also be used to increase the file size (cluster pre-allocation).
FRESULT f_lseek ( FIL* FileObject, /* Pointer to the file object structure */ DWORD Offset /* File offset in unit of byte */ );
The f_lseek function moves the file R/W pointer of an open file. The offset can be specified in only origin from top of the file. When an offset above the file size is specified in write mode, the file size is increased and the data in the expanded area is undefined. This is suitable to create a large file quickly, for fast write operation. After the f_lseek function succeeded, member fptr in the file object should be checked in order to make sure the R/W pointer has been moved correctry. In case of fptr is not the expected value, either of followings has been occured.
Available when _FS_MINIMIZE <= 2.
// Move to offset of 5000 from top of the file. res = f_lseek(file, 5000); // Move to end of the file to append data res = f_lseek(file, file->fsize); // Forward 3000 bytes res = f_lseek(file, file->fptr + 3000); // Rewind 2000 bytes (take care on overflow) res = f_lseek(file, file->fptr - 2000);
// Cluster pre-allocation (to prevent buffer overrun on streaming write) res = f_open(file, recfile, FA_CREATE_NEW | FA_WRITE); // Create a file res = f_lseek(file, PRE_SIZE); // Pre-allocate clusters if (res || file->fptr != PRE_SIZE) ... // Check if the file size has been increased correctly res = f_lseek(file, DATA_START); // Record data stream without cluster allocation delay ... res = f_truncate(file); // Truncate unused area res = f_lseek(file, 0); // Put file header ... res = f_close(file);