mirror of
https://github.com/Fishwaldo/u-boot.git
synced 2025-03-17 12:41:32 +00:00
fs/fat: Avoid corruption of sectors following the FAT
The FAT is read/flushed in segments of 6 (FATBUFBLOCKS) disk sectors. The last segment may be less than 6 sectors, cap the length. Signed-off-by: Stefan Brüns <stefan.bruens@rwth-aachen.de> Reviewed-by: Benoît Thébaudeau <benoit.thebaudeau.dev@gmail.com>
This commit is contained in:
parent
c99d1b3ccf
commit
6c1a808052
2 changed files with 13 additions and 10 deletions
|
@ -202,6 +202,7 @@ static __u32 get_fatent(fsdata *mydata, __u32 entry)
|
|||
__u32 fatlength = mydata->fatlength;
|
||||
__u32 startblock = bufnum * FATBUFBLOCKS;
|
||||
|
||||
/* Cap length if fatlength is not a multiple of FATBUFBLOCKS */
|
||||
if (startblock + getsize > fatlength)
|
||||
getsize = fatlength - startblock;
|
||||
|
||||
|
|
|
@ -117,10 +117,11 @@ static int flush_dirty_fat_buffer(fsdata *mydata)
|
|||
if ((!mydata->fat_dirty) || (mydata->fatbufnum == -1))
|
||||
return 0;
|
||||
|
||||
startblock += mydata->fat_sect;
|
||||
/* Cap length if fatlength is not a multiple of FATBUFBLOCKS */
|
||||
if (startblock + getsize > fatlength)
|
||||
getsize = fatlength - startblock;
|
||||
|
||||
if (getsize > fatlength)
|
||||
getsize = fatlength;
|
||||
startblock += mydata->fat_sect;
|
||||
|
||||
/* Write FAT buf */
|
||||
if (disk_write(startblock, getsize, bufptr) < 0) {
|
||||
|
@ -187,8 +188,9 @@ static __u32 get_fatent_value(fsdata *mydata, __u32 entry)
|
|||
__u32 fatlength = mydata->fatlength;
|
||||
__u32 startblock = bufnum * FATBUFBLOCKS;
|
||||
|
||||
if (getsize > fatlength)
|
||||
getsize = fatlength;
|
||||
/* Cap length if fatlength is not a multiple of FATBUFBLOCKS */
|
||||
if (startblock + getsize > fatlength)
|
||||
getsize = fatlength - startblock;
|
||||
|
||||
startblock += mydata->fat_sect; /* Offset from start of disk */
|
||||
|
||||
|
@ -499,15 +501,15 @@ static int set_fatent_value(fsdata *mydata, __u32 entry, __u32 entry_value)
|
|||
__u32 fatlength = mydata->fatlength;
|
||||
__u32 startblock = bufnum * FATBUFBLOCKS;
|
||||
|
||||
fatlength *= mydata->sect_size;
|
||||
startblock += mydata->fat_sect;
|
||||
|
||||
if (getsize > fatlength)
|
||||
getsize = fatlength;
|
||||
/* Cap length if fatlength is not a multiple of FATBUFBLOCKS */
|
||||
if (startblock + getsize > fatlength)
|
||||
getsize = fatlength - startblock;
|
||||
|
||||
if (flush_dirty_fat_buffer(mydata) < 0)
|
||||
return -1;
|
||||
|
||||
startblock += mydata->fat_sect;
|
||||
|
||||
if (disk_read(startblock, getsize, bufptr) < 0) {
|
||||
debug("Error reading FAT blocks\n");
|
||||
return -1;
|
||||
|
|
Loading…
Add table
Reference in a new issue