Commit 40c5184a authored by Ken Thomases's avatar Ken Thomases Committed by Alexandre Julliard

winemac: Fix implementation of the AllowVerticalSync registry setting.

parent 14035b6d
...@@ -1539,7 +1539,6 @@ static BOOL create_context(struct wgl_context *context, CGLContextObj share, uns ...@@ -1539,7 +1539,6 @@ static BOOL create_context(struct wgl_context *context, CGLContextObj share, uns
} }
context->major = major; context->major = major;
if (allow_vsync)
InterlockedExchange(&context->update_swap_interval, TRUE); InterlockedExchange(&context->update_swap_interval, TRUE);
TRACE("created context %p/%p/%p\n", context, context->context, context->cglcontext); TRACE("created context %p/%p/%p\n", context, context->context, context->cglcontext);
...@@ -1742,7 +1741,9 @@ static void sync_swap_interval(struct wgl_context *context) ...@@ -1742,7 +1741,9 @@ static void sync_swap_interval(struct wgl_context *context)
{ {
int interval; int interval;
if (context->draw_hwnd) if (!allow_vsync)
interval = 0;
else if (context->draw_hwnd)
{ {
struct macdrv_win_data *data = get_win_data(context->draw_hwnd); struct macdrv_win_data *data = get_win_data(context->draw_hwnd);
if (data) if (data)
...@@ -3478,7 +3479,7 @@ static int macdrv_wglGetSwapIntervalEXT(void) ...@@ -3478,7 +3479,7 @@ static int macdrv_wglGetSwapIntervalEXT(void)
release_win_data(data); release_win_data(data);
if (InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE)) if (InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE))
set_swap_interval(context, value); set_swap_interval(context, allow_vsync ? value : 0);
} }
else else
{ {
...@@ -3543,8 +3544,8 @@ static BOOL macdrv_wglMakeContextCurrentARB(HDC draw_hdc, HDC read_hdc, struct w ...@@ -3543,8 +3544,8 @@ static BOOL macdrv_wglMakeContextCurrentARB(HDC draw_hdc, HDC read_hdc, struct w
return FALSE; return FALSE;
} }
if (allow_vsync && (InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE) || hwnd != context->draw_hwnd)) if (InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE) || hwnd != context->draw_hwnd)
set_swap_interval(context, data->swap_interval); set_swap_interval(context, allow_vsync ? data->swap_interval : 0);
context->draw_hwnd = hwnd; context->draw_hwnd = hwnd;
context->draw_view = data->client_cocoa_view; context->draw_view = data->client_cocoa_view;
...@@ -3569,8 +3570,7 @@ static BOOL macdrv_wglMakeContextCurrentARB(HDC draw_hdc, HDC read_hdc, struct w ...@@ -3569,8 +3570,7 @@ static BOOL macdrv_wglMakeContextCurrentARB(HDC draw_hdc, HDC read_hdc, struct w
return FALSE; return FALSE;
} }
if (allow_vsync && if (InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE) || pbuffer != context->draw_pbuffer)
(InterlockedCompareExchange(&context->update_swap_interval, FALSE, TRUE) || pbuffer != context->draw_pbuffer))
set_swap_interval(context, 0); set_swap_interval(context, 0);
} }
else else
...@@ -4115,6 +4115,9 @@ static BOOL macdrv_wglSwapIntervalEXT(int interval) ...@@ -4115,6 +4115,9 @@ static BOOL macdrv_wglSwapIntervalEXT(int interval)
else /* pbuffer */ else /* pbuffer */
interval = 0; interval = 0;
if (!allow_vsync)
interval = 0;
InterlockedExchange(&context->update_swap_interval, FALSE); InterlockedExchange(&context->update_swap_interval, FALSE);
if (!set_swap_interval(context, interval)) if (!set_swap_interval(context, interval))
{ {
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment