ROM file check optimizations and cleanups
This commit is contained in:
@@ -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,
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
@@ -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
|
||||||
}
|
}
|
||||||
|
|
||||||
|
|||||||
@@ -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
|
||||||
|
|||||||
Reference in New Issue
Block a user