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