xref: /aosp_15_r20/external/mesa3d/src/amd/vulkan/radv_buffer.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1 /*
2  * Copyright © 2016 Red Hat.
3  * Copyright © 2016 Bas Nieuwenhuizen
4  *
5  * based in part on anv driver which is:
6  * Copyright © 2015 Intel Corporation
7  *
8  * SPDX-License-Identifier: MIT
9  */
10 
11 #ifndef RADV_BUFFER_H
12 #define RADV_BUFFER_H
13 
14 #include "radv_radeon_winsys.h"
15 
16 #include "vk_buffer.h"
17 
18 struct radv_device;
19 
20 struct radv_buffer {
21    struct vk_buffer vk;
22 
23    /* Set when bound */
24    struct radeon_winsys_bo *bo;
25    VkDeviceSize offset;
26    uint64_t bo_va;
27    uint64_t range;
28 };
29 
30 VK_DEFINE_NONDISP_HANDLE_CASTS(radv_buffer, vk.base, VkBuffer, VK_OBJECT_TYPE_BUFFER)
31 
32 void radv_buffer_init(struct radv_buffer *buffer, struct radv_device *device, struct radeon_winsys_bo *bo,
33                       uint64_t size, uint64_t offset);
34 void radv_buffer_finish(struct radv_buffer *buffer);
35 
36 VkResult radv_create_buffer(struct radv_device *device, const VkBufferCreateInfo *pCreateInfo,
37                             const VkAllocationCallbacks *pAllocator, VkBuffer *pBuffer, bool is_internal);
38 
39 VkResult radv_bo_create(struct radv_device *device, struct vk_object_base *object, uint64_t size, unsigned alignment,
40                         enum radeon_bo_domain domain, enum radeon_bo_flag flags, unsigned priority, uint64_t address,
41                         bool is_internal, struct radeon_winsys_bo **out_bo);
42 
43 VkResult radv_bo_virtual_bind(struct radv_device *device, struct vk_object_base *object,
44                               struct radeon_winsys_bo *parent, uint64_t offset, uint64_t size,
45                               struct radeon_winsys_bo *bo, uint64_t bo_offset);
46 
47 void radv_bo_destroy(struct radv_device *device, struct vk_object_base *object, struct radeon_winsys_bo *bo);
48 
49 #endif /* RADV_BUFFER_H */
50