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 Workerradv_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