Skip to content

Commit

Permalink
Add context destruction blacklist.
Browse files Browse the repository at this point in the history
This will cause a context and window leak, which is bad, but
only for certain hardware combinations.

We can remove once we figure out exactly waht is causing
this behavior.
  • Loading branch information
AWoloszyn committed May 7, 2018
1 parent cb82762 commit 2560b0b
Show file tree
Hide file tree
Showing 2 changed files with 19 additions and 6 deletions.
12 changes: 11 additions & 1 deletion core/os/device/deviceinfo/cc/query.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -160,7 +160,17 @@ void buildDeviceInstance(const query::Option& opt, void* platform_data,
instance->set_allocated_configuration(configuration);
deviceInstanceID(instance);

query::destroyContext();
// Blacklist of OS/Hardware version that mean we cannot safely
// destroy the context.
bool blacklist = false;
if (std::string(gpuName).find("Vega") != std::string::npos &&
std::string(query::osName()).find("Windows 10") != std::string::npos) {
blacklist = true;
}

if (!blacklist) {
query::destroyContext();
}

*out = instance;
}
Expand Down
13 changes: 8 additions & 5 deletions core/os/device/deviceinfo/cc/windows/query.cpp
Original file line number Diff line number Diff line change
Expand Up @@ -26,16 +26,19 @@ namespace {

static const char* wndClassName = TEXT("opengl-dummy-window");

WNDCLASS registerWindowClass() {
WNDCLASS wc;
WNDCLASSEX registerWindowClass() {
WNDCLASSEX wc;
memset(&wc, 0, sizeof(wc));
wc.style = 0;
wc.cbSize = sizeof(wc);
// We must use CS_OWNDC here if we are to use this window with GL.
// https://www.khronos.org/opengl/wiki/Creating_an_OpenGL_Context_(WGL)#The_Window_Itself
wc.style = CS_OWNDC;
wc.lpfnWndProc = DefWindowProc;
wc.hInstance = GetModuleHandle(0);
wc.hCursor = LoadCursor(0, IDC_ARROW);
wc.lpszMenuName = TEXT("");
wc.lpszClassName = wndClassName;
RegisterClass(&wc);
RegisterClassEx(&wc);
return wc;
}

Expand Down Expand Up @@ -91,7 +94,7 @@ void createGlContext() {
return;
}

WNDCLASS wc = registerWindowClass();
WNDCLASSEX wc = registerWindowClass();
gContext.mWnd = CreateWindow(wndClassName, TEXT(""), WS_POPUP, 0, 0, 8, 8, 0, 0, GetModuleHandle(0), 0);
if (gContext.mWnd == nullptr) {
return;
Expand Down

0 comments on commit 2560b0b

Please sign in to comment.