From f7662a63802d5d8601bd162840389b5a62d970e5 Mon Sep 17 00:00:00 2001 From: =?UTF-8?q?Stefan=20D=C3=B6singer?= Date: Tue, 15 Dec 2009 20:16:19 +0100 Subject: [PATCH 01/17] WineD3D: Don't render single buffered swapchains to a FBO --- dlls/wined3d/device.c | 9 +++++++-- dlls/wined3d/swapchain.c | 1 + 2 files changed, 8 insertions(+), 2 deletions(-) diff --git a/dlls/wined3d/device.c b/dlls/wined3d/device.c index a55f3e6..0063aa9 100644 --- a/dlls/wined3d/device.c +++ b/dlls/wined3d/device.c @@ -6527,8 +6527,13 @@ static HRESULT WINAPI IWineD3DDeviceImpl_Reset(IWineD3DDevice* iface, WINED3DPRE RECT client_rect; GetClientRect(swapchain->win_handle, &client_rect); - if(swapchain->presentParms.BackBufferWidth != client_rect.right || - swapchain->presentParms.BackBufferHeight != client_rect.bottom) + if(!swapchain->presentParms.BackBufferCount) + { + TRACE("Single buffered rendering\n"); + swapchain->render_to_fbo = FALSE; + } + else if(swapchain->presentParms.BackBufferWidth != client_rect.right || + swapchain->presentParms.BackBufferHeight != client_rect.bottom ) { TRACE("Rendering to FBO. Backbuffer %ux%u, window %ux%u\n", swapchain->presentParms.BackBufferWidth, diff --git a/dlls/wined3d/swapchain.c b/dlls/wined3d/swapchain.c index fb902ea..f1a61b4 100644 --- a/dlls/wined3d/swapchain.c +++ b/dlls/wined3d/swapchain.c @@ -739,6 +739,7 @@ HRESULT swapchain_init(IWineD3DSwapChainImpl *swapchain, WINED3DSURFTYPE surface swapchain->presentParms = *present_parameters; if (wined3d_settings.offscreen_rendering_mode == ORM_FBO + && present_parameters->BackBufferCount && (present_parameters->BackBufferWidth != client_rect.right || present_parameters->BackBufferHeight != client_rect.bottom)) { -- 1.6.4.4