gsdx:windows: Show different adapters for each renderer

OpenGL does not allow an adapter to be selected, and the available
adapters for D3D11 and D3D9 may be slightly different.
This commit is contained in:
Jonathan Li 2018-08-22 17:53:15 +01:00
parent e4dd0069ca
commit 22f1048e8f
4 changed files with 63 additions and 65 deletions

View File

@ -27,15 +27,24 @@
#include "GSDevice11.h" #include "GSDevice11.h"
#include "resource.h" #include "resource.h"
#include "GSSetting.h" #include "GSSetting.h"
#include <algorithm>
GSSettingsDlg::GSSettingsDlg() GSSettingsDlg::GSSettingsDlg()
: GSDialog(IDD_CONFIG) : GSDialog(IDD_CONFIG)
, m_renderers{theApp.m_gs_renderers}
, m_d3d11_adapters{EnumerateD3D11Adapters()}
, m_d3d9_adapters{EnumerateD3D9Adapters()}
, m_current_adapters{nullptr}
, m_last_selected_adapter_id{theApp.GetConfigS("Adapter")}
{ {
m_adapters = EnumerateD3D11Adapters(); if (m_d3d11_adapters.empty())
if (m_adapters.empty()) {
m_adapters = EnumerateD3D9Adapters(); auto is_d3d11_renderer = [](const auto &renderer) {
const GSRendererType type = static_cast<GSRendererType>(renderer.value);
return type == GSRendererType::DX1011_HW || type == GSRendererType::DX1011_SW || type == GSRendererType::DX1011_OpenCL;
};
m_renderers.erase(std::remove_if(m_renderers.begin(), m_renderers.end(), is_d3d11_renderer), m_renderers.end());
}
#ifdef ENABLE_OPENCL #ifdef ENABLE_OPENCL
std::list<OCLDeviceDesc> ocldevs; std::list<OCLDeviceDesc> ocldevs;
@ -77,6 +86,10 @@ std::vector<GSSettingsDlg::Adapter> GSSettingsDlg::EnumerateD3D11Adapters()
WideCharToMultiByte(CP_ACP, 0, desc.Description, sizeof(desc.Description), buf.data(), size, nullptr, nullptr); WideCharToMultiByte(CP_ACP, 0, desc.Description, sizeof(desc.Description), buf.data(), size, nullptr, nullptr);
adapters.push_back({buf.data(), GSAdapter(desc), level}); adapters.push_back({buf.data(), GSAdapter(desc), level});
} }
auto unsupported_adapter = [](const auto &adapter) { return adapter.level < D3D_FEATURE_LEVEL_10_0; };
adapters.erase(std::remove_if(adapters.begin(), adapters.end(), unsupported_adapter), adapters.end());
return adapters; return adapters;
} }
@ -108,19 +121,12 @@ void GSSettingsDlg::OnInit()
{ {
__super::OnInit(); __super::OnInit();
std::string adapter_setting = theApp.GetConfigS("Adapter"); GSRendererType renderer = GSRendererType(theApp.GetConfigI("Renderer"));
std::vector<GSSetting> adapter_settings; const bool dx11 = renderer == GSRendererType::DX1011_HW || renderer == GSRendererType::DX1011_SW || renderer == GSRendererType::DX1011_OpenCL;
unsigned int adapter_sel = 0; if (renderer == GSRendererType::Undefined || m_d3d11_adapters.empty() && dx11)
renderer = GSUtil::GetBestRenderer();
for(unsigned int i = 0; i < m_adapters.size(); i++) ComboBoxInit(IDC_RENDERER, m_renderers, static_cast<int32_t>(renderer));
{ UpdateAdapters();
if (m_adapters[i].id == adapter_setting)
{
adapter_sel = i;
}
adapter_settings.push_back(GSSetting(i, m_adapters[i].name.c_str(), ""));
}
std::string ocldev = theApp.GetConfigS("ocldev"); std::string ocldev = theApp.GetConfigS("ocldev");
@ -136,10 +142,8 @@ void GSSettingsDlg::OnInit()
} }
} }
ComboBoxInit(IDC_ADAPTER, adapter_settings, adapter_sel);
ComboBoxInit(IDC_OPENCL_DEVICE, m_ocl_devs, ocl_sel); ComboBoxInit(IDC_OPENCL_DEVICE, m_ocl_devs, ocl_sel);
ComboBoxInit(IDC_MIPMAP_HW, theApp.m_gs_hw_mipmapping, theApp.GetConfigI("mipmap_hw")); ComboBoxInit(IDC_MIPMAP_HW, theApp.m_gs_hw_mipmapping, theApp.GetConfigI("mipmap_hw"));
UpdateRenderers();
ComboBoxInit(IDC_INTERLACE, theApp.m_gs_interlace, theApp.GetConfigI("interlace")); ComboBoxInit(IDC_INTERLACE, theApp.m_gs_interlace, theApp.GetConfigI("interlace"));
ComboBoxInit(IDC_UPSCALE_MULTIPLIER, theApp.m_gs_upscale_multiplier, theApp.GetConfigI("upscale_multiplier")); ComboBoxInit(IDC_UPSCALE_MULTIPLIER, theApp.m_gs_upscale_multiplier, theApp.GetConfigI("upscale_multiplier"));
@ -193,13 +197,15 @@ bool GSSettingsDlg::OnCommand(HWND hWnd, UINT id, UINT code)
case IDC_ADAPTER: case IDC_ADAPTER:
if (code == CBN_SELCHANGE) if (code == CBN_SELCHANGE)
{ {
UpdateRenderers(); INT_PTR data;
UpdateControls(); if (ComboBoxGetSelData(IDC_ADAPTER, data))
m_last_selected_adapter_id = (*m_current_adapters)[data].id;
} }
break; break;
case IDC_RENDERER: case IDC_RENDERER:
if (code == CBN_SELCHANGE) if (code == CBN_SELCHANGE)
{ {
UpdateAdapters();
UpdateControls(); UpdateControls();
} }
break; break;
@ -227,7 +233,7 @@ bool GSSettingsDlg::OnCommand(HWND hWnd, UINT id, UINT code)
INT_PTR data; INT_PTR data;
std::string adapter_id; std::string adapter_id;
if (ComboBoxGetSelData(IDC_ADAPTER, data)) if (ComboBoxGetSelData(IDC_ADAPTER, data))
adapter_id = m_adapters[data].id; adapter_id = (*m_current_adapters)[data].id;
GSHacksDlg(adapter_id).DoModal(); GSHacksDlg(adapter_id).DoModal();
} }
break; break;
@ -237,7 +243,7 @@ bool GSSettingsDlg::OnCommand(HWND hWnd, UINT id, UINT code)
if(ComboBoxGetSelData(IDC_ADAPTER, data)) if(ComboBoxGetSelData(IDC_ADAPTER, data))
{ {
theApp.SetConfig("Adapter", m_adapters[data].id.c_str()); theApp.SetConfig("Adapter", (*m_current_adapters)[data].id.c_str());
} }
if(ComboBoxGetSelData(IDC_OPENCL_DEVICE, data)) if(ComboBoxGetSelData(IDC_OPENCL_DEVICE, data))
@ -311,52 +317,39 @@ bool GSSettingsDlg::OnCommand(HWND hWnd, UINT id, UINT code)
return __super::OnCommand(hWnd, id, code); return __super::OnCommand(hWnd, id, code);
} }
void GSSettingsDlg::UpdateRenderers() void GSSettingsDlg::UpdateAdapters()
{ {
INT_PTR i; INT_PTR data;
if (!ComboBoxGetSelData(IDC_RENDERER, data))
if (!ComboBoxGetSelData(IDC_ADAPTER, i))
return; return;
D3D_FEATURE_LEVEL level = m_adapters[i].level; const GSRendererType renderer = static_cast<GSRendererType>(data);
const bool ogl = renderer == GSRendererType::OGL_HW || renderer == GSRendererType::OGL_SW || renderer == GSRendererType::OGL_OpenCL;
const bool dx11 = renderer == GSRendererType::DX1011_HW || renderer == GSRendererType::DX1011_SW || renderer == GSRendererType::DX1011_OpenCL;
const bool null = renderer == GSRendererType::Null;
std::vector<GSSetting> renderers; EnableWindow(GetDlgItem(m_hWnd, IDC_ADAPTER), !(ogl || null));
EnableWindow(GetDlgItem(m_hWnd, IDC_ADAPTER_TEXT), !(ogl || null));
GSRendererType renderer_setting; if (ogl || null)
if (ComboBoxGetSelData(IDC_RENDERER, i))
{ {
renderer_setting = static_cast<GSRendererType>(i); SendMessage(GetDlgItem(m_hWnd, IDC_ADAPTER), CB_RESETCONTENT, 0, 0);
} return;
else
{
renderer_setting = GSRendererType(theApp.GetConfigI("Renderer"));
if (renderer_setting == GSRendererType::Undefined)
renderer_setting = GSUtil::GetBestRenderer();
} }
GSRendererType renderer_sel = GSRendererType::Default; m_current_adapters = dx11 ? &m_d3d11_adapters : &m_d3d9_adapters;
for(size_t i = 0; i < theApp.m_gs_renderers.size(); i++) std::vector<GSSetting> adapter_settings;
unsigned int adapter_sel = 0;
for (unsigned int i = 0; i < m_current_adapters->size(); i++)
{ {
GSSetting r = theApp.m_gs_renderers[i]; if ((*m_current_adapters)[i].id == m_last_selected_adapter_id)
adapter_sel = i;
GSRendererType renderer = static_cast<GSRendererType>(r.value); adapter_settings.push_back(GSSetting{i, (*m_current_adapters)[i].name.c_str(), ""});
if(renderer == GSRendererType::DX1011_HW || renderer == GSRendererType::DX1011_SW || renderer == GSRendererType::DX1011_OpenCL)
{
if(level < D3D_FEATURE_LEVEL_10_0) continue;
}
renderers.push_back(r);
if (static_cast<GSRendererType>(r.value) == renderer_setting)
{
renderer_sel = renderer_setting;
}
} }
ComboBoxInit(IDC_RENDERER, renderers, static_cast<int32_t>(renderer_sel)); ComboBoxInit(IDC_ADAPTER, adapter_settings, adapter_sel);
} }
void GSSettingsDlg::UpdateControls() void GSSettingsDlg::UpdateControls()

