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_RMV_H 12*61046927SAndroid Build Coastguard Worker #define RADV_RMV_H 13*61046927SAndroid Build Coastguard Worker 14*61046927SAndroid Build Coastguard Worker #include "rmv/vk_rmv_common.h" 15*61046927SAndroid Build Coastguard Worker #include "rmv/vk_rmv_tokens.h" 16*61046927SAndroid Build Coastguard Worker 17*61046927SAndroid Build Coastguard Worker #include "radv_radeon_winsys.h" 18*61046927SAndroid Build Coastguard Worker 19*61046927SAndroid Build Coastguard Worker struct radv_device; 20*61046927SAndroid Build Coastguard Worker struct radv_physical_device; 21*61046927SAndroid Build Coastguard Worker struct radv_pipeline; 22*61046927SAndroid Build Coastguard Worker struct radv_ray_tracing_pipeline; 23*61046927SAndroid Build Coastguard Worker 24*61046927SAndroid Build Coastguard Worker void radv_memory_trace_init(struct radv_device *device); 25*61046927SAndroid Build Coastguard Worker 26*61046927SAndroid Build Coastguard Worker void radv_rmv_fill_device_info(const struct radv_physical_device *pdev, struct vk_rmv_device_info *info); 27*61046927SAndroid Build Coastguard Worker 28*61046927SAndroid Build Coastguard Worker void radv_rmv_collect_trace_events(struct radv_device *device); 29*61046927SAndroid Build Coastguard Worker 30*61046927SAndroid Build Coastguard Worker void radv_memory_trace_finish(struct radv_device *device); 31*61046927SAndroid Build Coastguard Worker 32*61046927SAndroid Build Coastguard Worker void radv_rmv_log_heap_create(struct radv_device *device, VkDeviceMemory heap, bool is_internal, 33*61046927SAndroid Build Coastguard Worker VkMemoryAllocateFlags alloc_flags); 34*61046927SAndroid Build Coastguard Worker 35*61046927SAndroid Build Coastguard Worker void radv_rmv_log_bo_allocate(struct radv_device *device, struct radeon_winsys_bo *bo, bool is_internal); 36*61046927SAndroid Build Coastguard Worker 37*61046927SAndroid Build Coastguard Worker void radv_rmv_log_bo_destroy(struct radv_device *device, struct radeon_winsys_bo *bo); 38*61046927SAndroid Build Coastguard Worker 39*61046927SAndroid Build Coastguard Worker void radv_rmv_log_buffer_bind(struct radv_device *device, VkBuffer _buffer); 40*61046927SAndroid Build Coastguard Worker 41*61046927SAndroid Build Coastguard Worker void radv_rmv_log_image_create(struct radv_device *device, const VkImageCreateInfo *create_info, bool is_internal, 42*61046927SAndroid Build Coastguard Worker VkImage _image); 43*61046927SAndroid Build Coastguard Worker 44*61046927SAndroid Build Coastguard Worker void radv_rmv_log_image_bind(struct radv_device *device, uint32_t bind_idx, VkImage _image); 45*61046927SAndroid Build Coastguard Worker 46*61046927SAndroid Build Coastguard Worker void radv_rmv_log_query_pool_create(struct radv_device *device, VkQueryPool pool); 47*61046927SAndroid Build Coastguard Worker 48*61046927SAndroid Build Coastguard Worker void radv_rmv_log_command_buffer_bo_create(struct radv_device *device, struct radeon_winsys_bo *bo, 49*61046927SAndroid Build Coastguard Worker uint32_t executable_size, uint32_t data_size, uint32_t scratch_size); 50*61046927SAndroid Build Coastguard Worker 51*61046927SAndroid Build Coastguard Worker void radv_rmv_log_command_buffer_bo_destroy(struct radv_device *device, struct radeon_winsys_bo *bo); 52*61046927SAndroid Build Coastguard Worker 53*61046927SAndroid Build Coastguard Worker void radv_rmv_log_border_color_palette_create(struct radv_device *device, struct radeon_winsys_bo *bo); 54*61046927SAndroid Build Coastguard Worker 55*61046927SAndroid Build Coastguard Worker void radv_rmv_log_border_color_palette_destroy(struct radv_device *device, struct radeon_winsys_bo *bo); 56*61046927SAndroid Build Coastguard Worker 57*61046927SAndroid Build Coastguard Worker void radv_rmv_log_sparse_add_residency(struct radv_device *device, struct radeon_winsys_bo *src_bo, uint64_t offset); 58*61046927SAndroid Build Coastguard Worker 59*61046927SAndroid Build Coastguard Worker void radv_rmv_log_sparse_remove_residency(struct radv_device *device, struct radeon_winsys_bo *src_bo, uint64_t offset); 60*61046927SAndroid Build Coastguard Worker 61*61046927SAndroid Build Coastguard Worker void radv_rmv_log_descriptor_pool_create(struct radv_device *device, const VkDescriptorPoolCreateInfo *create_info, 62*61046927SAndroid Build Coastguard Worker VkDescriptorPool pool); 63*61046927SAndroid Build Coastguard Worker 64*61046927SAndroid Build Coastguard Worker void radv_rmv_log_graphics_pipeline_create(struct radv_device *device, struct radv_pipeline *pipeline, 65*61046927SAndroid Build Coastguard Worker bool is_internal); 66*61046927SAndroid Build Coastguard Worker 67*61046927SAndroid Build Coastguard Worker void radv_rmv_log_compute_pipeline_create(struct radv_device *device, struct radv_pipeline *pipeline, bool is_internal); 68*61046927SAndroid Build Coastguard Worker 69*61046927SAndroid Build Coastguard Worker void radv_rmv_log_rt_pipeline_create(struct radv_device *device, struct radv_ray_tracing_pipeline *pipeline); 70*61046927SAndroid Build Coastguard Worker 71*61046927SAndroid Build Coastguard Worker void radv_rmv_log_event_create(struct radv_device *device, VkEvent event, VkEventCreateFlags flags, bool is_internal); 72*61046927SAndroid Build Coastguard Worker 73*61046927SAndroid Build Coastguard Worker void radv_rmv_log_submit(struct radv_device *device, enum amd_ip_type type); 74*61046927SAndroid Build Coastguard Worker 75*61046927SAndroid Build Coastguard Worker void radv_rmv_log_resource_destroy(struct radv_device *device, uint64_t handle); 76*61046927SAndroid Build Coastguard Worker 77*61046927SAndroid Build Coastguard Worker #endif /* RADV_RMV_H */ 78