void pl_frame_limit(void)
{
/* called once per frame, make psxCpu->Execute() above return */
- stop = 1;
+ stop++;
}
void pl_timing_prepare(int is_pal)
#ifdef GPU_NEON
var.value = NULL;
- var.key = "pcsx_rearmed_neon_interlace_enable";
+ var.key = "pcsx_rearmed_neon_interlace_enable_v2";
if (environ_cb(RETRO_ENVIRONMENT_GET_VARIABLE, &var) && var.value)
{
pl_rearmed_cbs.gpu_neon.allow_interlace = 0;
else if (strcmp(var.value, "enabled") == 0)
pl_rearmed_cbs.gpu_neon.allow_interlace = 1;
+ else // auto
+ pl_rearmed_cbs.gpu_neon.allow_interlace = 2;
}
var.value = NULL;
{
rebootemu = 0;
SysReset();
- if (!Config.HLE && !Config.SlowBoot)
- {
- // skip BIOS logos
- psxRegs.pc = psxRegs.GPR.n.ra;
- }
- return;
}
print_internal_fps();
static bool find_any_bios(const char *dirpath, char *path, size_t path_size)
{
+ static const char *substrings[] = { "scph", "psx", "openbios" };
DIR *dir;
struct dirent *ent;
bool ret = false;
+ size_t i;
dir = opendir(dirpath);
if (dir == NULL)
return false;
- while ((ent = readdir(dir)))
+ for (i = 0; sizeof(substrings) / sizeof(substrings[0]); i++)
{
- if ((strncasecmp(ent->d_name, "scph", 4) != 0) && (strncasecmp(ent->d_name, "psx", 3) != 0))
- continue;
-
- snprintf(path, path_size, "%s%c%s", dirpath, SLASH, ent->d_name);
- ret = try_use_bios(path);
- if (ret)
- break;
+ const char *substr = substrings[i];
+ size_t len = strlen(substr);
+ rewinddir(dir);
+ while ((ent = readdir(dir)))
+ {
+ if ((strncasecmp(ent->d_name, substr, len) != 0))
+ continue;
+ if (strstr(ent->d_name, "unirom"))
+ continue;
+
+ snprintf(path, path_size, "%s%c%s", dirpath, SLASH, ent->d_name);
+ ret = try_use_bios(path);
+ if (ret)
+ {
+ closedir(dir);
+ return ret;
+ }
+ }
}
closedir(dir);
return ret;
if (log_cb)
log_cb(RETRO_LOG_DEBUG, "%s", msg);
}
+
+// vim:sw=3:ts=3:expandtab