Henri Verbeet : dxgi: Convert DXGI_FORMAT values to WINED3DFORMAT values.

Alexandre Julliard julliard at winehq.org
Fri Feb 20 12:49:31 CST 2009


Module: wine
Branch: master
Commit: 8afd92154df3169c8f68e18be47d7cb5bfb438b0
URL:    http://source.winehq.org/git/wine.git/?a=commit;h=8afd92154df3169c8f68e18be47d7cb5bfb438b0

Author: Henri Verbeet <hverbeet at codeweavers.com>
Date:   Thu Feb 19 16:59:42 2009 +0100

dxgi: Convert DXGI_FORMAT values to WINED3DFORMAT values.

---

 dlls/dxgi/device.c       |    7 ++-
 dlls/dxgi/dxgi_private.h |    2 +
 dlls/dxgi/utils.c        |   99 ++++++++++++++++++++++++++++++++++++++++++++++
 3 files changed, 105 insertions(+), 3 deletions(-)

diff --git a/dlls/dxgi/device.c b/dlls/dxgi/device.c
index 3c10f99..5c3fdfc 100644
--- a/dlls/dxgi/device.c
+++ b/dlls/dxgi/device.c
@@ -160,7 +160,7 @@ static HRESULT STDMETHODCALLTYPE dxgi_device_CreateSurface(IWineDXGIDevice *ifac
         return E_FAIL;
     }
 
-    FIXME("Implement DXGI<->wined3d format and usage conversion\n");
+    FIXME("Implement DXGI<->wined3d usage conversion\n");
 
     memset(surface, 0, surface_count * sizeof(*surface));
     for (i = 0; i < surface_count; ++i)
