Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-winehq
Project
Project
Details
Activity
Cycle Analytics
Repository
Repository
Files
Commits
Branches
Tags
Contributors
Graph
Compare
Charts
Issues
0
Issues
0
List
Board
Labels
Milestones
Merge Requests
0
Merge Requests
0
CI / CD
CI / CD
Pipelines
Jobs
Schedules
Charts
Registry
Registry
Wiki
Wiki
Snippets
Snippets
Members
Members
Collapse sidebar
Close sidebar
Activity
Graph
Charts
Create a new issue
Jobs
Commits
Issue Boards
Open sidebar
wine
wine-winehq
Commits
5f99b59e
Commit
5f99b59e
authored
May 08, 2012
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winex11: Add an OpenGL GDI driver.
parent
eb80e6f2
Expand all
Hide whitespace changes
Inline
Side-by-side
Showing
4 changed files
with
97 additions
and
37 deletions
+97
-37
init.c
dlls/winex11.drv/init.c
+96
-13
opengl.c
dlls/winex11.drv/opengl.c
+0
-0
x11drv.h
dlls/winex11.drv/x11drv.h
+1
-23
x11drv_main.c
dlls/winex11.drv/x11drv_main.c
+0
-1
No files found.
dlls/winex11.drv/init.c
View file @
5f99b59e
...
...
@@ -134,6 +134,7 @@ static X11DRV_PDEVICE *create_x11_physdev( Drawable drawable )
static
BOOL
X11DRV_CreateDC
(
PHYSDEV
*
pdev
,
LPCWSTR
driver
,
LPCWSTR
device
,
LPCWSTR
output
,
const
DEVMODEW
*
initData
)
{
const
struct
gdi_dc_funcs
*
glx_funcs
=
get_glx_driver
();
X11DRV_PDEVICE
*
physDev
=
create_x11_physdev
(
root_window
);
if
(
!
physDev
)
return
FALSE
;
...
...
@@ -144,8 +145,9 @@ static BOOL X11DRV_CreateDC( PHYSDEV *pdev, LPCWSTR driver, LPCWSTR device,
SetRect
(
&
physDev
->
dc_rect
,
0
,
0
,
virtual_screen_rect
.
right
-
virtual_screen_rect
.
left
,
virtual_screen_rect
.
bottom
-
virtual_screen_rect
.
top
);
push_dc_driver
(
pdev
,
&
physDev
->
dev
,
&
x11drv_funcs
);
if
(
!
xrender_funcs
)
return
TRUE
;
return
xrender_funcs
->
pCreateDC
(
pdev
,
driver
,
device
,
output
,
initData
);
if
(
xrender_funcs
&&
!
xrender_funcs
->
pCreateDC
(
pdev
,
driver
,
device
,
output
,
initData
))
return
FALSE
;
if
(
glx_funcs
&&
!
glx_funcs
->
pCreateDC
(
pdev
,
driver
,
device
,
output
,
initData
))
return
FALSE
;
return
TRUE
;
}
...
...
@@ -154,6 +156,7 @@ static BOOL X11DRV_CreateDC( PHYSDEV *pdev, LPCWSTR driver, LPCWSTR device,
*/
static
BOOL
X11DRV_CreateCompatibleDC
(
PHYSDEV
orig
,
PHYSDEV
*
pdev
)
{
const
struct
gdi_dc_funcs
*
glx_funcs
=
get_glx_driver
();
X11DRV_PDEVICE
*
physDev
=
create_x11_physdev
(
BITMAP_stock_phys_bitmap
.
pixmap
);
if
(
!
physDev
)
return
FALSE
;
...
...
@@ -167,8 +170,9 @@ static BOOL X11DRV_CreateCompatibleDC( PHYSDEV orig, PHYSDEV *pdev )
physDev
->
dc_rect
=
physDev
->
drawable_rect
;
push_dc_driver
(
pdev
,
&
physDev
->
dev
,
&
x11drv_funcs
);
if
(
orig
)
return
TRUE
;
/* we already went through Xrender if we have an orig device */
if
(
!
xrender_funcs
)
return
TRUE
;
return
xrender_funcs
->
pCreateCompatibleDC
(
NULL
,
pdev
);
if
(
xrender_funcs
&&
!
xrender_funcs
->
pCreateCompatibleDC
(
NULL
,
pdev
))
return
FALSE
;
if
(
glx_funcs
&&
!
glx_funcs
->
pCreateCompatibleDC
(
NULL
,
pdev
))
return
FALSE
;
return
TRUE
;
}
...
...
@@ -435,6 +439,85 @@ static INT X11DRV_ExtEscape( PHYSDEV dev, INT escape, INT in_count, LPCVOID in_d
}
static
inline
void
opengl_error
(
void
)
{
static
int
warned
;
if
(
!
warned
++
)
ERR
(
"No OpenGL support compiled in.
\n
"
);
}
/***********************************************************************
* X11DRV_ChoosePixelFormat
*/
static
int
X11DRV_ChoosePixelFormat
(
PHYSDEV
dev
,
const
PIXELFORMATDESCRIPTOR
*
ppfd
)
{
opengl_error
();
return
0
;
}
/***********************************************************************
* X11DRV_DescribePixelFormat
*/
static
int
X11DRV_DescribePixelFormat
(
PHYSDEV
dev
,
int
fmt
,
UINT
size
,
PIXELFORMATDESCRIPTOR
*
ppfd
)
{
opengl_error
();
return
0
;
}
/***********************************************************************
* X11DRV_SetPixelFormat
*/
static
BOOL
X11DRV_SetPixelFormat
(
PHYSDEV
dev
,
int
fmt
,
const
PIXELFORMATDESCRIPTOR
*
ppfd
)
{
opengl_error
();
return
FALSE
;
}
/***********************************************************************
* X11DRV_wglCreateContext
*/
static
HGLRC
X11DRV_wglCreateContext
(
PHYSDEV
dev
)
{
opengl_error
();
return
NULL
;
}
/***********************************************************************
* X11DRV_wglCreateContextAttribsARB
*/
static
HGLRC
X11DRV_wglCreateContextAttribsARB
(
PHYSDEV
dev
,
HGLRC
hShareContext
,
const
int
*
attribList
)
{
opengl_error
();
return
NULL
;
}
/***********************************************************************
* X11DRV_wglGetProcAddress
*/
static
PROC
X11DRV_wglGetProcAddress
(
LPCSTR
proc
)
{
opengl_error
();
return
NULL
;
}
/***********************************************************************
* X11DRV_wglGetPbufferDCARB
*/
static
HDC
X11DRV_wglGetPbufferDCARB
(
PHYSDEV
dev
,
void
*
hPbuffer
)
{
opengl_error
();
return
NULL
;
}
/***********************************************************************
* X11DRV_wglSetPixelFormatWINE
*/
static
BOOL
X11DRV_wglSetPixelFormatWINE
(
PHYSDEV
dev
,
int
fmt
,
const
PIXELFORMATDESCRIPTOR
*
ppfd
)
{
opengl_error
();
return
FALSE
;
}
static
const
struct
gdi_dc_funcs
x11drv_funcs
=
{
NULL
,
/* pAbortDoc */
...
...
@@ -492,7 +575,7 @@ static const struct gdi_dc_funcs x11drv_funcs =
X11DRV_GetNearestColor
,
/* pGetNearestColor */
NULL
,
/* pGetOutlineTextMetrics */
NULL
,
/* pGetPixel */
X11DRV_GetPixelFormat
,
/* pGetPixelFormat */
NULL
,
/* pGetPixelFormat */
X11DRV_GetSystemPaletteEntries
,
/* pGetSystemPaletteEntries */
NULL
,
/* pGetTextCharsetInfo */
NULL
,
/* pGetTextExtentExPoint */
...
...
@@ -568,21 +651,21 @@ static const struct gdi_dc_funcs x11drv_funcs =
NULL
,
/* pStretchDIBits */
NULL
,
/* pStrokeAndFillPath */
NULL
,
/* pStrokePath */
X11DRV_SwapBuffers
,
/* pSwapBuffers */
NULL
,
/* pSwapBuffers */
X11DRV_UnrealizePalette
,
/* pUnrealizePalette */
NULL
,
/* pWidenPath */
X11DRV_wglCopyContext
,
/* pwglCopyContext */
NULL
,
/* pwglCopyContext */
X11DRV_wglCreateContext
,
/* pwglCreateContext */
X11DRV_wglCreateContextAttribsARB
,
/* pwglCreateContextAttribsARB */
X11DRV_wglDeleteContext
,
/* pwglDeleteContext */
NULL
,
/* pwglDeleteContext */
X11DRV_wglGetPbufferDCARB
,
/* pwglGetPbufferDCARB */
X11DRV_wglGetProcAddress
,
/* pwglGetProcAddress */
X11DRV_wglMakeContextCurrentARB
,
/* pwglMakeContextCurrentARB */
X11DRV_wglMakeCurrent
,
/* pwglMakeCurrent */
NULL
,
/* pwglMakeContextCurrentARB */
NULL
,
/* pwglMakeCurrent */
X11DRV_wglSetPixelFormatWINE
,
/* pwglSetPixelFormatWINE */
X11DRV_wglShareLists
,
/* pwglShareLists */
X11DRV_wglUseFontBitmapsA
,
/* pwglUseFontBitmapsA */
X11DRV_wglUseFontBitmapsW
,
/* pwglUseFontBitmapsW */
NULL
,
/* pwglShareLists */
NULL
,
/* pwglUseFontBitmapsA */
NULL
,
/* pwglUseFontBitmapsW */
GDI_PRIORITY_GRAPHICS_DRV
/* priority */
};
...
...
dlls/winex11.drv/opengl.c
View file @
5f99b59e
This diff is collapsed.
Click to expand it.
dlls/winex11.drv/x11drv.h
View file @
5f99b59e
...
...
@@ -216,32 +216,9 @@ extern COLORREF X11DRV_SetDCPenColor( PHYSDEV dev, COLORREF crColor ) DECLSPEC_H
extern
void
X11DRV_SetDeviceClipping
(
PHYSDEV
dev
,
HRGN
rgn
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_SetDeviceGammaRamp
(
PHYSDEV
dev
,
LPVOID
ramp
)
DECLSPEC_HIDDEN
;
extern
COLORREF
X11DRV_SetPixel
(
PHYSDEV
dev
,
INT
x
,
INT
y
,
COLORREF
color
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_SetPixelFormat
(
PHYSDEV
dev
,
int
iPixelFormat
,
const
PIXELFORMATDESCRIPTOR
*
ppfd
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_StretchBlt
(
PHYSDEV
dst_dev
,
struct
bitblt_coords
*
dst
,
PHYSDEV
src_dev
,
struct
bitblt_coords
*
src
,
DWORD
rop
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_UnrealizePalette
(
HPALETTE
hpal
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglCopyContext
(
HGLRC
hglrcSrc
,
HGLRC
hglrcDst
,
UINT
mask
)
DECLSPEC_HIDDEN
;
extern
HGLRC
X11DRV_wglCreateContext
(
PHYSDEV
dev
)
DECLSPEC_HIDDEN
;
extern
HGLRC
X11DRV_wglCreateContextAttribsARB
(
PHYSDEV
dev
,
HGLRC
hShareContext
,
const
int
*
attribList
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglDeleteContext
(
HGLRC
hglrc
)
DECLSPEC_HIDDEN
;
extern
PROC
X11DRV_wglGetProcAddress
(
LPCSTR
proc
)
DECLSPEC_HIDDEN
;
extern
HDC
X11DRV_wglGetPbufferDCARB
(
PHYSDEV
dev
,
void
*
pbuffer
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglMakeContextCurrentARB
(
PHYSDEV
draw_dev
,
PHYSDEV
read_dev
,
HGLRC
hglrc
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglMakeCurrent
(
PHYSDEV
dev
,
HGLRC
hglrc
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglSetPixelFormatWINE
(
PHYSDEV
dev
,
int
iPixelFormat
,
const
PIXELFORMATDESCRIPTOR
*
ppfd
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglShareLists
(
HGLRC
hglrc1
,
HGLRC
hglrc2
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglUseFontBitmapsA
(
PHYSDEV
dev
,
DWORD
first
,
DWORD
count
,
DWORD
listBase
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_wglUseFontBitmapsW
(
PHYSDEV
dev
,
DWORD
first
,
DWORD
count
,
DWORD
listBase
)
DECLSPEC_HIDDEN
;
/* OpenGL / X11 driver functions */
extern
int
X11DRV_ChoosePixelFormat
(
PHYSDEV
dev
,
const
PIXELFORMATDESCRIPTOR
*
pppfd
)
DECLSPEC_HIDDEN
;
extern
int
X11DRV_DescribePixelFormat
(
PHYSDEV
dev
,
int
iPixelFormat
,
UINT
nBytes
,
PIXELFORMATDESCRIPTOR
*
ppfd
)
DECLSPEC_HIDDEN
;
extern
int
X11DRV_GetPixelFormat
(
PHYSDEV
dev
)
DECLSPEC_HIDDEN
;
extern
BOOL
X11DRV_SwapBuffers
(
PHYSDEV
dev
)
DECLSPEC_HIDDEN
;
extern
void
X11DRV_OpenGL_Cleanup
(
void
)
DECLSPEC_HIDDEN
;
/* X11 driver internal functions */
...
...
@@ -280,6 +257,7 @@ extern int client_side_antialias_with_render DECLSPEC_HIDDEN;
extern
const
struct
gdi_dc_funcs
*
X11DRV_XRender_Init
(
void
)
DECLSPEC_HIDDEN
;
extern
void
X11DRV_XRender_Finalize
(
void
)
DECLSPEC_HIDDEN
;
extern
const
struct
gdi_dc_funcs
*
get_glx_driver
(
void
)
DECLSPEC_HIDDEN
;
extern
BOOL
destroy_glxpixmap
(
Display
*
display
,
XID
glxpixmap
)
DECLSPEC_HIDDEN
;
/* IME support */
...
...
dlls/winex11.drv/x11drv_main.c
View file @
5f99b59e
...
...
@@ -633,7 +633,6 @@ static void process_detach(void)
/* cleanup GDI */
X11DRV_GDI_Finalize
();
X11DRV_OpenGL_Cleanup
();
IME_UnregisterClasses
();
DeleteCriticalSection
(
&
X11DRV_CritSection
);
...
...
Write
Preview
Markdown
is supported
0%
Try again
or
attach a new file
Attach a file
Cancel
You are about to add
0
people
to the discussion. Proceed with caution.
Finish editing this message first!
Cancel
Please
register
or
sign in
to comment