forked from len0rd/rockbox
The dir code is now reentrant.
git-svn-id: svn://svn.rockbox.org/rockbox/trunk@3184 a1c6a512-1295-4272-9138-f99709370657
This commit is contained in:
parent
ff4da18d1a
commit
38bc30b0d6
2 changed files with 7 additions and 10 deletions
|
@ -253,10 +253,6 @@ struct fat_cache_entry
|
||||||
static char fat_cache_sectors[FAT_CACHE_SIZE][SECTOR_SIZE];
|
static char fat_cache_sectors[FAT_CACHE_SIZE][SECTOR_SIZE];
|
||||||
static struct fat_cache_entry fat_cache[FAT_CACHE_SIZE];
|
static struct fat_cache_entry fat_cache[FAT_CACHE_SIZE];
|
||||||
|
|
||||||
/* sectors cache for longname use */
|
|
||||||
static unsigned char lastsector[SECTOR_SIZE];
|
|
||||||
static unsigned char lastsector2[SECTOR_SIZE];
|
|
||||||
|
|
||||||
static int sec2cluster(unsigned int sec)
|
static int sec2cluster(unsigned int sec)
|
||||||
{
|
{
|
||||||
if ( sec < fat_bpb.firstdatasector )
|
if ( sec < fat_bpb.firstdatasector )
|
||||||
|
@ -1695,7 +1691,7 @@ int fat_getnext(struct fat_dir *dir, struct fat_direntry *entry)
|
||||||
int longarray[20];
|
int longarray[20];
|
||||||
int longs=0;
|
int longs=0;
|
||||||
int sectoridx=0;
|
int sectoridx=0;
|
||||||
static unsigned char cached_buf[SECTOR_SIZE];
|
unsigned char* cached_buf = dir->sectorcache[0];
|
||||||
|
|
||||||
dir->entrycount = 0;
|
dir->entrycount = 0;
|
||||||
|
|
||||||
|
@ -1766,13 +1762,13 @@ int fat_getnext(struct fat_dir *dir, struct fat_direntry *entry)
|
||||||
if ( sectoridx >= SECTOR_SIZE*2 ) {
|
if ( sectoridx >= SECTOR_SIZE*2 ) {
|
||||||
if ( ( index >= SECTOR_SIZE ) &&
|
if ( ( index >= SECTOR_SIZE ) &&
|
||||||
( index < SECTOR_SIZE*2 ))
|
( index < SECTOR_SIZE*2 ))
|
||||||
ptr = lastsector;
|
ptr = dir->sectorcache[1];
|
||||||
else
|
else
|
||||||
ptr = lastsector2;
|
ptr = dir->sectorcache[2];
|
||||||
}
|
}
|
||||||
else {
|
else {
|
||||||
if ( index < SECTOR_SIZE )
|
if ( index < SECTOR_SIZE )
|
||||||
ptr = lastsector;
|
ptr = dir->sectorcache[1];
|
||||||
}
|
}
|
||||||
|
|
||||||
index &= SECTOR_SIZE-1;
|
index &= SECTOR_SIZE-1;
|
||||||
|
@ -1799,9 +1795,9 @@ int fat_getnext(struct fat_dir *dir, struct fat_direntry *entry)
|
||||||
|
|
||||||
/* save this sector, for longname use */
|
/* save this sector, for longname use */
|
||||||
if ( sectoridx )
|
if ( sectoridx )
|
||||||
memcpy( lastsector2, cached_buf, SECTOR_SIZE );
|
memcpy( dir->sectorcache[2], dir->sectorcache[0], SECTOR_SIZE );
|
||||||
else
|
else
|
||||||
memcpy( lastsector, cached_buf, SECTOR_SIZE );
|
memcpy( dir->sectorcache[1], dir->sectorcache[0], SECTOR_SIZE );
|
||||||
sectoridx += SECTOR_SIZE;
|
sectoridx += SECTOR_SIZE;
|
||||||
|
|
||||||
}
|
}
|
||||||
|
|
|
@ -64,6 +64,7 @@ struct fat_dir
|
||||||
unsigned int entrycount;
|
unsigned int entrycount;
|
||||||
int sector;
|
int sector;
|
||||||
struct fat_file file;
|
struct fat_file file;
|
||||||
|
unsigned char sectorcache[3][SECTOR_SIZE];
|
||||||
};
|
};
|
||||||
|
|
||||||
|
|
||||||
|
|
Loading…
Add table
Add a link
Reference in a new issue