@@ -168,8 +168,9 @@ static HRESULT STDMETHODCALLTYPE dxgi_device_CreateSurface(IWineDXGIDevice *ifac
         IWineD3DSurface *wined3d_surface;
         IUnknown *parent;
 
-        hr = IWineD3DDeviceParent_CreateSurface(device_parent, NULL, desc->Width, desc->Height, desc->Format,
-                usage, WINED3DPOOL_DEFAULT, 0, WINED3DCUBEMAP_FACE_POSITIVE_X, &wined3d_surface);
+        hr = IWineD3DDeviceParent_CreateSurface(device_parent, NULL, desc->Width, desc->Height,
+                wined3dformat_from_dxgi_format(desc->Format), usage, WINED3DPOOL_DEFAULT, 0,
+                WINED3DCUBEMAP_FACE_POSITIVE_X, &wined3d_surface);
         if (FAILED(hr))
         {
             ERR("CreateSurface failed, returning %#x\n", hr);
diff --git a/dlls/dxgi/dxgi_private.h b/dlls/dxgi/dxgi_private.h
index 4e6901c..90ed4dc 100644
--- a/dlls/dxgi/dxgi_private.h
+++ b/dlls/dxgi/dxgi_private.h
@@ -39,6 +39,8 @@ extern CRITICAL_SECTION dxgi_cs;
 /* TRACE helper functions */
 const char *debug_dxgi_format(DXGI_FORMAT format);
 
+WINED3DFORMAT wined3dformat_from_dxgi_format(DXGI_FORMAT format);
+
 /* IDXGIFactory */
 extern const struct IWineDXGIFactoryVtbl dxgi_factory_vtbl;
 struct dxgi_factory
diff --git a/dlls/dxgi/utils.c b/dlls/dxgi/utils.c
index be3949f..c2999f8 100644
--- a/dlls/dxgi/utils.c
+++ b/dlls/dxgi/utils.c
@@ -126,3 +126,102 @@ const char *debug_dxgi_format(DXGI_FORMAT format)
 }
 
 #undef WINE_DXGI_TO_STR
+
+WINED3DFORMAT wined3dformat_from_dxgi_format(DXGI_FORMAT format)
+{
+    switch(format)
+    {
+        case DXGI_FORMAT_UNKNOWN: return WINED3DFMT_UNKNOWN;
+        case DXGI_FORMAT_R32G32B32A32_TYPELESS: return WINED3DFMT_R32G32B32A32_TYPELESS;
+        case DXGI_FORMAT_R32G32B32A32_FLOAT: return WINED3DFMT_R32G32B32A32_FLOAT;
+        case DXGI_FORMAT_R32G32B32A32_UINT: return WINED3DFMT_R32G32B32A32_UINT;
+        case DXGI_FORMAT_R32G32B32A32_SINT: return WINED3DFMT_R32G32B32A32_SINT;
+        case DXGI_FORMAT_R32G32B32_TYPELESS: return WINED3DFMT_R32G32B32_TYPELESS;
+        case DXGI_FORMAT_R32G32B32_FLOAT: return WINED3DFMT_R32G32B32_FLOAT;
+        case DXGI_FORMAT_R32G32B32_UINT: return WINED3DFMT_R32G32B32_UINT;
+        case DXGI_FORMAT_R32G32B32_SINT: return WINED3DFMT_R32G32B32_SINT;
+        case DXGI_FORMAT_R16G16B16A16_TYPELESS: return WINED3DFMT_R16G16B16A16_TYPELESS;
+        case DXGI_FORMAT_R16G16B16A16_FLOAT: return WINED3DFMT_R16G16B16A16_FLOAT;
+        case DXGI_FORMAT_R16G16B16A16_UNORM: return WINED3DFMT_R16G16B16A16_UNORM;
+        case DXGI_FORMAT_R16G16B16A16_UINT: return WINED3DFMT_R16G16B16A16_UINT;
+        case DXGI_FORMAT_R16G16B16A16_SNORM: return WINED3DFMT_R16G16B16A16_SNORM;
+        case DXGI_FORMAT_R16G16B16A16_SINT: return WINED3DFMT_R16G16B16A16_SINT;
+        case DXGI_FORMAT_R32G32_TYPELESS: return WINED3DFMT_R32G32_TYPELESS;
+        case DXGI_FORMAT_R32G32_FLOAT: return WINED3DFMT_R32G32_FLOAT;
+        case DXGI_FORMAT_R32G32_UINT: return WINED3DFMT_R32G32_UINT;
+        case DXGI_FORMAT_R32G32_SINT: return WINED3DFMT_R32G32_SINT;
+        case DXGI_FORMAT_R32G8X24_TYPELESS: return WINED3DFMT_R32G8X24_TYPELESS;
+        case DXGI_FORMAT_D32_FLOAT_S8X24_UINT: return WINED3DFMT_D32_FLOAT_S8X24_UINT;
+        case DXGI_FORMAT_R32_FLOAT_X8X24_TYPELESS: return WINED3DFMT_R32_FLOAT_X8X24_TYPELESS;
+        case DXGI_FORMAT_X32_TYPELESS_G8X24_UINT: return WINED3DFMT_X32_TYPELESS_G8X24_UINT;
+        case DXGI_FORMAT_R10G10B10A2_TYPELESS: return WINED3DFMT_R10G10B10A2_TYPELESS;
+        case DXGI_FORMAT_R10G10B10A2_UNORM: return WINED3DFMT_R10G10B10A2_UNORM;
+        case DXGI_FORMAT_R10G10B10A2_UINT: return WINED3DFMT_R10G10B10A2_UINT;
+        case DXGI_FORMAT_R11G11B10_FLOAT: return WINED3DFMT_R11G11B10_FLOAT;
+        case DXGI_FORMAT_R8G8B8A8_TYPELESS: return WINED3DFMT_R8G8B8A8_TYPELESS;
+        case DXGI_FORMAT_R8G8B8A8_UNORM: return WINED3DFMT_R8G8B8A8_UNORM;
+        case DXGI_FORMAT_R8G8B8A8_UNORM_SRGB: return WINED3DFMT_R8G8B8A8_UNORM_SRGB;
+        case DXGI_FORMAT_R8G8B8A8_UINT: return WINED3DFMT_R8G8B8A8_UINT;
+        case DXGI_FORMAT_R8G8B8A8_SNORM: return WINED3DFMT_R8G8B8A8_SNORM;
+        case DXGI_FORMAT_R8G8B8A8_SINT: return WINED3DFMT_R8G8B8A8_SINT;
+        case DXGI_FORMAT_R16G16_TYPELESS: return WINED3DFMT_R16G16_TYPELESS;
+        case DXGI_FORMAT_R16G16_FLOAT: return WINED3DFMT_R16G16_FLOAT;
+        case DXGI_FORMAT_R16G16_UNORM: return WINED3DFMT_R16G16_UNORM;
+        case DXGI_FORMAT_R16G16_UINT: return WINED3DFMT_R16G16_UINT;
+        case DXGI_FORMAT_R16G16_SNORM: return WINED3DFMT_R16G16_SNORM;
+        case DXGI_FORMAT_R16G16_SINT: return WINED3DFMT_R16G16_SINT;
+        case DXGI_FORMAT_R32_TYPELESS: return WINED3DFMT_R32_TYPELESS;
+        case DXGI_FORMAT_D32_FLOAT: return WINED3DFMT_D32_FLOAT;
+        case DXGI_FORMAT_R32_FLOAT: return WINED3DFMT_R32_FLOAT;
+        case DXGI_FORMAT_R32_UINT: return WINED3DFMT_R32_UINT;
+        case DXGI_FORMAT_R32_SINT: return WINED3DFMT_R32_SINT;
+        case DXGI_FORMAT_R24G8_TYPELESS: return WINED3DFMT_R24G8_TYPELESS;
+        case DXGI_FORMAT_D24_UNORM_S8_UINT: return WINED3DFMT_D24_UNORM_S8_UINT;
+        case DXGI_FORMAT_R24_UNORM_X8_TYPELESS: return WINED3DFMT_R24_UNORM_X8_TYPELESS;
+        case DXGI_FORMAT_X24_TYPELESS_G8_UINT: return WINED3DFMT_X24_TYPELESS_G8_UINT;
+        case DXGI_FORMAT_R8G8_TYPELESS: return WINED3DFMT_R8G8_TYPELESS;
+        case DXGI_FORMAT_R8G8_UNORM: return WINED3DFMT_R8G8_UNORM;
+        case DXGI_FORMAT_R8G8_UINT: return WINED3DFMT_R8G8_UINT;
+        case DXGI_FORMAT_R8G8_SNORM: return WINED3DFMT_R8G8_SNORM;
+        case DXGI_FORMAT_R8G8_SINT: return WINED3DFMT_R8G8_SINT;
+        case DXGI_FORMAT_R16_TYPELESS: return WINED3DFMT_R16_TYPELESS;
+        case DXGI_FORMAT_R16_FLOAT: return WINED3DFMT_R16_FLOAT;
+        case DXGI_FORMAT_D16_UNORM: return WINED3DFMT_D16_UNORM;
+        case DXGI_FORMAT_R16_UNORM: return WINED3DFMT_R16_UNORM;
+        case DXGI_FORMAT_R16_UINT: return WINED3DFMT_R16_UINT;
+        case DXGI_FORMAT_R16_SNORM: return WINED3DFMT_R16_SNORM;
+        case DXGI_FORMAT_R16_SINT: return WINED3DFMT_R16_SINT;
+        case DXGI_FORMAT_R8_TYPELESS: return WINED3DFMT_R8_TYPELESS;
+        case DXGI_FORMAT_R8_UNORM: return WINED3DFMT_R8_UNORM;
+        case DXGI_FORMAT_R8_UINT: return WINED3DFMT_R8_UINT;
+        case DXGI_FORMAT_R8_SNORM: return WINED3DFMT_R8_SNORM;
+        case DXGI_FORMAT_R8_SINT: return WINED3DFMT_R8_SINT;
+        case DXGI_FORMAT_A8_UNORM: return WINED3DFMT_A8_UNORM;
+        case DXGI_FORMAT_R1_UNORM: return WINED3DFMT_R1_UNORM;
+        case DXGI_FORMAT_R9G9B9E5_SHAREDEXP: return WINED3DFMT_R9G9B9E5_SHAREDEXP;
+        case DXGI_FORMAT_R8G8_B8G8_UNORM: return WINED3DFMT_R8G8_B8G8_UNORM;
+        case DXGI_FORMAT_G8R8_G8B8_UNORM: return WINED3DFMT_G8R8_G8B8_UNORM;
+        case DXGI_FORMAT_BC1_TYPELESS: return WINED3DFMT_BC1_TYPELESS;
+        case DXGI_FORMAT_BC1_UNORM: return WINED3DFMT_BC1_UNORM;
+        case DXGI_FORMAT_BC1_UNORM_SRGB: return WINED3DFMT_BC1_UNORM_SRGB;
+        case DXGI_FORMAT_BC2_TYPELESS: return WINED3DFMT_BC2_TYPELESS;
+        case DXGI_FORMAT_BC2_UNORM: return WINED3DFMT_BC2_UNORM;
+        case DXGI_FORMAT_BC2_UNORM_SRGB: return WINED3DFMT_BC2_UNORM_SRGB;
+        case DXGI_FORMAT_BC3_TYPELESS: return WINED3DFMT_BC3_TYPELESS;
+        case DXGI_FORMAT_BC3_UNORM: return WINED3DFMT_BC3_UNORM;
+        case DXGI_FORMAT_BC3_UNORM_SRGB: return WINED3DFMT_BC3_UNORM_SRGB;
+        case DXGI_FORMAT_BC4_TYPELESS: return WINED3DFMT_BC4_TYPELESS;
+        case DXGI_FORMAT_BC4_UNORM: return WINED3DFMT_BC4_UNORM;
+        case DXGI_FORMAT_BC4_SNORM: return WINED3DFMT_BC4_SNORM;
+        case DXGI_FORMAT_BC5_TYPELESS: return WINED3DFMT_BC5_TYPELESS;
+        case DXGI_FORMAT_BC5_UNORM: return WINED3DFMT_BC5_UNORM;
+        case DXGI_FORMAT_BC5_SNORM: return WINED3DFMT_BC5_SNORM;
+        case DXGI_FORMAT_B5G6R5_UNORM: return WINED3DFMT_B5G6R5_UNORM;
+        case DXGI_FORMAT_B5G5R5A1_UNORM: return WINED3DFMT_B5G5R5A1_UNORM;
+        case DXGI_FORMAT_B8G8R8A8_UNORM: return WINED3DFMT_B8G8R8A8_UNORM;
+        case DXGI_FORMAT_B8G8R8X8_UNORM: return WINED3DFMT_B8G8R8X8_UNORM;
+        default:
+            FIXME("Unhandled DXGI_FORMAT %#x\n", format);
+            return WINED3DFMT_UNKNOWN;
+    }
+}




More information about the wine-cvs mailing list