- Timestamp:
- Aug 20, 2010 5:12:14 PM (14 years ago)
- Location:
- trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d
- Files:
-
- 10 edited
Legend:
- Unmodified
- Added
- Removed
-
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/basetexture.c
r30916 r31828 39 39 HRESULT basetexture_init(IWineD3DBaseTextureImpl *texture, UINT levels, WINED3DRESOURCETYPE resource_type, 40 40 IWineD3DDeviceImpl *device, UINT size, DWORD usage, const struct wined3d_format_desc *format_desc, 41 WINED3DPOOL pool, IUnknown *parent, const struct wined3d_parent_ops *parent_ops) 41 WINED3DPOOL pool, IUnknown *parent, const struct wined3d_parent_ops *parent_ops 42 #ifdef VBOXWDDM 43 , HANDLE *shared_handle 44 , void *pvClientMem 45 #endif 46 ) 42 47 { 43 48 HRESULT hr; … … 46 51 size, usage, format_desc, pool, parent, parent_ops 47 52 #ifdef VBOXWDDM 48 , NULL, NULL /* <- no need this info here */53 , shared_handle, pvClientMem 49 54 #endif 50 55 ); … … 262 267 if (gl_tex->name == 0) { 263 268 *set_surface_desc = TRUE; 264 glGenTextures(1, &gl_tex->name); 269 #ifdef VBOXWDDM 270 if (VBOXSHRC_IS_SHARED_OPENED(This)) 271 { 272 gl_tex->name = VBOXSHRC_GET_SHAREHANDLE(This); 273 } 274 else 275 #endif 276 { 277 glGenTextures(1, &gl_tex->name); 278 #ifdef VBOXWDDM 279 if (VBOXSHRC_IS_SHARED(This)) 280 { 281 VBOXSHRC_SET_SHAREHANDLE(This, gl_tex->name); 282 } 283 #endif 284 } 265 285 checkGLcall("glGenTextures"); 266 286 TRACE("Generated texture %d\n", gl_tex->name); -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/context.c
r30719 r31828 1508 1508 GL_EXTCALL(glProvokingVertexEXT(GL_FIRST_VERTEX_CONVENTION_EXT)); 1509 1509 } 1510 1511 #ifdef VBOXWDDM 1512 GL_EXTCALL(glChromiumParameteriCR(GL_SHARE_CONTEXT_RESOURCES_CR, GL_TRUE)); 1513 #endif 1510 1514 1511 1515 LEAVE_GL(); -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/cubetexture.c
r30916 r31828 489 489 490 490 hr = basetexture_init((IWineD3DBaseTextureImpl *)texture, levels, WINED3DRTYPE_CUBETEXTURE, 491 device, 0, usage, format_desc, pool, parent, parent_ops); 491 device, 0, usage, format_desc, pool, parent, parent_ops 492 #ifdef VBOXWDDM 493 , NULL 494 , NULL 495 #endif 496 ); 492 497 if (FAILED(hr)) 493 498 { -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/directx.c
r29452 r31828 2182 2182 gl_info->supported[WINED3D_GL_EXT_NONE] = TRUE; 2183 2183 2184 #ifdef VBOXWDDM 2185 gl_info->supported[VBOX_SHARED_CONTEXTS] = TRUE; 2186 #endif 2187 2184 2188 while (*GL_Extensions) 2185 2189 { -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/resource.c
r30916 r31828 66 66 resource->heapMemory = NULL; 67 67 } 68 else if (pool == WINED3DPOOL_DEFAULT && shared_handle) 69 { 70 resource->allocatedMemory = NULL; 71 resource->heapMemory = NULL; 72 resource->sharerc_handle = shared_handle; 73 resource->sharerc_flags = VBOXSHRC_F_SHARED; 74 if (*shared_handle) 75 resource->sharerc_flags |= VBOXSHRC_F_SHARED_OPENED; 76 } 68 77 else 69 78 #endif -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/surface.c
r30916 r31828 482 482 return hr; 483 483 } 484 #ifdef VBOXWDDM 485 if (shared_handle && !*shared_handle) 486 { 487 *shared_handle = VBOXSHRC_GET_SHAREHANDLE(surface); 488 } 489 #endif 484 490 485 491 return hr; … … 521 527 } 522 528 529 #ifdef VBOXWDDM 530 if (VBOXSHRC_IS_SHARED(This)) 531 { 532 VBOXSHRC_SET_SHAREHANDLE(This, new_name); 533 } 534 #endif 523 535 *name = new_name; 524 536 surface_force_reload(iface); … … 979 991 } 980 992 993 #ifdef VBOXWDDM 994 static HRESULT WINAPI IWineD3DSurfaceImpl_LoadLocation(IWineD3DSurface *iface, DWORD flag, const RECT *rect); 995 #endif 996 981 997 /* Slightly inefficient way to handle multiple dirty rects but it works :) */ 982 998 void surface_add_dirty_rect(IWineD3DSurface *iface, const RECT *dirty_rect) … … 985 1001 IWineD3DBaseTexture *baseTexture = NULL; 986 1002 987 if (!(This->Flags & SFLAG_INSYSMEM) && (This->Flags & SFLAG_INTEXTURE)) 988 IWineD3DSurface_LoadLocation(iface, SFLAG_INSYSMEM, NULL /* no partial locking for textures yet */); 989 990 IWineD3DSurface_ModifyLocation(iface, SFLAG_INSYSMEM, TRUE); 1003 #ifdef VBOXWDDM 1004 if (VBOXSHRC_IS_SHARED(This)) 1005 { 1006 if (!VBOXSHRC_IS_SHARED_OPENED(This)) 1007 IWineD3DSurfaceImpl_LoadLocation(iface, SFLAG_INTEXTURE, NULL); 1008 else 1009 This->Flags |= SFLAG_INTEXTURE; 1010 } 1011 else 1012 #endif 1013 { 1014 if (!(This->Flags & SFLAG_INSYSMEM) && (This->Flags & SFLAG_INTEXTURE)) 1015 IWineD3DSurface_LoadLocation(iface, SFLAG_INSYSMEM, NULL /* no partial locking for textures yet */); 1016 1017 IWineD3DSurface_ModifyLocation(iface, SFLAG_INSYSMEM, TRUE); 1018 } 1019 991 1020 if (dirty_rect) 992 1021 { … … 2601 2630 { 2602 2631 if (!*name) { 2603 glGenTextures(1, name); 2632 #ifdef VBOXWDDM 2633 if (VBOXSHRC_IS_SHARED_OPENED(This)) 2634 { 2635 *name = VBOXSHRC_GET_SHAREHANDLE(This); 2636 } 2637 else 2638 #endif 2639 { 2640 glGenTextures(1, name); 2641 #ifdef VBOXWDDM 2642 if (VBOXSHRC_IS_SHARED(This)) 2643 { 2644 VBOXSHRC_SET_SHAREHANDLE(This, *name); 2645 } 2646 #endif 2647 } 2604 2648 checkGLcall("glGenTextures"); 2605 2649 TRACE("Surface %p given name %d\n", This, *name); … … 4022 4066 } 4023 4067 4024 This->Flags |= SFLAG_INSYSMEM; 4068 #ifdef VBOXWDDM 4069 if (!VBOXSHRC_IS_SHARED(This)) 4070 #endif 4071 { 4072 This->Flags |= SFLAG_INSYSMEM; 4073 } 4025 4074 4026 4075 return WINED3D_OK; -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/texture.c
r30916 r31828 513 513 514 514 hr = basetexture_init((IWineD3DBaseTextureImpl *)texture, levels, WINED3DRTYPE_TEXTURE, 515 device, 0, usage, format_desc, pool, parent, parent_ops); 515 device, 0, usage, format_desc, pool, parent, parent_ops 516 #ifdef VBOXWDDM 517 , shared_handle, pvClientMem 518 #endif 519 ); 516 520 if (FAILED(hr)) 517 521 { -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/volumetexture.c
r28475 r31828 410 410 411 411 hr = basetexture_init((IWineD3DBaseTextureImpl *)texture, levels, WINED3DRTYPE_VOLUMETEXTURE, 412 device, 0, usage, format_desc, pool, parent, parent_ops); 412 device, 0, usage, format_desc, pool, parent, parent_ops 413 #ifdef VBOXWDDM 414 , NULL, NULL 415 #endif 416 ); 413 417 if (FAILED(hr)) 414 418 { -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/wined3d_gl.h
r28475 r31828 1842 1842 WGL_ARB_PIXEL_FORMAT, 1843 1843 WGL_WINE_PIXEL_FORMAT_PASSTHROUGH, 1844 1845 #ifdef VBOXWDDM 1846 VBOX_SHARED_CONTEXTS, 1847 #endif 1844 1848 /* Internally used */ 1845 1849 WINE_NORMALIZED_TEXRECT, … … 3768 3772 typedef BOOL (WINAPI *WINED3D_PFNWGLSETPIXELFORMATWINE)(HDC hdc, int iPixelFormat, 3769 3773 const PIXELFORMATDESCRIPTOR *ppfd); 3774 3775 #ifdef VBOXWDDM 3776 #define GL_SHARE_CONTEXT_RESOURCES_CR 0x8B27 3777 typedef void (WINE_GLAPI *PGLFNCHROMIUMPARAMETERUCR)(GLenum param, GLint value); 3778 3779 # define VBOXWDDM_GL_EXT_FUNCS_GEN \ 3780 USE_GL_FUNC(PGLFNCHROMIUMPARAMETERUCR, \ 3781 glChromiumParameteriCR, VBOX_SHARED_CONTEXTS, NULL) \ 3782 3783 #else 3784 # define VBOXWDDM_GL_EXT_FUNCS_GEN 3785 #endif 3770 3786 3771 3787 #define GL_EXT_FUNCS_GEN \ … … 4494 4510 glXGetVideoSyncSGI, SGI_VIDEO_SYNC, NULL) \ 4495 4511 USE_GL_FUNC(PGLXFNWAITVIDEOSYNCSGIPROC, \ 4496 glXWaitVideoSyncSGI, SGI_VIDEO_SYNC, NULL) 4512 glXWaitVideoSyncSGI, SGI_VIDEO_SYNC, NULL) \ 4513 VBOXWDDM_GL_EXT_FUNCS_GEN 4497 4514 4498 4515 #define WGL_EXT_FUNCS_GEN \ -
trunk/src/VBox/Additions/WINNT/Graphics/Wine/wined3d/wined3d_private.h
r30916 r31828 53 53 #include "wine/list.h" 54 54 #include "wine/rbtree.h" 55 56 #ifdef VBOXWDDM 57 # include "vboxsharedrc.h" 58 #endif 55 59 56 60 /* Driver quirks */ … … 1804 1808 BYTE *allocatedMemory; /* Pointer to the real data location */ 1805 1809 BYTE *heapMemory; /* Pointer to the HeapAlloced block of memory */ 1810 #ifdef VBOXWDDM 1811 DWORD sharerc_flags; /* shared resource flags */ 1812 DWORD sharerc_handle; 1813 #endif 1806 1814 struct list privateData; 1807 1815 struct list resource_list_entry; … … 1921 1929 HRESULT basetexture_init(IWineD3DBaseTextureImpl *texture, UINT levels, WINED3DRESOURCETYPE resource_type, 1922 1930 IWineD3DDeviceImpl *device, UINT size, DWORD usage, const struct wined3d_format_desc *format_desc, 1923 WINED3DPOOL pool, IUnknown *parent, const struct wined3d_parent_ops *parent_ops) DECLSPEC_HIDDEN; 1931 WINED3DPOOL pool, IUnknown *parent, const struct wined3d_parent_ops *parent_ops 1932 #ifdef VBOXWDDM 1933 , HANDLE *shared_handle 1934 , void *pvClientMem 1935 #endif 1936 ) DECLSPEC_HIDDEN; 1924 1937 HRESULT basetexture_set_autogen_filter_type(IWineD3DBaseTexture *iface, 1925 1938 WINED3DTEXTUREFILTERTYPE filter_type) DECLSPEC_HIDDEN; … … 2230 2243 #ifdef VBOXWDDM 2231 2244 # define SFLAG_CLIENTMEM 0x10000000 /* SYSMEM surface using client-supplied memory buffer */ 2232 2233 2245 # define SFLAG_DONOTFREE_VBOXWDDM SFLAG_CLIENTMEM 2234 2246 #else
Note:
See TracChangeset
for help on using the changeset viewer.