1 /*
2 * Copyright 2020 Google LLC
3 * SPDX-License-Identifier: MIT
4 */
5
6 #ifndef VKR_DEVICE_H
7 #define VKR_DEVICE_H
8
9 #include "vkr_common.h"
10
11 #include "vkr_context.h"
12
13 struct vkr_device {
14 struct vkr_object base;
15
16 struct vkr_physical_device *physical_device;
17
18 /* Vulkan 1.2 */
19 PFN_vkGetSemaphoreCounterValue GetSemaphoreCounterValue;
20 PFN_vkWaitSemaphores WaitSemaphores;
21 PFN_vkSignalSemaphore SignalSemaphore;
22 PFN_vkGetDeviceMemoryOpaqueCaptureAddress GetDeviceMemoryOpaqueCaptureAddress;
23 PFN_vkGetBufferOpaqueCaptureAddress GetBufferOpaqueCaptureAddress;
24 PFN_vkGetBufferDeviceAddress GetBufferDeviceAddress;
25 PFN_vkResetQueryPool ResetQueryPool;
26 PFN_vkCreateRenderPass2 CreateRenderPass2;
27 PFN_vkCmdBeginRenderPass2 CmdBeginRenderPass2;
28 PFN_vkCmdNextSubpass2 CmdNextSubpass2;
29 PFN_vkCmdEndRenderPass2 CmdEndRenderPass2;
30 PFN_vkCmdDrawIndirectCount CmdDrawIndirectCount;
31 PFN_vkCmdDrawIndexedIndirectCount CmdDrawIndexedIndirectCount;
32
33 PFN_vkCmdBindTransformFeedbackBuffersEXT cmd_bind_transform_feedback_buffers;
34 PFN_vkCmdBeginTransformFeedbackEXT cmd_begin_transform_feedback;
35 PFN_vkCmdEndTransformFeedbackEXT cmd_end_transform_feedback;
36 PFN_vkCmdBeginQueryIndexedEXT cmd_begin_query_indexed;
37 PFN_vkCmdEndQueryIndexedEXT cmd_end_query_indexed;
38 PFN_vkCmdDrawIndirectByteCountEXT cmd_draw_indirect_byte_count;
39
40 PFN_vkGetImageDrmFormatModifierPropertiesEXT get_image_drm_format_modifier_properties;
41
42 PFN_vkGetMemoryFdPropertiesKHR get_memory_fd_properties;
43
44 struct list_head queues;
45
46 mtx_t free_sync_mutex;
47 struct list_head free_syncs;
48
49 struct list_head objects;
50 };
51 VKR_DEFINE_OBJECT_CAST(device, VK_OBJECT_TYPE_DEVICE, VkDevice)
52
53 void
54 vkr_context_init_device_dispatch(struct vkr_context *ctx);
55
56 void
57 vkr_device_destroy(struct vkr_context *ctx, struct vkr_device *dev);
58
59 static inline bool
vkr_device_should_track_object(const struct vkr_object * obj)60 vkr_device_should_track_object(const struct vkr_object *obj)
61 {
62 assert(vkr_is_recognized_object_type(obj->type));
63
64 switch (obj->type) {
65 case VK_OBJECT_TYPE_INSTANCE: /* non-device objects */
66 case VK_OBJECT_TYPE_PHYSICAL_DEVICE: /* non-device objects */
67 case VK_OBJECT_TYPE_DEVICE: /* device itself */
68 case VK_OBJECT_TYPE_QUEUE: /* not tracked as device objects */
69 case VK_OBJECT_TYPE_COMMAND_BUFFER: /* pool objects */
70 case VK_OBJECT_TYPE_DESCRIPTOR_SET: /* pool objects */
71 return false;
72 default:
73 return true;
74 }
75 }
76
77 static inline void
vkr_device_add_object(struct vkr_context * ctx,struct vkr_device * dev,struct vkr_object * obj)78 vkr_device_add_object(struct vkr_context *ctx,
79 struct vkr_device *dev,
80 struct vkr_object *obj)
81 {
82 vkr_context_add_object(ctx, obj);
83
84 assert(vkr_device_should_track_object(obj));
85 list_add(&obj->track_head, &dev->objects);
86 }
87
88 static inline void
vkr_device_remove_object(struct vkr_context * ctx,UNUSED struct vkr_device * dev,struct vkr_object * obj)89 vkr_device_remove_object(struct vkr_context *ctx,
90 UNUSED struct vkr_device *dev,
91 struct vkr_object *obj)
92 {
93 assert(vkr_device_should_track_object(obj));
94 list_del(&obj->track_head);
95
96 /* this frees obj */
97 vkr_context_remove_object(ctx, obj);
98 }
99
100 #endif /* VKR_DEVICE_H */
101