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_PERFCOUNTER_H 12*61046927SAndroid Build Coastguard Worker #define RADV_PERFCOUNTER_H 13*61046927SAndroid Build Coastguard Worker 14*61046927SAndroid Build Coastguard Worker #include "radv_radeon_winsys.h" 15*61046927SAndroid Build Coastguard Worker 16*61046927SAndroid Build Coastguard Worker #include "radv_query.h" 17*61046927SAndroid Build Coastguard Worker 18*61046927SAndroid Build Coastguard Worker struct radv_physical_device; 19*61046927SAndroid Build Coastguard Worker struct radv_device; 20*61046927SAndroid Build Coastguard Worker 21*61046927SAndroid Build Coastguard Worker struct radv_pc_query_pool { 22*61046927SAndroid Build Coastguard Worker struct radv_query_pool b; 23*61046927SAndroid Build Coastguard Worker 24*61046927SAndroid Build Coastguard Worker uint32_t *pc_regs; 25*61046927SAndroid Build Coastguard Worker unsigned num_pc_regs; 26*61046927SAndroid Build Coastguard Worker 27*61046927SAndroid Build Coastguard Worker unsigned num_passes; 28*61046927SAndroid Build Coastguard Worker 29*61046927SAndroid Build Coastguard Worker unsigned num_counters; 30*61046927SAndroid Build Coastguard Worker struct radv_perfcounter_impl *counters; 31*61046927SAndroid Build Coastguard Worker }; 32*61046927SAndroid Build Coastguard Worker 33*61046927SAndroid Build Coastguard Worker void radv_perfcounter_emit_shaders(struct radv_device *device, struct radeon_cmdbuf *cs, unsigned shaders); 34*61046927SAndroid Build Coastguard Worker 35*61046927SAndroid Build Coastguard Worker void radv_perfcounter_emit_spm_reset(struct radeon_cmdbuf *cs); 36*61046927SAndroid Build Coastguard Worker 37*61046927SAndroid Build Coastguard Worker void radv_perfcounter_emit_spm_start(struct radv_device *device, struct radeon_cmdbuf *cs, int family); 38*61046927SAndroid Build Coastguard Worker 39*61046927SAndroid Build Coastguard Worker void radv_perfcounter_emit_spm_stop(struct radv_device *device, struct radeon_cmdbuf *cs, int family); 40*61046927SAndroid Build Coastguard Worker 41*61046927SAndroid Build Coastguard Worker void radv_pc_deinit_query_pool(struct radv_pc_query_pool *pool); 42*61046927SAndroid Build Coastguard Worker 43*61046927SAndroid Build Coastguard Worker VkResult radv_pc_init_query_pool(struct radv_physical_device *pdev, const VkQueryPoolCreateInfo *pCreateInfo, 44*61046927SAndroid Build Coastguard Worker struct radv_pc_query_pool *pool); 45*61046927SAndroid Build Coastguard Worker 46*61046927SAndroid Build Coastguard Worker void radv_pc_begin_query(struct radv_cmd_buffer *cmd_buffer, struct radv_pc_query_pool *pool, uint64_t va); 47*61046927SAndroid Build Coastguard Worker 48*61046927SAndroid Build Coastguard Worker void radv_pc_end_query(struct radv_cmd_buffer *cmd_buffer, struct radv_pc_query_pool *pool, uint64_t va); 49*61046927SAndroid Build Coastguard Worker 50*61046927SAndroid Build Coastguard Worker void radv_pc_get_results(const struct radv_pc_query_pool *pc_pool, const uint64_t *data, void *out); 51*61046927SAndroid Build Coastguard Worker 52*61046927SAndroid Build Coastguard Worker #endif /* RADV_PERFCOUNTER_H */ 53