ddraw: Fix IDirectDrawSurfaceImpl_SetColorKey to also change surface_desc.
diff --git a/dlls/ddraw/surface.c b/dlls/ddraw/surface.c
index cab163b..03ea974 100644
--- a/dlls/ddraw/surface.c
+++ b/dlls/ddraw/surface.c
@@ -2037,6 +2037,58 @@
     HRESULT hr;
     TRACE("(%p)->(%x,%p)\n", This, Flags, CKey);
 
+    if (CKey)
+    {
+        switch (Flags & ~DDCKEY_COLORSPACE)
+        {
+        case DDCKEY_DESTBLT:
+            This->surface_desc.ddckCKDestBlt = *CKey;
+            This->surface_desc.dwFlags |= DDSD_CKDESTBLT;
+            break;
+
+        case DDCKEY_DESTOVERLAY:
+            This->surface_desc.u3.ddckCKDestOverlay = *CKey;
+            This->surface_desc.dwFlags |= DDSD_CKDESTOVERLAY;
+            break;
+
+        case DDCKEY_SRCOVERLAY:
+            This->surface_desc.ddckCKSrcOverlay = *CKey;
+            This->surface_desc.dwFlags |= DDSD_CKSRCOVERLAY;
+            break;
+
+        case DDCKEY_SRCBLT:
+            This->surface_desc.ddckCKSrcBlt = *CKey;
+            This->surface_desc.dwFlags |= DDSD_CKSRCBLT;
+            break;
+
+        default:
+            return DDERR_INVALIDPARAMS;
+        }
+    }
+    else
+    {
+        switch (Flags & ~DDCKEY_COLORSPACE)
+        {
+        case DDCKEY_DESTBLT:
+            This->surface_desc.dwFlags &= ~DDSD_CKDESTBLT;
+            break;
+
+        case DDCKEY_DESTOVERLAY:
+            This->surface_desc.dwFlags &= ~DDSD_CKDESTOVERLAY;
+            break;
+
+        case DDCKEY_SRCOVERLAY:
+            This->surface_desc.dwFlags &= ~DDSD_CKSRCOVERLAY;
+            break;
+
+        case DDCKEY_SRCBLT:
+            This->surface_desc.dwFlags &= ~DDSD_CKSRCBLT;
+            break;
+
+        default:
+            return DDERR_INVALIDPARAMS;
+        }
+    }
     for(surf = This->first_complex; surf; surf = surf->next_complex)
     {
         hr = IWineD3DSurface_SetColorKey(surf->WineD3DSurface,