xref: /aosp_15_r20/external/mesa3d/src/intel/vulkan/anv_rmv.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright © 2024 Intel Corporation
3*61046927SAndroid Build Coastguard Worker  *
4*61046927SAndroid Build Coastguard Worker  * Permission is hereby granted, free of charge, to any person obtaining a
5*61046927SAndroid Build Coastguard Worker  * copy of this software and associated documentation files (the "Software"),
6*61046927SAndroid Build Coastguard Worker  * to deal in the Software without restriction, including without limitation
7*61046927SAndroid Build Coastguard Worker  * the rights to use, copy, modify, merge, publish, distribute, sublicense,
8*61046927SAndroid Build Coastguard Worker  * and/or sell copies of the Software, and to permit persons to whom the
9*61046927SAndroid Build Coastguard Worker  * Software is furnished to do so, subject to the following conditions:
10*61046927SAndroid Build Coastguard Worker  *
11*61046927SAndroid Build Coastguard Worker  * The above copyright notice and this permission notice (including the next
12*61046927SAndroid Build Coastguard Worker  * paragraph) shall be included in all copies or substantial portions of the
13*61046927SAndroid Build Coastguard Worker  * Software.
14*61046927SAndroid Build Coastguard Worker  *
15*61046927SAndroid Build Coastguard Worker  * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
16*61046927SAndroid Build Coastguard Worker  * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
17*61046927SAndroid Build Coastguard Worker  * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT.  IN NO EVENT SHALL
18*61046927SAndroid Build Coastguard Worker  * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
19*61046927SAndroid Build Coastguard Worker  * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
20*61046927SAndroid Build Coastguard Worker  * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
21*61046927SAndroid Build Coastguard Worker  * IN THE SOFTWARE.
22*61046927SAndroid Build Coastguard Worker  */
23*61046927SAndroid Build Coastguard Worker 
24*61046927SAndroid Build Coastguard Worker #ifndef ANV_RMV_H
25*61046927SAndroid Build Coastguard Worker #define ANV_RMV_H
26*61046927SAndroid Build Coastguard Worker 
27*61046927SAndroid Build Coastguard Worker #include <stdbool.h>
28*61046927SAndroid Build Coastguard Worker #include <stdint.h>
29*61046927SAndroid Build Coastguard Worker 
30*61046927SAndroid Build Coastguard Worker #include "vulkan/vulkan_core.h"
31*61046927SAndroid Build Coastguard Worker 
32*61046927SAndroid Build Coastguard Worker struct anv_device;
33*61046927SAndroid Build Coastguard Worker struct anv_device_memory;
34*61046927SAndroid Build Coastguard Worker struct anv_physical_device;
35*61046927SAndroid Build Coastguard Worker struct anv_descriptor_pool;
36*61046927SAndroid Build Coastguard Worker struct anv_buffer;
37*61046927SAndroid Build Coastguard Worker struct anv_image;
38*61046927SAndroid Build Coastguard Worker struct anv_bo;
39*61046927SAndroid Build Coastguard Worker struct anv_event;
40*61046927SAndroid Build Coastguard Worker struct anv_graphics_pipeline;
41*61046927SAndroid Build Coastguard Worker struct anv_compute_pipeline;
42*61046927SAndroid Build Coastguard Worker struct anv_ray_tracing_pipeline;
43*61046927SAndroid Build Coastguard Worker 
44*61046927SAndroid Build Coastguard Worker enum anv_image_memory_binding;
45*61046927SAndroid Build Coastguard Worker 
46*61046927SAndroid Build Coastguard Worker #define ANV_RMV(func, device, ...) do { \
47*61046927SAndroid Build Coastguard Worker       if (unlikely((device)->vk.memory_trace_data.is_enabled)) \
48*61046927SAndroid Build Coastguard Worker          anv_rmv_log_##func(device, __VA_ARGS__); \
49*61046927SAndroid Build Coastguard Worker    } while (0)
50*61046927SAndroid Build Coastguard Worker 
51*61046927SAndroid Build Coastguard Worker void anv_memory_trace_init(struct anv_device *device);
52*61046927SAndroid Build Coastguard Worker void anv_rmv_fill_device_info(const struct anv_physical_device *device,
53*61046927SAndroid Build Coastguard Worker                               struct vk_rmv_device_info *info);
54*61046927SAndroid Build Coastguard Worker void anv_memory_trace_finish(struct anv_device *device);
55*61046927SAndroid Build Coastguard Worker 
56*61046927SAndroid Build Coastguard Worker void anv_rmv_log_heap_create(struct anv_device *device,
57*61046927SAndroid Build Coastguard Worker                              struct anv_device_memory *memory,
58*61046927SAndroid Build Coastguard Worker                              bool is_internal,
59*61046927SAndroid Build Coastguard Worker                              VkMemoryAllocateFlags alloc_flags);
60*61046927SAndroid Build Coastguard Worker void anv_rmv_log_bo_gtt_map(struct anv_device *device,
61*61046927SAndroid Build Coastguard Worker                             struct anv_bo *bo);
62*61046927SAndroid Build Coastguard Worker void anv_rmv_log_bo_gtt_unmap(struct anv_device *device,
63*61046927SAndroid Build Coastguard Worker                               struct anv_bo *bo);
64*61046927SAndroid Build Coastguard Worker void anv_rmv_log_bos_gtt_map(struct anv_device *device,
65*61046927SAndroid Build Coastguard Worker                              struct anv_bo **bos,
66*61046927SAndroid Build Coastguard Worker                              uint32_t bo_count);
67*61046927SAndroid Build Coastguard Worker void anv_rmv_log_vm_binds(struct anv_device *device,
68*61046927SAndroid Build Coastguard Worker                           struct anv_vm_bind *binds,
69*61046927SAndroid Build Coastguard Worker                           uint32_t bind_count);
70*61046927SAndroid Build Coastguard Worker void anv_rmv_log_bo_allocate(struct anv_device *device,
71*61046927SAndroid Build Coastguard Worker                              struct anv_bo *bo);
72*61046927SAndroid Build Coastguard Worker void anv_rmv_log_bo_destroy(struct anv_device *device, struct anv_bo *bo);
73*61046927SAndroid Build Coastguard Worker void anv_rmv_log_buffer_create(struct anv_device *device,
74*61046927SAndroid Build Coastguard Worker                                bool is_internal,
75*61046927SAndroid Build Coastguard Worker                                struct anv_buffer *buffer);
76*61046927SAndroid Build Coastguard Worker void anv_rmv_log_buffer_destroy(struct anv_device *device,
77*61046927SAndroid Build Coastguard Worker                                 struct anv_buffer *buffer);
78*61046927SAndroid Build Coastguard Worker void anv_rmv_log_buffer_bind(struct anv_device *device, struct anv_buffer *buffer);
79*61046927SAndroid Build Coastguard Worker void anv_rmv_log_image_create(struct anv_device *device,
80*61046927SAndroid Build Coastguard Worker                               bool is_internal,
81*61046927SAndroid Build Coastguard Worker                               struct anv_image *image);
82*61046927SAndroid Build Coastguard Worker void anv_rmv_log_image_destroy(struct anv_device *device,
83*61046927SAndroid Build Coastguard Worker                                struct anv_image *image);
84*61046927SAndroid Build Coastguard Worker void anv_rmv_log_image_bind(struct anv_device *device,
85*61046927SAndroid Build Coastguard Worker                             struct anv_image *image,
86*61046927SAndroid Build Coastguard Worker                             enum anv_image_memory_binding binding);
87*61046927SAndroid Build Coastguard Worker void anv_rmv_log_query_pool_create(struct anv_device *device,
88*61046927SAndroid Build Coastguard Worker                                    struct anv_query_pool *pool,
89*61046927SAndroid Build Coastguard Worker                                    bool is_internal);
90*61046927SAndroid Build Coastguard Worker void anv_rmv_log_cmd_buffer_create(struct anv_device *device,
91*61046927SAndroid Build Coastguard Worker                                    struct anv_cmd_buffer *cmd_buffer);
92*61046927SAndroid Build Coastguard Worker void anv_rmv_log_cmd_buffer_destroy(struct anv_device *device,
93*61046927SAndroid Build Coastguard Worker                                     struct anv_cmd_buffer *cmd_buffer);
94*61046927SAndroid Build Coastguard Worker void anv_rmv_log_sparse_add_residency(struct anv_device *device,
95*61046927SAndroid Build Coastguard Worker                                       struct anv_bo *src_bo,
96*61046927SAndroid Build Coastguard Worker                                       uint64_t offset);
97*61046927SAndroid Build Coastguard Worker void anv_rmv_log_sparse_remove_residency(struct anv_device *device,
98*61046927SAndroid Build Coastguard Worker                                          struct anv_bo *src_bo,
99*61046927SAndroid Build Coastguard Worker                                          uint64_t offset);
100*61046927SAndroid Build Coastguard Worker void anv_rmv_log_descriptor_pool_create(struct anv_device *device,
101*61046927SAndroid Build Coastguard Worker                                         const VkDescriptorPoolCreateInfo *create_info,
102*61046927SAndroid Build Coastguard Worker                                         struct anv_descriptor_pool *pool,
103*61046927SAndroid Build Coastguard Worker                                         bool is_internal);
104*61046927SAndroid Build Coastguard Worker void anv_rmv_log_graphics_pipeline_create(struct anv_device *device,
105*61046927SAndroid Build Coastguard Worker                                           struct anv_graphics_pipeline *pipeline,
106*61046927SAndroid Build Coastguard Worker                                           bool is_internal);
107*61046927SAndroid Build Coastguard Worker void anv_rmv_log_compute_pipeline_create(struct anv_device *device,
108*61046927SAndroid Build Coastguard Worker                                          struct anv_compute_pipeline *pipeline,
109*61046927SAndroid Build Coastguard Worker                                          bool is_internal);
110*61046927SAndroid Build Coastguard Worker void anv_rmv_log_rt_pipeline_create(struct anv_device *device,
111*61046927SAndroid Build Coastguard Worker                                     struct anv_ray_tracing_pipeline *pipeline,
112*61046927SAndroid Build Coastguard Worker                                     bool is_internal);
113*61046927SAndroid Build Coastguard Worker void anv_rmv_log_event_create(struct anv_device *device,
114*61046927SAndroid Build Coastguard Worker                               struct anv_event *event,
115*61046927SAndroid Build Coastguard Worker                               VkEventCreateFlags flags, bool is_internal);
116*61046927SAndroid Build Coastguard Worker void anv_rmv_log_resource_destroy(struct anv_device *device, const void *obj);
117*61046927SAndroid Build Coastguard Worker 
118*61046927SAndroid Build Coastguard Worker #endif /* ANV_RMV_H */
119