mirror of
https://github.com/AsahiLinux/u-boot
synced 2024-11-24 21:54:01 +00:00
fs/fat: Fix unaligned __u16 reads for FAT12 access
Doing unaligned reads is not supported on all architectures, use
byte sized reads of the little endian buffer.
Rename off16 to off8, as it reflects the buffer offset in byte
granularity (offset is in entry, i.e. 12 bit, granularity).
Fix a regression introduced in 8d48c92b45
Reported-by: Oleksandr Tymoshenko <gonzo@bluezbox.com>
Signed-off-by: Stefan Brüns <stefan.bruens@rwth-aachen.de>
Tested-by: Oleksandr Tymoshenko <gonzo@bluezbox.com>
This commit is contained in:
parent
a55bed1208
commit
b352caea75
1 changed files with 4 additions and 3 deletions
|
@ -179,7 +179,7 @@ int flush_dirty_fat_buffer(fsdata *mydata)
|
|||
static __u32 get_fatent(fsdata *mydata, __u32 entry)
|
||||
{
|
||||
__u32 bufnum;
|
||||
__u32 off16, offset;
|
||||
__u32 offset, off8;
|
||||
__u32 ret = 0x00;
|
||||
|
||||
if (CHECK_CLUST(entry, mydata->fatsize)) {
|
||||
|
@ -242,8 +242,9 @@ static __u32 get_fatent(fsdata *mydata, __u32 entry)
|
|||
ret = FAT2CPU16(((__u16 *) mydata->fatbuf)[offset]);
|
||||
break;
|
||||
case 12:
|
||||
off16 = (offset * 3) / 2;
|
||||
ret = FAT2CPU16(*(__u16 *)(mydata->fatbuf + off16));
|
||||
off8 = (offset * 3) / 2;
|
||||
/* fatbut + off8 may be unaligned, read in byte granularity */
|
||||
ret = mydata->fatbuf[off8] + (mydata->fatbuf[off8 + 1] << 8);
|
||||
|
||||
if (offset & 0x1)
|
||||
ret >>= 4;
|
||||
|
|
Loading…
Reference in a new issue