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
7a03ccfb
Commit
7a03ccfb
authored
May 27, 2020
by
Henri Verbeet
Committed by
Alexandre Julliard
May 27, 2020
Browse files
Options
Browse Files
Download
Email Patches
Plain Diff
wined3d: Implement pipeline statistics queries for the Vulkan adapter.
Signed-off-by:
Henri Verbeet
<
hverbeet@codeweavers.com
>
Signed-off-by:
Alexandre Julliard
<
julliard@winehq.org
>
parent
8f70aad2
Hide whitespace changes
Inline
Side-by-side
Showing
3 changed files
with
45 additions
and
0 deletions
+45
-0
context_vk.c
dlls/wined3d/context_vk.c
+6
-0
query.c
dlls/wined3d/query.c
+38
-0
wined3d_private.h
dlls/wined3d/wined3d_private.h
+1
-0
No files found.
dlls/wined3d/context_vk.c
View file @
7a03ccfb
...
@@ -1231,6 +1231,10 @@ bool wined3d_context_vk_allocate_query(struct wined3d_context_vk *context_vk,
...
@@ -1231,6 +1231,10 @@ bool wined3d_context_vk_allocate_query(struct wined3d_context_vk *context_vk,
free_pools
=
&
context_vk
->
free_timestamp_query_pools
;
free_pools
=
&
context_vk
->
free_timestamp_query_pools
;
break
;
break
;
case
WINED3D_QUERY_TYPE_PIPELINE_STATISTICS
:
free_pools
=
&
context_vk
->
free_pipeline_statistics_query_pools
;
break
;
default:
default:
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
return
false
;
return
false
;
...
@@ -1291,6 +1295,7 @@ void wined3d_context_vk_cleanup(struct wined3d_context_vk *context_vk)
...
@@ -1291,6 +1295,7 @@ void wined3d_context_vk_cleanup(struct wined3d_context_vk *context_vk)
wined3d_context_vk_cleanup_resources
(
context_vk
);
wined3d_context_vk_cleanup_resources
(
context_vk
);
wined3d_context_vk_destroy_query_pools
(
context_vk
,
&
context_vk
->
free_occlusion_query_pools
);
wined3d_context_vk_destroy_query_pools
(
context_vk
,
&
context_vk
->
free_occlusion_query_pools
);
wined3d_context_vk_destroy_query_pools
(
context_vk
,
&
context_vk
->
free_timestamp_query_pools
);
wined3d_context_vk_destroy_query_pools
(
context_vk
,
&
context_vk
->
free_timestamp_query_pools
);
wined3d_context_vk_destroy_query_pools
(
context_vk
,
&
context_vk
->
free_pipeline_statistics_query_pools
);
wine_rb_destroy
(
&
context_vk
->
bo_slab_available
,
wined3d_context_vk_destroy_bo_slab
,
context_vk
);
wine_rb_destroy
(
&
context_vk
->
bo_slab_available
,
wined3d_context_vk_destroy_bo_slab
,
context_vk
);
heap_free
(
context_vk
->
pending_queries
.
queries
);
heap_free
(
context_vk
->
pending_queries
.
queries
);
heap_free
(
context_vk
->
submitted
.
buffers
);
heap_free
(
context_vk
->
submitted
.
buffers
);
...
@@ -3063,6 +3068,7 @@ HRESULT wined3d_context_vk_init(struct wined3d_context_vk *context_vk, struct wi
...
@@ -3063,6 +3068,7 @@ HRESULT wined3d_context_vk_init(struct wined3d_context_vk *context_vk, struct wi
list_init
(
&
context_vk
->
active_queries
);
list_init
(
&
context_vk
->
active_queries
);
list_init
(
&
context_vk
->
free_occlusion_query_pools
);
list_init
(
&
context_vk
->
free_occlusion_query_pools
);
list_init
(
&
context_vk
->
free_timestamp_query_pools
);
list_init
(
&
context_vk
->
free_timestamp_query_pools
);
list_init
(
&
context_vk
->
free_pipeline_statistics_query_pools
);
wine_rb_init
(
&
context_vk
->
render_passes
,
wined3d_render_pass_vk_compare
);
wine_rb_init
(
&
context_vk
->
render_passes
,
wined3d_render_pass_vk_compare
);
wine_rb_init
(
&
context_vk
->
pipeline_layouts
,
wined3d_pipeline_layout_vk_compare
);
wine_rb_init
(
&
context_vk
->
pipeline_layouts
,
wined3d_pipeline_layout_vk_compare
);
...
...
dlls/wined3d/query.c
View file @
7a03ccfb
...
@@ -1408,6 +1408,21 @@ bool wined3d_query_pool_vk_init(struct wined3d_query_pool_vk *pool_vk,
...
@@ -1408,6 +1408,21 @@ bool wined3d_query_pool_vk_init(struct wined3d_query_pool_vk *pool_vk,
pool_info
.
pipelineStatistics
=
0
;
pool_info
.
pipelineStatistics
=
0
;
break
;
break
;
case
WINED3D_QUERY_TYPE_PIPELINE_STATISTICS
:
pool_info
.
queryType
=
VK_QUERY_TYPE_PIPELINE_STATISTICS
;
pool_info
.
pipelineStatistics
=
VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_VERTICES_BIT
|
VK_QUERY_PIPELINE_STATISTIC_INPUT_ASSEMBLY_PRIMITIVES_BIT
|
VK_QUERY_PIPELINE_STATISTIC_VERTEX_SHADER_INVOCATIONS_BIT
|
VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_INVOCATIONS_BIT
|
VK_QUERY_PIPELINE_STATISTIC_GEOMETRY_SHADER_PRIMITIVES_BIT
|
VK_QUERY_PIPELINE_STATISTIC_CLIPPING_INVOCATIONS_BIT
|
VK_QUERY_PIPELINE_STATISTIC_CLIPPING_PRIMITIVES_BIT
|
VK_QUERY_PIPELINE_STATISTIC_FRAGMENT_SHADER_INVOCATIONS_BIT
|
VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_CONTROL_SHADER_PATCHES_BIT
|
VK_QUERY_PIPELINE_STATISTIC_TESSELLATION_EVALUATION_SHADER_INVOCATIONS_BIT
|
VK_QUERY_PIPELINE_STATISTIC_COMPUTE_SHADER_INVOCATIONS_BIT
;
break
;
default:
default:
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
return
false
;
return
false
;
...
@@ -1428,12 +1443,15 @@ bool wined3d_query_vk_accumulate_data(struct wined3d_query_vk *query_vk,
...
@@ -1428,12 +1443,15 @@ bool wined3d_query_vk_accumulate_data(struct wined3d_query_vk *query_vk,
struct
wined3d_context_vk
*
context_vk
,
const
struct
wined3d_query_pool_idx_vk
*
pool_idx
)
struct
wined3d_context_vk
*
context_vk
,
const
struct
wined3d_query_pool_idx_vk
*
pool_idx
)
{
{
struct
wined3d_device_vk
*
device_vk
=
wined3d_device_vk
(
context_vk
->
c
.
device
);
struct
wined3d_device_vk
*
device_vk
=
wined3d_device_vk
(
context_vk
->
c
.
device
);
const
struct
wined3d_query_data_pipeline_statistics
*
ps_tmp
;
const
struct
wined3d_vk_info
*
vk_info
=
context_vk
->
vk_info
;
const
struct
wined3d_vk_info
*
vk_info
=
context_vk
->
vk_info
;
struct
wined3d_query_data_pipeline_statistics
*
ps_result
;
VkResult
vr
;
VkResult
vr
;
union
union
{
{
uint64_t
occlusion
;
uint64_t
occlusion
;
uint64_t
timestamp
;
uint64_t
timestamp
;
struct
wined3d_query_data_pipeline_statistics
pipeline_statistics
;
}
tmp
,
*
result
;
}
tmp
,
*
result
;
if
((
vr
=
VK_CALL
(
vkGetQueryPoolResults
(
device_vk
->
vk_device
,
pool_idx
->
pool_vk
->
vk_query_pool
,
if
((
vr
=
VK_CALL
(
vkGetQueryPoolResults
(
device_vk
->
vk_device
,
pool_idx
->
pool_vk
->
vk_query_pool
,
...
@@ -1457,6 +1475,22 @@ bool wined3d_query_vk_accumulate_data(struct wined3d_query_vk *query_vk,
...
@@ -1457,6 +1475,22 @@ bool wined3d_query_vk_accumulate_data(struct wined3d_query_vk *query_vk,
result
->
timestamp
=
tmp
.
timestamp
;
result
->
timestamp
=
tmp
.
timestamp
;
break
;
break
;
case
WINED3D_QUERY_TYPE_PIPELINE_STATISTICS
:
ps_result
=
&
result
->
pipeline_statistics
;
ps_tmp
=
&
tmp
.
pipeline_statistics
;
ps_result
->
vertices_submitted
+=
ps_tmp
->
vertices_submitted
;
ps_result
->
primitives_submitted
+=
ps_tmp
->
primitives_submitted
;
ps_result
->
vs_invocations
+=
ps_tmp
->
vs_invocations
;
ps_result
->
gs_invocations
+=
ps_tmp
->
gs_invocations
;
ps_result
->
gs_primitives
+=
ps_tmp
->
gs_primitives
;
ps_result
->
clipping_input_primitives
+=
ps_tmp
->
clipping_input_primitives
;
ps_result
->
clipping_output_primitives
+=
ps_tmp
->
clipping_output_primitives
;
ps_result
->
ps_invocations
+=
ps_tmp
->
ps_invocations
;
ps_result
->
hs_invocations
+=
ps_tmp
->
hs_invocations
;
ps_result
->
ds_invocations
+=
ps_tmp
->
ds_invocations
;
ps_result
->
cs_invocations
+=
ps_tmp
->
cs_invocations
;
break
;
default:
default:
FIXME
(
"Unhandled query type %#x.
\n
"
,
query_vk
->
q
.
type
);
FIXME
(
"Unhandled query type %#x.
\n
"
,
query_vk
->
q
.
type
);
return
false
;
return
false
;
...
@@ -1763,6 +1797,10 @@ HRESULT wined3d_query_vk_create(struct wined3d_device *device, enum wined3d_quer
...
@@ -1763,6 +1797,10 @@ HRESULT wined3d_query_vk_create(struct wined3d_device *device, enum wined3d_quer
data_size
=
sizeof
(
struct
wined3d_query_data_timestamp_disjoint
);
data_size
=
sizeof
(
struct
wined3d_query_data_timestamp_disjoint
);
break
;
break
;
case
WINED3D_QUERY_TYPE_PIPELINE_STATISTICS
:
data_size
=
sizeof
(
struct
wined3d_query_data_pipeline_statistics
);
break
;
default:
default:
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
FIXME
(
"Unhandled query type %#x.
\n
"
,
type
);
return
WINED3DERR_NOTAVAILABLE
;
return
WINED3DERR_NOTAVAILABLE
;
...
...
dlls/wined3d/wined3d_private.h
View file @
7a03ccfb
...
@@ -2496,6 +2496,7 @@ struct wined3d_context_vk
...
@@ -2496,6 +2496,7 @@ struct wined3d_context_vk
struct
wined3d_pending_queries_vk
pending_queries
;
struct
wined3d_pending_queries_vk
pending_queries
;
struct
list
free_occlusion_query_pools
;
struct
list
free_occlusion_query_pools
;
struct
list
free_timestamp_query_pools
;
struct
list
free_timestamp_query_pools
;
struct
list
free_pipeline_statistics_query_pools
;
struct
wined3d_retired_objects_vk
retired
;
struct
wined3d_retired_objects_vk
retired
;
struct
wine_rb_tree
render_passes
;
struct
wine_rb_tree
render_passes
;
...
...
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