Added a toggle switch for the OpenMP texture decoder in the graphics settings.
git-svn-id: https://dolphin-emu.googlecode.com/svn/trunk@7375 8ced0084-cf51-0410-be5f-012b33b47a6e
This commit is contained in:
parent
4079523346
commit
50c5dbdb09
|
@ -188,6 +188,7 @@ xcopy "$(SolutionDir)..\Externals\SDL\$(PlatformName)\*.dll" "$(TargetDir)" /e /
|
||||||
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
<ItemDefinitionGroup Condition="'$(Configuration)|$(Platform)'=='Release|x64'">
|
||||||
<ClCompile>
|
<ClCompile>
|
||||||
<AdditionalIncludeDirectories>..\Common\Src;..\VideoCommon\Src;..\AudioCommon\Src;..\Core\Src;..\Core\Src\PowerPC\JitCommon;..\DebuggerWX\Src;..\..\..\Externals\Bochs_disasm;..\InputCommon\Src;..\DiscIO\Src;..\..\..\Externals\SFML\include;..\..\..\Externals\wxWidgets\include;..\..\..\Externals\CLRun\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
<AdditionalIncludeDirectories>..\Common\Src;..\VideoCommon\Src;..\AudioCommon\Src;..\Core\Src;..\Core\Src\PowerPC\JitCommon;..\DebuggerWX\Src;..\..\..\Externals\Bochs_disasm;..\InputCommon\Src;..\DiscIO\Src;..\..\..\Externals\SFML\include;..\..\..\Externals\wxWidgets\include;..\..\..\Externals\CLRun\include;%(AdditionalIncludeDirectories)</AdditionalIncludeDirectories>
|
||||||
|
<OpenMPSupport>true</OpenMPSupport>
|
||||||
</ClCompile>
|
</ClCompile>
|
||||||
<Link />
|
<Link />
|
||||||
<PostBuildEvent>
|
<PostBuildEvent>
|
||||||
|
|
|
@ -127,6 +127,7 @@ wxString free_look_tooltip = wxT("");
|
||||||
wxString crop_tooltip = wxT("");
|
wxString crop_tooltip = wxT("");
|
||||||
wxString opencl_tooltip = wxT("");
|
wxString opencl_tooltip = wxT("");
|
||||||
wxString dlc_tooltip = wxT("");
|
wxString dlc_tooltip = wxT("");
|
||||||
|
wxString omp_tooltip = wxT("Uses multiple threads to decode the textures in the game.");
|
||||||
wxString hotkeys_tooltip = wxT("");
|
wxString hotkeys_tooltip = wxT("");
|
||||||
wxString ppshader_tooltip = wxT("");
|
wxString ppshader_tooltip = wxT("");
|
||||||
wxString cache_efb_copies_tooltip = wxTRANSLATE("When using EFB to RAM we very often need to decode RAM data to a VRAM texture, which is a very time-consuming task.\nWith this option enabled, we'll skip decoding a texture if it didn't change.\nThis results in a nice speedup, but possibly causes glitches.\nIf you have any problems with this option enabled you should either try increasing the safety of the texture cache or disable this option.\n(NOTE: The safer the texture cache is adjusted the lower the speedup will be; accurate texture cache set to \"safe\" might actually be slower!)");
|
wxString cache_efb_copies_tooltip = wxTRANSLATE("When using EFB to RAM we very often need to decode RAM data to a VRAM texture, which is a very time-consuming task.\nWith this option enabled, we'll skip decoding a texture if it didn't change.\nThis results in a nice speedup, but possibly causes glitches.\nIf you have any problems with this option enabled you should either try increasing the safety of the texture cache or disable this option.\n(NOTE: The safer the texture cache is adjusted the lower the speedup will be; accurate texture cache set to \"safe\" might actually be slower!)");
|
||||||
|
@ -426,6 +427,9 @@ VideoConfigDiag::VideoConfigDiag(wxWindow* parent, const std::string &title, con
|
||||||
szr_misc->Add(opencl = new SettingCheckBox(page_advanced, _("Enable OpenCL"), opencl_tooltip, vconfig.bEnableOpenCL), 0, wxLEFT|wxBOTTOM, 5);
|
szr_misc->Add(opencl = new SettingCheckBox(page_advanced, _("Enable OpenCL"), opencl_tooltip, vconfig.bEnableOpenCL), 0, wxLEFT|wxBOTTOM, 5);
|
||||||
szr_misc->Add(dlcache = new SettingCheckBox(page_advanced, _("Enable Display List Caching"), dlc_tooltip, vconfig.bDlistCachingEnable), 0, wxBOTTOM, 5);
|
szr_misc->Add(dlcache = new SettingCheckBox(page_advanced, _("Enable Display List Caching"), dlc_tooltip, vconfig.bDlistCachingEnable), 0, wxBOTTOM, 5);
|
||||||
szr_misc->Add(hotkeys = new SettingCheckBox(page_advanced, _("Enable Hotkeys"), hotkeys_tooltip, vconfig.bOSDHotKey), 0, wxLEFT|wxBOTTOM, 5);
|
szr_misc->Add(hotkeys = new SettingCheckBox(page_advanced, _("Enable Hotkeys"), hotkeys_tooltip, vconfig.bOSDHotKey), 0, wxLEFT|wxBOTTOM, 5);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
szr_misc->Add(ompdecoder = new SettingCheckBox(page_advanced, _("OpenMP Texture Decoder"), omp_tooltip, vconfig.bOMPDecoder), 0, wxBOTTOM, 5);
|
||||||
|
#endif
|
||||||
|
|
||||||
// postproc shader
|
// postproc shader
|
||||||
if (vconfig.backend_info.PPShaders.size())
|
if (vconfig.backend_info.PPShaders.size())
|
||||||
|
@ -626,6 +630,9 @@ void VideoConfigDiag::SetUIValuesFromConfig()
|
||||||
crop->SetValue(vconfig.bCrop);
|
crop->SetValue(vconfig.bCrop);
|
||||||
opencl->SetValue(vconfig.bEnableOpenCL);
|
opencl->SetValue(vconfig.bEnableOpenCL);
|
||||||
dlcache->SetValue(vconfig.bDlistCachingEnable);
|
dlcache->SetValue(vconfig.bDlistCachingEnable);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
ompdecoder->SetValue(vconfig.bOMPDecoder);
|
||||||
|
#endif
|
||||||
hotkeys->SetValue(vconfig.bOSDHotKey);
|
hotkeys->SetValue(vconfig.bOSDHotKey);
|
||||||
|
|
||||||
if (choice_ppshader)
|
if (choice_ppshader)
|
||||||
|
|
|
@ -161,7 +161,9 @@ protected:
|
||||||
SettingCheckBox* opencl;
|
SettingCheckBox* opencl;
|
||||||
SettingCheckBox* dlcache;
|
SettingCheckBox* dlcache;
|
||||||
SettingCheckBox* hotkeys;
|
SettingCheckBox* hotkeys;
|
||||||
|
#ifdef _OPENMP
|
||||||
|
SettingCheckBox* ompdecoder;
|
||||||
|
#endif
|
||||||
wxChoice* choice_ppshader;
|
wxChoice* choice_ppshader;
|
||||||
|
|
||||||
// TODO: Add options for
|
// TODO: Add options for
|
||||||
|
|
|
@ -693,7 +693,7 @@ PC_TexFormat TexDecoder_Decode_real(u8 *dst, const u8 *src, int width, int heigh
|
||||||
{
|
{
|
||||||
#ifdef _OPENMP
|
#ifdef _OPENMP
|
||||||
//Dont use multithreading in small Textures
|
//Dont use multithreading in small Textures
|
||||||
if(width > 127 && height > 127)
|
if ((width > 127 && height > 127) && g_ActiveConfig.bOMPDecoder)
|
||||||
{
|
{
|
||||||
//don't span to many threads they will kill the rest of the emu :)
|
//don't span to many threads they will kill the rest of the emu :)
|
||||||
omp_set_num_threads((cpu_info.num_cores + 2) / 3);
|
omp_set_num_threads((cpu_info.num_cores + 2) / 3);
|
||||||
|
@ -968,7 +968,7 @@ PC_TexFormat TexDecoder_Decode_real(u8 *dst, const u8 *src, int width, int heigh
|
||||||
PC_TexFormat TexDecoder_Decode_RGBA(u32 * dst, const u8 * src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
PC_TexFormat TexDecoder_Decode_RGBA(u32 * dst, const u8 * src, int width, int height, int texformat, int tlutaddr, int tlutfmt)
|
||||||
{
|
{
|
||||||
#ifdef _OPENMP
|
#ifdef _OPENMP
|
||||||
if(width > 127 && height > 127)
|
if ((width > 127 && height > 127) && g_ActiveConfig.bOMPDecoder)
|
||||||
{
|
{
|
||||||
//don't span to many threads they will kill the rest of the emu :)
|
//don't span to many threads they will kill the rest of the emu :)
|
||||||
omp_set_num_threads((cpu_info.num_cores + 2) / 3);
|
omp_set_num_threads((cpu_info.num_cores + 2) / 3);
|
||||||
|
|
|
@ -96,6 +96,9 @@ void VideoConfig::Load(const char *ini_file)
|
||||||
iniFile.Get("Settings", "DisableFog", &bDisableFog, 0);
|
iniFile.Get("Settings", "DisableFog", &bDisableFog, 0);
|
||||||
|
|
||||||
iniFile.Get("Settings", "EnableOpenCL", &bEnableOpenCL, false);
|
iniFile.Get("Settings", "EnableOpenCL", &bEnableOpenCL, false);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
iniFile.Get("Settings", "OMPDecoder", &bOMPDecoder, false);
|
||||||
|
#endif
|
||||||
|
|
||||||
iniFile.Get("Enhancements", "ForceFiltering", &bForceFiltering, 0);
|
iniFile.Get("Enhancements", "ForceFiltering", &bForceFiltering, 0);
|
||||||
iniFile.Get("Enhancements", "MaxAnisotropy", &iMaxAnisotropy, 0); // NOTE - this is x in (1 << x)
|
iniFile.Get("Enhancements", "MaxAnisotropy", &iMaxAnisotropy, 0); // NOTE - this is x in (1 << x)
|
||||||
|
@ -170,6 +173,9 @@ void VideoConfig::GameIniLoad(const char *ini_file)
|
||||||
iniFile.GetIfExists("Video_Settings", "DisableFog", &bDisableFog);
|
iniFile.GetIfExists("Video_Settings", "DisableFog", &bDisableFog);
|
||||||
|
|
||||||
iniFile.GetIfExists("Video_Settings", "EnableOpenCL", &bEnableOpenCL);
|
iniFile.GetIfExists("Video_Settings", "EnableOpenCL", &bEnableOpenCL);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
iniFile.GetIfExists("Video_Settings", "OMPDecoder", &bOMPDecoder);
|
||||||
|
#endif
|
||||||
|
|
||||||
iniFile.GetIfExists("Video_Enhancements", "ForceFiltering", &bForceFiltering);
|
iniFile.GetIfExists("Video_Enhancements", "ForceFiltering", &bForceFiltering);
|
||||||
iniFile.GetIfExists("Video_Enhancements", "MaxAnisotropy", &iMaxAnisotropy); // NOTE - this is x in (1 << x)
|
iniFile.GetIfExists("Video_Enhancements", "MaxAnisotropy", &iMaxAnisotropy); // NOTE - this is x in (1 << x)
|
||||||
|
@ -272,6 +278,9 @@ void VideoConfig::Save(const char *ini_file)
|
||||||
iniFile.Set("Settings", "DisableFog", bDisableFog);
|
iniFile.Set("Settings", "DisableFog", bDisableFog);
|
||||||
|
|
||||||
iniFile.Set("Settings", "EnableOpenCL", bEnableOpenCL);
|
iniFile.Set("Settings", "EnableOpenCL", bEnableOpenCL);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
iniFile.Set("Settings", "OMPDecoder", bOMPDecoder);
|
||||||
|
#endif
|
||||||
|
|
||||||
iniFile.Set("Enhancements", "ForceFiltering", bForceFiltering);
|
iniFile.Set("Enhancements", "ForceFiltering", bForceFiltering);
|
||||||
iniFile.Set("Enhancements", "MaxAnisotropy", iMaxAnisotropy);
|
iniFile.Set("Enhancements", "MaxAnisotropy", iMaxAnisotropy);
|
||||||
|
@ -351,6 +360,9 @@ void VideoConfig::GameIniSave(const char* default_ini, const char* game_ini)
|
||||||
SET_IF_DIFFERS("Video_Settings", "DisableFog", bDisableFog);
|
SET_IF_DIFFERS("Video_Settings", "DisableFog", bDisableFog);
|
||||||
|
|
||||||
SET_IF_DIFFERS("Video_Settings", "EnableOpenCL", bEnableOpenCL);
|
SET_IF_DIFFERS("Video_Settings", "EnableOpenCL", bEnableOpenCL);
|
||||||
|
#ifdef _OPENMP
|
||||||
|
SET_IF_DIFFERS("Video_Settings", "OMPDecoder", bOMPDecoder);
|
||||||
|
#endif
|
||||||
|
|
||||||
SET_IF_DIFFERS("Video_Enhancements", "ForceFiltering", bForceFiltering);
|
SET_IF_DIFFERS("Video_Enhancements", "ForceFiltering", bForceFiltering);
|
||||||
SET_IF_DIFFERS("Video_Enhancements", "MaxAnisotropy", iMaxAnisotropy); // NOTE - this is x in (1 << x)
|
SET_IF_DIFFERS("Video_Enhancements", "MaxAnisotropy", iMaxAnisotropy); // NOTE - this is x in (1 << x)
|
||||||
|
|
|
@ -121,6 +121,9 @@ struct VideoConfig
|
||||||
// Hacks
|
// Hacks
|
||||||
bool bEFBAccessEnable;
|
bool bEFBAccessEnable;
|
||||||
bool bDlistCachingEnable;
|
bool bDlistCachingEnable;
|
||||||
|
#ifdef _OPENMP
|
||||||
|
bool bOMPDecoder;
|
||||||
|
#endif
|
||||||
bool bEFBCopyEnable;
|
bool bEFBCopyEnable;
|
||||||
bool bEFBCopyCacheEnable;
|
bool bEFBCopyCacheEnable;
|
||||||
bool bEFBEmulateFormatChanges;
|
bool bEFBEmulateFormatChanges;
|
||||||
|
|
Loading…
Reference in New Issue