blob: 82f70be439b7c2ffb46b3db3b1607a49864c71d6 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
|
/*
* Copyright 2019 Google LLC
* SPDX-License-Identifier: MIT
*
* based in part on anv and radv which are:
* Copyright © 2015 Intel Corporation
* Copyright © 2016 Red Hat.
* Copyright © 2016 Bas Nieuwenhuizen
*/
#ifndef VN_BUFFER_H
#define VN_BUFFER_H
#include "vn_common.h"
struct vn_buffer_memory_requirements {
VkMemoryRequirements2 memory;
VkMemoryDedicatedRequirements dedicated;
};
struct vn_buffer_cache_entry {
struct vn_buffer_memory_requirements requirements;
atomic_bool valid;
};
struct vn_buffer_cache {
/* cache memory type requirement for AHB backed VkBuffer */
uint32_t ahb_mem_type_bits;
uint64_t max_buffer_size;
/* lazily cache memory requirements for native buffer infos */
struct util_sparse_array entries;
simple_mtx_t mutex;
struct {
uint32_t cache_skip_count;
uint32_t cache_hit_count;
uint32_t cache_miss_count;
} debug;
};
struct vn_buffer {
struct vn_object_base base;
struct vn_buffer_memory_requirements requirements;
};
VK_DEFINE_NONDISP_HANDLE_CASTS(vn_buffer,
base.base,
VkBuffer,
VK_OBJECT_TYPE_BUFFER)
struct vn_buffer_view {
struct vn_object_base base;
};
VK_DEFINE_NONDISP_HANDLE_CASTS(vn_buffer_view,
base.base,
VkBufferView,
VK_OBJECT_TYPE_BUFFER_VIEW)
VkResult
vn_buffer_create(struct vn_device *dev,
const VkBufferCreateInfo *create_info,
const VkAllocationCallbacks *alloc,
struct vn_buffer **out_buf);
VkResult
vn_buffer_cache_init(struct vn_device *dev);
void
vn_buffer_cache_fini(struct vn_device *dev);
#endif /* VN_BUFFER_H */
|