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
7f4d3022
Commit
7f4d3022
authored
Jun 27, 2012
by
Alexandre Julliard
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
winex11: Use the GET_DRAWABLE escape to implement wglMakeCurrent.
parent
3e8b3d0f
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
28 additions
and
43 deletions
+28
-43
opengl.c
dlls/winex11.drv/opengl.c
+28
-43
No files found.
dlls/winex11.drv/opengl.c
View file @
7f4d3022
...
@@ -631,26 +631,6 @@ static int describeContext(Wine_GLContext* ctx) {
...
@@ -631,26 +631,6 @@ static int describeContext(Wine_GLContext* ctx) {
return
ctx_vis_id
;
return
ctx_vis_id
;
}
}
static
BOOL
describeDrawable
(
struct
glx_physdev
*
physdev
)
{
int
tmp
;
WineGLPixelFormat
*
fmt
;
int
fmt_count
=
0
;
fmt
=
ConvertPixelFormatWGLtoGLX
(
gdi_display
,
physdev
->
pixel_format
,
TRUE
/* Offscreen */
,
&
fmt_count
);
if
(
!
fmt
)
return
FALSE
;
TRACE
(
" HDC %p has:
\n
"
,
physdev
->
dev
.
hdc
);
TRACE
(
" - iPixelFormat %d
\n
"
,
fmt
->
iPixelFormat
);
TRACE
(
" - Drawable %lx
\n
"
,
physdev
->
drawable
);
TRACE
(
" - FBCONFIG_ID 0x%x
\n
"
,
fmt
->
fmt_id
);
pglXGetFBConfigAttrib
(
gdi_display
,
fmt
->
fbconfig
,
GLX_VISUAL_ID
,
&
tmp
);
TRACE
(
" - VISUAL_ID 0x%x
\n
"
,
tmp
);
return
TRUE
;
}
static
int
ConvertAttribWGLtoGLX
(
const
int
*
iWGLAttr
,
int
*
oGLXAttr
,
Wine_GLPBuffer
*
pbuf
)
{
static
int
ConvertAttribWGLtoGLX
(
const
int
*
iWGLAttr
,
int
*
oGLXAttr
,
Wine_GLPBuffer
*
pbuf
)
{
int
nAttribs
=
0
;
int
nAttribs
=
0
;
unsigned
cur
=
0
;
unsigned
cur
=
0
;
...
@@ -1584,13 +1564,13 @@ static PROC glxdrv_wglGetProcAddress(LPCSTR lpszProc)
...
@@ -1584,13 +1564,13 @@ static PROC glxdrv_wglGetProcAddress(LPCSTR lpszProc)
return
NULL
;
return
NULL
;
}
}
static
GLXPixmap
get_context_pixmap
(
struct
glx_physdev
*
physdev
,
struct
wine_glcontext
*
ctx
)
static
GLXPixmap
get_context_pixmap
(
HDC
hdc
,
struct
wine_glcontext
*
ctx
)
{
{
if
(
!
ctx
->
pixmap
)
if
(
!
ctx
->
pixmap
)
{
{
BITMAP
bmp
;
BITMAP
bmp
;
GetObjectW
(
GetCurrentObject
(
physdev
->
dev
.
hdc
,
OBJ_BITMAP
),
sizeof
(
bmp
),
&
bmp
);
GetObjectW
(
GetCurrentObject
(
hdc
,
OBJ_BITMAP
),
sizeof
(
bmp
),
&
bmp
);
wine_tsx11_lock
();
wine_tsx11_lock
();
ctx
->
pixmap
=
XCreatePixmap
(
gdi_display
,
root_window
,
ctx
->
pixmap
=
XCreatePixmap
(
gdi_display
,
root_window
,
...
@@ -1610,14 +1590,13 @@ static GLXPixmap get_context_pixmap( struct glx_physdev *physdev, struct wine_gl
...
@@ -1610,14 +1590,13 @@ static GLXPixmap get_context_pixmap( struct glx_physdev *physdev, struct wine_gl
*/
*/
static
BOOL
glxdrv_wglMakeCurrent
(
PHYSDEV
dev
,
HGLRC
hglrc
)
static
BOOL
glxdrv_wglMakeCurrent
(
PHYSDEV
dev
,
HGLRC
hglrc
)
{
{
struct
glx_physdev
*
physdev
=
get_glxdrv_dev
(
dev
)
;
HDC
hdc
=
dev
->
hdc
;
BOOL
ret
;
BOOL
ret
;
Wine_GLContext
*
prev_ctx
=
NtCurrentTeb
()
->
glContext
;
Wine_GLContext
*
prev_ctx
=
NtCurrentTeb
()
->
glContext
;
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
Wine_GLContext
*
ctx
=
(
Wine_GLContext
*
)
hglrc
;
struct
x11drv_escape_get_drawable
escape
;
TRACE
(
"(%p,%p)
\n
"
,
dev
->
hdc
,
hglrc
);
TRACE
(
"(%p,%p)
\n
"
,
hdc
,
hglrc
);
if
(
!
has_opengl
())
return
FALSE
;
if
(
hglrc
==
NULL
)
if
(
hglrc
==
NULL
)
{
{
...
@@ -1627,36 +1606,42 @@ static BOOL glxdrv_wglMakeCurrent(PHYSDEV dev, HGLRC hglrc)
...
@@ -1627,36 +1606,42 @@ static BOOL glxdrv_wglMakeCurrent(PHYSDEV dev, HGLRC hglrc)
ret
=
pglXMakeCurrent
(
gdi_display
,
None
,
NULL
);
ret
=
pglXMakeCurrent
(
gdi_display
,
None
,
NULL
);
wine_tsx11_unlock
();
wine_tsx11_unlock
();
NtCurrentTeb
()
->
glContext
=
NULL
;
NtCurrentTeb
()
->
glContext
=
NULL
;
return
TRUE
;
}
}
else
if
(
!
physdev
->
pixel_format
)
escape
.
code
=
X11DRV_GET_DRAWABLE
;
if
(
!
ExtEscape
(
hdc
,
X11DRV_ESCAPE
,
sizeof
(
escape
.
code
),
(
LPCSTR
)
&
escape
.
code
,
sizeof
(
escape
),
(
LPSTR
)
&
escape
))
return
FALSE
;
if
(
!
escape
.
pixel_format
)
{
{
WARN
(
"Trying to use an invalid drawable
\n
"
);
WARN
(
"Trying to use an invalid drawable
\n
"
);
SetLastError
(
ERROR_INVALID_HANDLE
);
SetLastError
(
ERROR_INVALID_HANDLE
);
return
FALSE
;
return
FALSE
;
}
}
else
if
(
ctx
->
fmt
->
iPixelFormat
!=
physdev
->
pixel_format
)
if
(
ctx
->
fmt
->
iPixelFormat
!=
escape
.
pixel_format
)
{
{
WARN
(
"mismatched pixel format hdc %p %u ctx %p %u
\n
"
,
WARN
(
"mismatched pixel format hdc %p %u ctx %p %u
\n
"
,
dev
->
hdc
,
physdev
->
pixel_format
,
ctx
,
ctx
->
fmt
->
iPixelFormat
);
hdc
,
escape
.
pixel_format
,
ctx
,
ctx
->
fmt
->
iPixelFormat
);
SetLastError
(
ERROR_INVALID_PIXEL_FORMAT
);
SetLastError
(
ERROR_INVALID_PIXEL_FORMAT
);
return
FALSE
;
return
FALSE
;
}
}
else
else
{
{
Drawable
drawable
=
physdev
->
drawable
;
if
(
escape
.
gl_type
==
DC_GL_BITMAP
)
escape
.
drawable
=
get_context_pixmap
(
hdc
,
ctx
);
if
(
physdev
->
type
==
DC_GL_BITMAP
)
drawable
=
get_context_pixmap
(
physdev
,
ctx
);
wine_tsx11_lock
();
wine_tsx11_lock
();
if
(
TRACE_ON
(
wgl
))
{
if
(
TRACE_ON
(
wgl
))
{
describeDrawable
(
physdev
);
int
vis_id
;
pglXGetFBConfigAttrib
(
gdi_display
,
ctx
->
fmt
->
fbconfig
,
GLX_VISUAL_ID
,
&
vis_id
);
describeContext
(
ctx
);
describeContext
(
ctx
);
TRACE
(
"hdc %p drawable %lx fmt %u vis %x ctx %p
\n
"
,
hdc
,
escape
.
drawable
,
escape
.
pixel_format
,
vis_id
,
ctx
->
ctx
);
}
}
TRACE
(
" make current for drawable %lx, ctx %p
\n
"
,
drawable
,
ctx
->
ctx
);
ret
=
pglXMakeCurrent
(
gdi_display
,
escape
.
drawable
,
ctx
->
ctx
);
ret
=
pglXMakeCurrent
(
gdi_display
,
drawable
,
ctx
->
ctx
);
if
(
ret
)
if
(
ret
)
{
{
...
@@ -1665,13 +1650,13 @@ static BOOL glxdrv_wglMakeCurrent(PHYSDEV dev, HGLRC hglrc)
...
@@ -1665,13 +1650,13 @@ static BOOL glxdrv_wglMakeCurrent(PHYSDEV dev, HGLRC hglrc)
ctx
->
has_been_current
=
TRUE
;
ctx
->
has_been_current
=
TRUE
;
ctx
->
tid
=
GetCurrentThreadId
();
ctx
->
tid
=
GetCurrentThreadId
();
ctx
->
hdc
=
dev
->
hdc
;
ctx
->
hdc
=
hdc
;
ctx
->
read_hdc
=
dev
->
hdc
;
ctx
->
read_hdc
=
hdc
;
ctx
->
drawables
[
0
]
=
drawable
;
ctx
->
drawables
[
0
]
=
escape
.
drawable
;
ctx
->
drawables
[
1
]
=
drawable
;
ctx
->
drawables
[
1
]
=
escape
.
drawable
;
ctx
->
refresh_drawables
=
FALSE
;
ctx
->
refresh_drawables
=
FALSE
;
if
(
physdev
->
type
==
DC_GL_BITMAP
)
pglDrawBuffer
(
GL_FRONT_LEFT
);
if
(
escape
.
gl_
type
==
DC_GL_BITMAP
)
pglDrawBuffer
(
GL_FRONT_LEFT
);
}
}
else
else
SetLastError
(
ERROR_INVALID_HANDLE
);
SetLastError
(
ERROR_INVALID_HANDLE
);
...
@@ -1720,8 +1705,8 @@ static BOOL glxdrv_wglMakeContextCurrentARB( PHYSDEV draw_dev, PHYSDEV read_dev,
...
@@ -1720,8 +1705,8 @@ static BOOL glxdrv_wglMakeContextCurrentARB( PHYSDEV draw_dev, PHYSDEV read_dev,
if
(
!
pglXMakeContextCurrent
)
return
FALSE
;
if
(
!
pglXMakeContextCurrent
)
return
FALSE
;
if
(
draw_physdev
->
type
==
DC_GL_BITMAP
)
draw_drawable
=
get_context_pixmap
(
draw_physdev
,
ctx
);
if
(
draw_physdev
->
type
==
DC_GL_BITMAP
)
draw_drawable
=
get_context_pixmap
(
draw_physdev
->
dev
.
hdc
,
ctx
);
if
(
read_physdev
->
type
==
DC_GL_BITMAP
)
read_drawable
=
get_context_pixmap
(
read_physdev
,
ctx
);
if
(
read_physdev
->
type
==
DC_GL_BITMAP
)
read_drawable
=
get_context_pixmap
(
read_physdev
->
dev
.
hdc
,
ctx
);
wine_tsx11_lock
();
wine_tsx11_lock
();
ret
=
pglXMakeContextCurrent
(
gdi_display
,
draw_drawable
,
read_drawable
,
ctx
->
ctx
);
ret
=
pglXMakeContextCurrent
(
gdi_display
,
draw_drawable
,
read_drawable
,
ctx
->
ctx
);
...
...
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