ROM file check optimizations and cleanups

This commit is contained in:
RichardG867
2025-09-19 17:51:01 -03:00
parent 36f51f119b
commit 13d5de4e7b
4 changed files with 39 additions and 52 deletions

View File

@@ -59,7 +59,7 @@ extern void rom_writel(uint32_t addr, uint32_t val, void *priv);
extern void rom_get_full_path(char *dest, const char *fn); extern void rom_get_full_path(char *dest, const char *fn);
extern FILE *rom_fopen(const char *fn, char *mode); extern FILE *rom_fopen(const char *fn, char *mode);
extern int rom_getfile(char *fn, char *s, int size); extern int rom_getfile(const char *fn, char *s, int size);
extern int rom_present(const char *fn); extern int rom_present(const char *fn);
extern int rom_load_linear_oddeven(const char *fn, uint32_t addr, int sz, extern int rom_load_linear_oddeven(const char *fn, uint32_t addr, int sz,

View File

@@ -92,8 +92,9 @@ rom_check(const char *fn)
{ {
FILE *fp = NULL; FILE *fp = NULL;
int ret = 0; int ret = 0;
char last = fn[strlen(fn) - 1];
if ((fn[strlen(fn) - 1] == '/') || (fn[strlen(fn) - 1] == '\\')) if ((last == '/') || (last == '\\'))
ret = plat_dir_check((char *) fn); ret = plat_dir_check((char *) fn);
else { else {
fp = fopen(fn, "rb"); fp = fopen(fn, "rb");
@@ -112,7 +113,7 @@ rom_get_full_path(char *dest, const char *fn)
dest[0] = 0x00; dest[0] = 0x00;
if (strstr(fn, "roms/") == fn) { if (!strncmp(fn, "roms/", 5)) {
/* Relative path */ /* Relative path */
for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) { for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) {
path_append_filename(temp, rom_path->path, fn + 5); path_append_filename(temp, rom_path->path, fn + 5);
@@ -130,34 +131,6 @@ rom_get_full_path(char *dest, const char *fn)
} }
} }
bool
rom_fcheck(const char *fn)
{
char temp[1024];
bool exists = false;
if (fn == NULL)
return false;
if (strstr(fn, "roms/") == fn) {
/* Relative path */
for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) {
path_append_filename(temp, rom_path->path, fn + 5);
exists = plat_file_check(temp);
if (exists) {
return exists;
}
}
return exists;
} else {
/* Absolute path */
return plat_file_check(fn);
}
}
FILE * FILE *
rom_fopen(const char *fn, char *mode) rom_fopen(const char *fn, char *mode)
{ {
@@ -167,15 +140,14 @@ rom_fopen(const char *fn, char *mode)
if ((fn == NULL) || (mode == NULL)) if ((fn == NULL) || (mode == NULL))
return NULL; return NULL;
if (strstr(fn, "roms/") == fn) { if (!strncmp(fn, "roms/", 5)) {
/* Relative path */ /* Relative path */
for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) { for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) {
path_append_filename(temp, rom_path->path, fn + 5); path_append_filename(temp, rom_path->path, fn + 5);
if ((fp = plat_fopen(temp, mode)) != NULL) { if ((fp = plat_fopen(temp, mode)) != NULL)
return fp; return fp;
} }
}
return fp; return fp;
} else { } else {
@@ -185,16 +157,16 @@ rom_fopen(const char *fn, char *mode)
} }
int int
rom_getfile(char *fn, char *s, int size) rom_getfile(const char *fn, char *s, int size)
{ {
char temp[1024]; char temp[1024];
if (strstr(fn, "roms/") == fn) { if (!strncmp(fn, "roms/", 5)) {
/* Relative path */ /* Relative path */
for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) { for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) {
path_append_filename(temp, rom_path->path, fn + 5); path_append_filename(temp, rom_path->path, fn + 5);
if (rom_present(temp)) { if (plat_file_check(temp)) {
strncpy(s, temp, size); strncpy(s, temp, size);
return 1; return 1;
} }
@@ -203,7 +175,7 @@ rom_getfile(char *fn, char *s, int size)
return 0; return 0;
} else { } else {
/* Absolute path */ /* Absolute path */
if (rom_present(fn)) { if (plat_file_check(fn)) {
strncpy(s, fn, size); strncpy(s, fn, size);
return 1; return 1;
} }
@@ -215,7 +187,25 @@ rom_getfile(char *fn, char *s, int size)
int int
rom_present(const char *fn) rom_present(const char *fn)
{ {
return rom_fcheck(fn); char temp[1024];
if (fn == NULL)
return 0;
if (!strncmp(fn, "roms/", 5)) {
/* Relative path */
for (rom_path_t *rom_path = &rom_paths; rom_path != NULL; rom_path = rom_path->next) {
path_append_filename(temp, rom_path->path, fn + 5);
if (plat_file_check(temp))
return 1;
}
return 0;
} else {
/* Absolute path */
return plat_file_check(fn);
}
} }
uint8_t uint8_t

View File

@@ -258,13 +258,12 @@ plat_file_check(const char *path)
#ifdef _WIN32 #ifdef _WIN32
auto data = QString::fromUtf8(path).toStdWString(); auto data = QString::fromUtf8(path).toStdWString();
auto res = GetFileAttributesW(data.c_str()); auto res = GetFileAttributesW(data.c_str());
return (res != INVALID_FILE_ATTRIBUTES && !(res & FILE_ATTRIBUTE_DIRECTORY)); return (res != INVALID_FILE_ATTRIBUTES) && !(res & FILE_ATTRIBUTE_DIRECTORY);
#else #else
struct stat dummy; struct stat stats;
if (stat(path, &dummy) < 0) { if (stat(path, &stats) < 0)
return 0; return 0;
} return !S_ISDIR(stats.st_mode);
return !S_ISDIR(dummy.st_mode);
#endif #endif
} }

View File

@@ -405,21 +405,19 @@ path_append_filename(char *dest, const char *s1, const char *s2)
int int
plat_dir_check(char *path) plat_dir_check(char *path)
{ {
struct stat dummy; struct stat stats;
if (stat(path, &dummy) < 0) { if (stat(path, &stats) < 0)
return 0; return 0;
} return S_ISDIR(stats.st_mode);
return S_ISDIR(dummy.st_mode);
} }
int int
plat_file_check(const char *path) plat_file_check(const char *path)
{ {
struct stat dummy; struct stat stats;
if (stat(path, &dummy) < 0) { if (stat(path, &stats) < 0)
return 0; return 0;
} return !S_ISDIR(stats.st_mode);
return !S_ISDIR(dummy.st_mode);
} }
int int