xref: /aosp_15_r20/external/mesa3d/src/amd/vulkan/radv_query.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright © 2016 Red Hat.
3*61046927SAndroid Build Coastguard Worker  * Copyright © 2016 Bas Nieuwenhuizen
4*61046927SAndroid Build Coastguard Worker  *
5*61046927SAndroid Build Coastguard Worker  * based in part on anv driver which is:
6*61046927SAndroid Build Coastguard Worker  * Copyright © 2015 Intel Corporation
7*61046927SAndroid Build Coastguard Worker  *
8*61046927SAndroid Build Coastguard Worker  * SPDX-License-Identifier: MIT
9*61046927SAndroid Build Coastguard Worker  */
10*61046927SAndroid Build Coastguard Worker 
11*61046927SAndroid Build Coastguard Worker #ifndef RADV_QUERY_H
12*61046927SAndroid Build Coastguard Worker #define RADV_QUERY_H
13*61046927SAndroid Build Coastguard Worker 
14*61046927SAndroid Build Coastguard Worker #include "amd_family.h"
15*61046927SAndroid Build Coastguard Worker 
16*61046927SAndroid Build Coastguard Worker #include "vk_query_pool.h"
17*61046927SAndroid Build Coastguard Worker 
18*61046927SAndroid Build Coastguard Worker struct radv_cmd_buffer;
19*61046927SAndroid Build Coastguard Worker 
20*61046927SAndroid Build Coastguard Worker struct radv_query_pool {
21*61046927SAndroid Build Coastguard Worker    struct vk_query_pool vk;
22*61046927SAndroid Build Coastguard Worker    struct radeon_winsys_bo *bo;
23*61046927SAndroid Build Coastguard Worker    uint32_t stride;
24*61046927SAndroid Build Coastguard Worker    uint32_t availability_offset;
25*61046927SAndroid Build Coastguard Worker    uint64_t size;
26*61046927SAndroid Build Coastguard Worker    char *ptr;
27*61046927SAndroid Build Coastguard Worker    bool uses_gds; /* For NGG GS on GFX10+ */
28*61046927SAndroid Build Coastguard Worker    bool uses_ace; /* For task shader invocations on GFX10.3+ */
29*61046927SAndroid Build Coastguard Worker };
30*61046927SAndroid Build Coastguard Worker 
31*61046927SAndroid Build Coastguard Worker VK_DEFINE_NONDISP_HANDLE_CASTS(radv_query_pool, vk.base, VkQueryPool, VK_OBJECT_TYPE_QUERY_POOL)
32*61046927SAndroid Build Coastguard Worker 
33*61046927SAndroid Build Coastguard Worker static inline uint64_t
radv_get_tdr_timeout_for_ip(enum amd_ip_type ip_type)34*61046927SAndroid Build Coastguard Worker radv_get_tdr_timeout_for_ip(enum amd_ip_type ip_type)
35*61046927SAndroid Build Coastguard Worker {
36*61046927SAndroid Build Coastguard Worker    const uint64_t compute_tdr_duration_ns = 60000000000ull; /* 1 minute (default in kernel) */
37*61046927SAndroid Build Coastguard Worker    const uint64_t other_tdr_duration_ns = 10000000000ull;   /* 10 seconds (default in kernel) */
38*61046927SAndroid Build Coastguard Worker 
39*61046927SAndroid Build Coastguard Worker    return ip_type == AMD_IP_COMPUTE ? compute_tdr_duration_ns : other_tdr_duration_ns;
40*61046927SAndroid Build Coastguard Worker }
41*61046927SAndroid Build Coastguard Worker 
42*61046927SAndroid Build Coastguard Worker void radv_write_timestamp(struct radv_cmd_buffer *cmd_buffer, uint64_t va, VkPipelineStageFlags2 stage);
43*61046927SAndroid Build Coastguard Worker 
44*61046927SAndroid Build Coastguard Worker #endif /* RADV_QUERY_H */
45