Skip to content
Projects
Groups
Snippets
Help
This project
Loading...
Sign in / Register
Toggle navigation
W
wine-cw
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-cw
Commits
36f20ec5
Commit
36f20ec5
authored
Jan 29, 2018
by
Henri Verbeet
Committed by
Alexandre Julliard
Jan 29, 2018
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Use the resource access flags in fbo_blitter_supported().
Signed-off-by:
Henri Verbeet
<
hverbeet@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
a3b6f8ce
Hide whitespace changes
Inline
Side-by-side
Showing
1 changed file
with
16 additions
and
17 deletions
+16
-17
surface.c
dlls/wined3d/surface.c
+16
-17
No files found.
dlls/wined3d/surface.c
View file @
36f20ec5
...
@@ -484,25 +484,28 @@ static void surface_blt_fbo(const struct wined3d_device *device,
...
@@ -484,25 +484,28 @@ static void surface_blt_fbo(const struct wined3d_device *device,
context_restore
(
context
,
restore_rt
);
context_restore
(
context
,
restore_rt
);
}
}
static
BOOL
fbo_blitter_supported
(
const
struct
wined3d_gl_info
*
gl_info
,
enum
wined3d_blit_op
blit_op
,
static
BOOL
fbo_blitter_supported
(
enum
wined3d_blit_op
blit_op
,
const
struct
wined3d_gl_info
*
gl_info
,
DWORD
src_usage
,
enum
wined3d_pool
src_pool
,
const
struct
wined3d_format
*
src_format
,
DWORD
src_location
,
const
struct
wined3d_resource
*
src_resource
,
DWORD
src_location
,
DWORD
dst_usage
,
enum
wined3d_pool
dst_pool
,
const
struct
wined3d_format
*
dst_format
,
DWORD
dst_location
)
const
struct
wined3d_resource
*
dst_resource
,
DWORD
dst_location
)
{
{
const
struct
wined3d_format
*
src_format
=
src_resource
->
format
;
const
struct
wined3d_format
*
dst_format
=
dst_resource
->
format
;
if
((
wined3d_settings
.
offscreen_rendering_mode
!=
ORM_FBO
)
||
!
gl_info
->
fbo_ops
.
glBlitFramebuffer
)
if
((
wined3d_settings
.
offscreen_rendering_mode
!=
ORM_FBO
)
||
!
gl_info
->
fbo_ops
.
glBlitFramebuffer
)
return
FALSE
;
return
FALSE
;
/* Source and/or destination need to be on the GL side */
/* Source and/or destination need to be on the GL side */
if
(
src_pool
==
WINED3D_POOL_SYSTEM_MEM
||
dst_pool
==
WINED3D_POOL_SYSTEM_MEM
)
if
(
!
(
src_resource
->
access
&
dst_resource
->
access
&
WINED3D_RESOURCE_ACCESS_GPU
)
)
return
FALSE
;
return
FALSE
;
switch
(
blit_op
)
switch
(
blit_op
)
{
{
case
WINED3D_BLIT_OP_COLOR_BLIT
:
case
WINED3D_BLIT_OP_COLOR_BLIT
:
if
(
!
((
src_format
->
flags
[
WINED3D_GL_RES_TYPE_TEX_2D
]
&
WINED3DFMT_FLAG_FBO_ATTACHABLE
)
if
(
!
((
src_format
->
flags
[
WINED3D_GL_RES_TYPE_TEX_2D
]
&
WINED3DFMT_FLAG_FBO_ATTACHABLE
)
||
(
src_usage
&
WINED3DUSAGE_RENDERTARGET
)))
||
(
src_
resource
->
usage
&
WINED3DUSAGE_RENDERTARGET
)))
return
FALSE
;
return
FALSE
;
if
(
!
((
dst_format
->
flags
[
WINED3D_GL_RES_TYPE_TEX_2D
]
&
WINED3DFMT_FLAG_FBO_ATTACHABLE
)
if
(
!
((
dst_format
->
flags
[
WINED3D_GL_RES_TYPE_TEX_2D
]
&
WINED3DFMT_FLAG_FBO_ATTACHABLE
)
||
(
dst_usage
&
WINED3DUSAGE_RENDERTARGET
)))
||
(
dst_
resource
->
usage
&
WINED3DUSAGE_RENDERTARGET
)))
return
FALSE
;
return
FALSE
;
if
((
src_format
->
id
!=
dst_format
->
id
||
dst_location
==
WINED3D_LOCATION_DRAWABLE
)
if
((
src_format
->
id
!=
dst_format
->
id
||
dst_location
==
WINED3D_LOCATION_DRAWABLE
)
&&
(
!
is_identity_fixup
(
src_format
->
color_fixup
)
||
!
is_identity_fixup
(
dst_format
->
color_fixup
)))
&&
(
!
is_identity_fixup
(
src_format
->
color_fixup
)
||
!
is_identity_fixup
(
dst_format
->
color_fixup
)))
...
@@ -2229,11 +2232,9 @@ static BOOL surface_load_texture(struct wined3d_surface *surface,
...
@@ -2229,11 +2232,9 @@ static BOOL surface_load_texture(struct wined3d_surface *surface,
if
(
!
depth
&&
sub_resource
->
locations
&
(
WINED3D_LOCATION_TEXTURE_SRGB
|
WINED3D_LOCATION_TEXTURE_RGB
)
if
(
!
depth
&&
sub_resource
->
locations
&
(
WINED3D_LOCATION_TEXTURE_SRGB
|
WINED3D_LOCATION_TEXTURE_RGB
)
&&
(
texture
->
resource
.
format_flags
&
WINED3DFMT_FLAG_FBO_ATTACHABLE_SRGB
)
&&
(
texture
->
resource
.
format_flags
&
WINED3DFMT_FLAG_FBO_ATTACHABLE_SRGB
)
&&
fbo_blitter_supported
(
gl_info
,
WINED3D_BLIT_OP_COLOR_BLIT
,
&&
fbo_blitter_supported
(
WINED3D_BLIT_OP_COLOR_BLIT
,
gl_info
,
texture
->
resource
.
usage
,
texture
->
resource
.
pool
,
&
texture
->
resource
,
WINED3D_LOCATION_TEXTURE_RGB
,
texture
->
resource
.
format
,
WINED3D_LOCATION_TEXTURE_RGB
,
&
texture
->
resource
,
WINED3D_LOCATION_TEXTURE_SRGB
))
texture
->
resource
.
usage
,
texture
->
resource
.
pool
,
texture
->
resource
.
format
,
WINED3D_LOCATION_TEXTURE_SRGB
))
{
{
if
(
srgb
)
if
(
srgb
)
surface_blt_fbo
(
device
,
context
,
WINED3D_TEXF_POINT
,
surface
,
WINED3D_LOCATION_TEXTURE_RGB
,
surface_blt_fbo
(
device
,
context
,
WINED3D_TEXF_POINT
,
surface
,
WINED3D_LOCATION_TEXTURE_RGB
,
...
@@ -2252,9 +2253,8 @@ static BOOL surface_load_texture(struct wined3d_surface *surface,
...
@@ -2252,9 +2253,8 @@ static BOOL surface_load_texture(struct wined3d_surface *surface,
WINED3D_LOCATION_RB_RESOLVED
:
WINED3D_LOCATION_RB_MULTISAMPLE
;
WINED3D_LOCATION_RB_RESOLVED
:
WINED3D_LOCATION_RB_MULTISAMPLE
;
DWORD
dst_location
=
srgb
?
WINED3D_LOCATION_TEXTURE_SRGB
:
WINED3D_LOCATION_TEXTURE_RGB
;
DWORD
dst_location
=
srgb
?
WINED3D_LOCATION_TEXTURE_SRGB
:
WINED3D_LOCATION_TEXTURE_RGB
;
if
(
fbo_blitter_supported
(
gl_info
,
WINED3D_BLIT_OP_COLOR_BLIT
,
if
(
fbo_blitter_supported
(
WINED3D_BLIT_OP_COLOR_BLIT
,
gl_info
,
texture
->
resource
.
usage
,
texture
->
resource
.
pool
,
texture
->
resource
.
format
,
src_location
,
&
texture
->
resource
,
src_location
,
&
texture
->
resource
,
dst_location
))
texture
->
resource
.
usage
,
texture
->
resource
.
pool
,
texture
->
resource
.
format
,
dst_location
))
surface_blt_fbo
(
device
,
context
,
WINED3D_TEXF_POINT
,
surface
,
src_location
,
surface_blt_fbo
(
device
,
context
,
WINED3D_TEXF_POINT
,
surface
,
src_location
,
&
src_rect
,
surface
,
dst_location
,
&
src_rect
);
&
src_rect
,
surface
,
dst_location
,
&
src_rect
);
...
@@ -2470,9 +2470,8 @@ static DWORD fbo_blitter_blit(struct wined3d_blitter *blitter, enum wined3d_blit
...
@@ -2470,9 +2470,8 @@ static DWORD fbo_blitter_blit(struct wined3d_blitter *blitter, enum wined3d_blit
blit_op
=
WINED3D_BLIT_OP_COLOR_BLIT
;
blit_op
=
WINED3D_BLIT_OP_COLOR_BLIT
;
}
}
if
(
!
fbo_blitter_supported
(
&
device
->
adapter
->
gl_info
,
blit_op
,
if
(
!
fbo_blitter_supported
(
blit_op
,
context
->
gl_info
,
src_resource
->
usage
,
src_resource
->
pool
,
src_resource
->
format
,
src_location
,
src_resource
,
src_location
,
dst_resource
,
dst_location
))
src_resource
->
usage
,
dst_resource
->
pool
,
dst_resource
->
format
,
dst_location
))
{
{
if
((
next
=
blitter
->
next
))
if
((
next
=
blitter
->
next
))
return
next
->
ops
->
blitter_blit
(
next
,
op
,
context
,
src_surface
,
src_location
,
return
next
->
ops
->
blitter_blit
(
next
,
op
,
context
,
src_surface
,
src_location
,
...
...
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