internal/glfw: bug fix: limit the DWM swap interval to Vista and 7

This change applies the bug fix at glfw/glfw#1072.

Updates #2961
This commit is contained in:
Hajime Hoshi 2024-04-14 15:31:10 +09:00
parent d5f15f9354
commit 86e0bcc264

View File

@ -261,19 +261,13 @@ func makeContextCurrentWGL(window *Window) error {
} }
func swapBuffersWGL(window *Window) error { func swapBuffersWGL(window *Window) error {
if window.monitor == nil && winver.IsWindowsVistaOrGreater() { if window.monitor == nil {
// DWM Composition is always enabled on Win8+ // HACK: Use DwmFlush when desktop composition is enabled on Windows Vista and 7
enabled := winver.IsWindows8OrGreater() if !winver.IsWindows8OrGreater() && winver.IsWindowsVistaOrGreater() {
enabled, err := _DwmIsCompositionEnabled()
if !enabled {
var err error
enabled, err = _DwmIsCompositionEnabled()
if err != nil { if err != nil {
return err return err
} }
}
// HACK: Use DwmFlush when desktop composition is enabled
if enabled { if enabled {
for i := 0; i < window.context.platform.interval; i++ { for i := 0; i < window.context.platform.interval; i++ {
// Ignore an error from DWM functions as they might not be implemented e.g. on Proton (#2113). // Ignore an error from DWM functions as they might not be implemented e.g. on Proton (#2113).
@ -281,6 +275,7 @@ func swapBuffersWGL(window *Window) error {
} }
} }
} }
}
if err := _SwapBuffers(window.context.platform.dc); err != nil { if err := _SwapBuffers(window.context.platform.dc); err != nil {
return err return err
@ -297,24 +292,20 @@ func swapIntervalWGL(interval int) error {
window.context.platform.interval = interval window.context.platform.interval = interval
if window.monitor == nil && winver.IsWindowsVistaOrGreater() { if window.monitor == nil {
// DWM Composition is always enabled on Win8+ // HACK: Disable WGL swap interval when desktop composition is enabled on Windows
enabled := winver.IsWindows8OrGreater() // Vista and 7 to avoid interfering with DWM vsync
if !winver.IsWindows8OrGreater() && winver.IsWindowsVistaOrGreater() {
if !enabled { enabled, err := _DwmIsCompositionEnabled()
e, err := _DwmIsCompositionEnabled()
// Ignore an error from DWM functions as they might not be implemented e.g. on Proton (#2113). // Ignore an error from DWM functions as they might not be implemented e.g. on Proton (#2113).
if err == nil { if err == nil {
enabled = e enabled = false
} }
}
// HACK: Disable WGL swap interval when desktop composition is enabled to
// avoid interfering with DWM vsync
if enabled { if enabled {
interval = 0 interval = 0
} }
} }
}
if _glfw.platformContext.EXT_swap_control { if _glfw.platformContext.EXT_swap_control {
if err := wglSwapIntervalEXT(int32(interval)); err != nil { if err := wglSwapIntervalEXT(int32(interval)); err != nil {