diff -upr ppsspp-1.19.2.org/libretro/libretro.cpp ppsspp-1.19.2.mod/libretro/libretro.cpp --- ppsspp-1.19.2.org/libretro/libretro.cpp 2025-06-15 20:41:44.000000000 +0900 +++ ppsspp-1.19.2.mod/libretro/libretro.cpp 2025-07-05 02:12:11.930212000 +0900 @@ -1223,16 +1223,6 @@ void retro_init(void) if (environ_cb(RETRO_ENVIRONMENT_GET_INPUT_BITMASKS, NULL)) libretro_supports_bitmasks = true; - g_Config.Load("", ""); - g_Config.iInternalResolution = 0; - - // Log levels must be set after g_Config.Load - g_logManager.SetAllLogLevels(LogLevel::LINFO); - - const char* nickname = NULL; - if (environ_cb(RETRO_ENVIRONMENT_GET_USERNAME, &nickname) && nickname) - g_Config.sNickName = std::string(nickname); - Path retro_base_dir; Path retro_save_dir; const char* dir_ptr = NULL; @@ -1242,6 +1232,17 @@ void retro_init(void) if (environ_cb(RETRO_ENVIRONMENT_GET_SAVE_DIRECTORY, &dir_ptr) && dir_ptr) retro_save_dir = Path(dir_ptr); + g_Config.SetSearchPath(retro_save_dir / GetSysDirectory(DIRECTORY_SYSTEM).c_str()); + g_Config.Load("", ""); + g_Config.iInternalResolution = 0; + + // Log levels must be set after g_Config.Load + g_logManager.SetAllLogLevels(LogLevel::LINFO); + + const char* nickname = NULL; + if (environ_cb(RETRO_ENVIRONMENT_GET_USERNAME, &nickname) && nickname) + g_Config.sNickName = std::string(nickname); + retro_base_dir /= "PPSSPP"; g_Config.currentDirectory = retro_base_dir;