View File

@ -83,14 +83,18 @@ class GSSettingsDlg : public GSDialog
Adapter(const std::string &n, const std::string &i, const D3D_FEATURE_LEVEL &l) : name(n), id(i), level(l) {} Adapter(const std::string &n, const std::string &i, const D3D_FEATURE_LEVEL &l) : name(n), id(i), level(l) {}
}; };
std::vector<Adapter> m_adapters; std::vector<GSSetting> m_renderers;
std::vector<Adapter> m_d3d11_adapters;
std::vector<Adapter> m_d3d9_adapters;
std::vector<Adapter> *m_current_adapters;
std::string m_last_selected_adapter_id;
std::vector<GSSetting> m_ocl_devs; std::vector<GSSetting> m_ocl_devs;
std::vector<Adapter> EnumerateD3D11Adapters(); std::vector<Adapter> EnumerateD3D11Adapters();
std::vector<Adapter> EnumerateD3D9Adapters(); std::vector<Adapter> EnumerateD3D9Adapters();
void UpdateRenderers(); void UpdateAdapters();
void UpdateControls(); void UpdateControls();
protected: protected:

View File

@ -287,10 +287,10 @@ BEGIN
CONTROL IDB_LOGO11,IDC_LOGO11,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44 CONTROL IDB_LOGO11,IDC_LOGO11,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44
CONTROL IDB_LOGOGL,IDC_LOGOGL,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44 CONTROL IDB_LOGOGL,IDC_LOGOGL,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44
CONTROL IDB_NULL,IDC_NULL,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44 CONTROL IDB_NULL,IDC_NULL,"Static",SS_BITMAP | SS_REALSIZECONTROL,6,6,230,44
LTEXT "Adapter:",IDC_STATIC,6,57,30,8 LTEXT "Renderer:",IDC_STATIC,6,57,79,8
COMBOBOX IDC_ADAPTER,71,55,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP COMBOBOX IDC_RENDERER,71,55,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
LTEXT "Renderer:",IDC_STATIC,6,72,34,8 LTEXT "Adapter:",IDC_ADAPTER_TEXT,6,72,79,8
COMBOBOX IDC_RENDERER,71,70,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP COMBOBOX IDC_ADAPTER,71,70,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
LTEXT "Interlacing (F5):",IDC_STATIC,6,87,52,8 LTEXT "Interlacing (F5):",IDC_STATIC,6,87,52,8
COMBOBOX IDC_INTERLACE,71,85,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP COMBOBOX IDC_INTERLACE,71,85,166,118,CBS_DROPDOWNLIST | WS_VSCROLL | WS_TABSTOP
LTEXT "Texture Filtering:",IDC_FILTER_TEXT,6,102,79,8 LTEXT "Texture Filtering:",IDC_FILTER_TEXT,6,102,79,8

View File

@ -10,8 +10,9 @@
#define IDB_LOGOGL 2006 #define IDB_LOGOGL 2006
#define IDC_NULL 2007 #define IDC_NULL 2007
#define IDC_LOGO9 2008 #define IDC_LOGO9 2008
#define IDC_LOGO11 2010 #define IDC_LOGO11 2009
#define IDC_LOGOGL 2011 #define IDC_LOGOGL 2010
#define IDC_ADAPTER_TEXT 2011
#define IDC_ADAPTER 2012 #define IDC_ADAPTER 2012
#define IDC_RENDERER 2013 #define IDC_RENDERER 2013
#define IDC_FILTER_TEXT 2014 #define IDC_FILTER_TEXT 2014