From 5442bf1d78dca161bf0bd298fa0536a2e88721f4 Mon Sep 17 00:00:00 2001 From: evilynux Date: Fri, 16 Feb 2007 06:16:22 +0000 Subject: [PATCH] - Fixed file reading resume, thanks to elhobbs. - Fixed relative path file open for anything else than MS Windows (DIR_SEP). - Using constants for filename size and filename extension size. Files that are not 8+3 are still broken. Even if you rename TowerDefense maps to 8+3, it crashes, to be debugged. I'm commiting anyway as my tests show that it doesn't worsen current state. Please reverse if otherwise. --- desmume/src/cflash.c | 35 ++++++++++++++++++----------------- desmume/src/fat.h | 13 +++++++++---- 2 files changed, 27 insertions(+), 21 deletions(-) diff --git a/desmume/src/cflash.c b/desmume/src/cflash.c index b06387852..921c188bb 100644 --- a/desmume/src/cflash.c +++ b/desmume/src/cflash.c @@ -72,8 +72,8 @@ int lfn_checksum() { u8 chk; chk = 0; - for (i=0; i < 11; i++) { - chk = ((chk & 1) ? 0x80 : 0) + (chk >> 1) + (i < 8 ? files[numFiles].name[i] : files[numFiles].ext[i - 8]); + for (i=0; i < (NAME_LEN + EXT_LEN); i++) { + chk = ((chk & 1) ? 0x80 : 0) + (chk >> 1) + (i < NAME_LEN ? files[numFiles].name[i] : files[numFiles].ext[i - NAME_LEN]); } return chk; } @@ -96,9 +96,9 @@ void add_file(char *fname, FsEntry * entry, int fileLevel) { if (i<0) i = strlen(fname); for (j=0; j=strlen(fname)) break; files[numFiles].ext[j] = fname[j+i+1]; } @@ -142,9 +142,9 @@ void add_file(char *fname, FsEntry * entry, int fileLevel) { if (i<0) i = strlen(fname); for (j=0; j=strlen(fname)) break; files[numFiles].ext[j] = fname[j+i+1]; } @@ -169,8 +169,8 @@ void add_file(char *fname, FsEntry * entry, int fileLevel) { numFiles++; } else if (fileLevel > 0) { fileLink[fileLevel].filesInDir += 1; - strncpy((char*)&files[numFiles].name[0],".. ",8); - strncpy((char*)&files[numFiles].ext[0]," ",3); + strncpy((char*)&files[numFiles].name[0],".. ",NAME_LEN); + strncpy((char*)&files[numFiles].ext[0]," ",EXT_LEN); fileLink[numFiles].parent = fileLevel; files[numFiles].attrib = 0x10; numFiles++; @@ -295,9 +295,9 @@ BOOL cflash_build_fat() { dirEntries[k++] = files[j]; if ((files[j].attrib & ATTRIB_LFN)==0) { if (files[j].attrib & ATTRIB_DIR) { - if (strncmp((char*)&files[j].name[0],". ",8)==0) { + if (strncmp((char*)&files[j].name[0],". ",NAME_LEN)==0) { dirEntries[k-1].startCluster = dirEntryLink[k-1].level; - } else if (strncmp((char*)&files[j].name[0],".. ",8)==0) { + } else if (strncmp((char*)&files[j].name[0],".. ",NAME_LEN)==0) { dirEntries[k-1].startCluster = dirEntryLink[k-1].parent; } else { clust++; @@ -455,13 +455,13 @@ void fatstring_to_asciiz(int dirent,char *out,DIR_ENT *d) { else pd = d; - for (i=0; i<8; i++) { + for (i=0; iname[i] == ' ') break; out[i] = pd->name[i]; } if ((pd->attrib & 0x10)==0) { out[i++] = '.'; - for (j=0; j<3; j++) { + for (j=0; jext[j] == ' ') break; out[i++] = pd->ext[j]; } @@ -482,7 +482,7 @@ void resolve_path(int dirent) { ((dirEntries[i].attrib&ATTRIB_DIR)!=0)) { fatstring_to_asciiz(i,dirname,NULL); strncat(fpath,dirname,256-strlen(fpath)); - strncat(fpath,"\\",256-strlen(fpath)); + strncat(fpath,DIR_SEP,256-strlen(fpath)); dirent = i; break; } @@ -493,7 +493,7 @@ void resolve_path(int dirent) { /* Read from a file using a 512 byte buffer */ u16 fread_buffered(int dirent,u32 cluster,u32 offset) { - char fname[32]; + char fname[2*NAME_LEN+EXT_LEN]; int i,j; offset += cluster*512*SECPERCLUS; @@ -515,7 +515,7 @@ u16 fread_buffered(int dirent,u32 cluster,u32 offset) { /* replaced strcpy/cat with strncpy/strcat to fixed possible buffer overruns */ strncpy(fpath,sRomPath,256); - strncat(fpath,"\\",256-strlen(fpath)); + strncat(fpath,DIR_SEP,256-strlen(fpath)); resolve_path(dirent); @@ -523,8 +523,9 @@ u16 fread_buffered(int dirent,u32 cluster,u32 offset) { strncat(fpath,fname,256-strlen(fpath)); hFile = fopen(fpath, "rb"); - if (!hFile) - return 0; + if (!hFile) return 0; + bufferStart = offset; + fseek(hFile, offset, SEEK_SET); fread(&freadBuffer, 1, 512, hFile); bufferStart = offset; diff --git a/desmume/src/fat.h b/desmume/src/fat.h index 65696d375..0c5922d0e 100644 --- a/desmume/src/fat.h +++ b/desmume/src/fat.h @@ -13,10 +13,14 @@ #define ATTRIB_LFN 0x0F #define FILE_FREE 0xE5 +/* Name and extension maximum length */ +#define NAME_LEN 8 +#define EXT_LEN 3 // Boot Sector - must be packed #ifdef _MSC_VER #pragma pack(push, 1) +#define DIR_SEP "\\" typedef struct { u8 jmpBoot[3]; @@ -54,8 +58,8 @@ typedef struct #pragma pack(push, 1) typedef struct { - u8 name[8]; - u8 ext[3]; + u8 name[NAME_LEN]; + u8 ext[EXT_LEN]; u8 attrib; u8 reserved; u8 cTime_ms; @@ -70,6 +74,7 @@ typedef struct } DIR_ENT; #pragma pack(pop) #else +#define DIR_SEP "/" typedef struct { u8 jmpBoot[3] __PACKED; @@ -105,8 +110,8 @@ typedef struct // Directory entry - must be packed typedef struct { - u8 name[8] __PACKED; - u8 ext[3] __PACKED; + u8 name[NAME_LEN] __PACKED; + u8 ext[EXT_LEN] __PACKED; u8 attrib __PACKED; u8 reserved __PACKED; u8 cTime_ms __PACKED;