xref: /aosp_15_r20/external/mesa3d/src/nouveau/vulkan/nvk_buffer.h (revision 6104692788411f58d303aa86923a9ff6ecaded22)
1*61046927SAndroid Build Coastguard Worker /*
2*61046927SAndroid Build Coastguard Worker  * Copyright © 2022 Collabora Ltd. and Red Hat Inc.
3*61046927SAndroid Build Coastguard Worker  * SPDX-License-Identifier: MIT
4*61046927SAndroid Build Coastguard Worker  */
5*61046927SAndroid Build Coastguard Worker #ifndef NVK_BUFFER_H
6*61046927SAndroid Build Coastguard Worker #define NVK_BUFFER_H 1
7*61046927SAndroid Build Coastguard Worker 
8*61046927SAndroid Build Coastguard Worker #include "nvk_private.h"
9*61046927SAndroid Build Coastguard Worker #include "nvk_device_memory.h"
10*61046927SAndroid Build Coastguard Worker 
11*61046927SAndroid Build Coastguard Worker #include "vk_buffer.h"
12*61046927SAndroid Build Coastguard Worker 
13*61046927SAndroid Build Coastguard Worker struct nvk_device_memory;
14*61046927SAndroid Build Coastguard Worker struct nvk_physical_device;
15*61046927SAndroid Build Coastguard Worker struct nvk_queue;
16*61046927SAndroid Build Coastguard Worker struct nvkmd_va;
17*61046927SAndroid Build Coastguard Worker 
18*61046927SAndroid Build Coastguard Worker struct nvk_buffer {
19*61046927SAndroid Build Coastguard Worker    struct vk_buffer vk;
20*61046927SAndroid Build Coastguard Worker    uint64_t addr;
21*61046927SAndroid Build Coastguard Worker 
22*61046927SAndroid Build Coastguard Worker    /** Reserved VA for sparse buffers, NULL otherwise. */
23*61046927SAndroid Build Coastguard Worker    struct nvkmd_va *va;
24*61046927SAndroid Build Coastguard Worker };
25*61046927SAndroid Build Coastguard Worker 
26*61046927SAndroid Build Coastguard Worker VK_DEFINE_NONDISP_HANDLE_CASTS(nvk_buffer, vk.base, VkBuffer,
27*61046927SAndroid Build Coastguard Worker                                VK_OBJECT_TYPE_BUFFER)
28*61046927SAndroid Build Coastguard Worker 
29*61046927SAndroid Build Coastguard Worker static inline uint64_t
nvk_buffer_address(const struct nvk_buffer * buffer,uint64_t offset)30*61046927SAndroid Build Coastguard Worker nvk_buffer_address(const struct nvk_buffer *buffer, uint64_t offset)
31*61046927SAndroid Build Coastguard Worker {
32*61046927SAndroid Build Coastguard Worker    return buffer->addr + offset;
33*61046927SAndroid Build Coastguard Worker }
34*61046927SAndroid Build Coastguard Worker 
35*61046927SAndroid Build Coastguard Worker static inline struct nvk_addr_range
nvk_buffer_addr_range(const struct nvk_buffer * buffer,uint64_t offset,uint64_t range)36*61046927SAndroid Build Coastguard Worker nvk_buffer_addr_range(const struct nvk_buffer *buffer,
37*61046927SAndroid Build Coastguard Worker                       uint64_t offset, uint64_t range)
38*61046927SAndroid Build Coastguard Worker {
39*61046927SAndroid Build Coastguard Worker    if (buffer == NULL)
40*61046927SAndroid Build Coastguard Worker       return (struct nvk_addr_range) { .range = 0 };
41*61046927SAndroid Build Coastguard Worker 
42*61046927SAndroid Build Coastguard Worker    return (struct nvk_addr_range) {
43*61046927SAndroid Build Coastguard Worker       .addr = nvk_buffer_address(buffer, offset),
44*61046927SAndroid Build Coastguard Worker       .range = vk_buffer_range(&buffer->vk, offset, range),
45*61046927SAndroid Build Coastguard Worker    };
46*61046927SAndroid Build Coastguard Worker }
47*61046927SAndroid Build Coastguard Worker 
48*61046927SAndroid Build Coastguard Worker VkResult nvk_queue_buffer_bind(struct nvk_queue *queue,
49*61046927SAndroid Build Coastguard Worker                                const VkSparseBufferMemoryBindInfo *bind_info);
50*61046927SAndroid Build Coastguard Worker 
51*61046927SAndroid Build Coastguard Worker #endif
52