summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorSamuel Pitoiset <samuel.pitoiset@gmail.com>2023-03-07 16:44:43 +0100
committerMarge Bot <emma+marge@anholt.net>2023-03-08 16:21:10 +0000
commit17c5a91028409205cce2b37429d6fbf032a9773c (patch)
tree8371e553e2d0ee9b0159a85e4d3d5209a4f1eb85 /src
parent4de305cb8a3c68df8e89f8c1359f510a1089cfd3 (diff)
downloadmesa-17c5a91028409205cce2b37429d6fbf032a9773c.tar.gz
radv: move event related code to radv_event.c
radv_device.c is getting too big. Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21767>
Diffstat (limited to 'src')
-rw-r--r--src/amd/vulkan/meson.build1
-rw-r--r--src/amd/vulkan/radv_device.c113
-rw-r--r--src/amd/vulkan/radv_event.c141
3 files changed, 142 insertions, 113 deletions
diff --git a/src/amd/vulkan/meson.build b/src/amd/vulkan/meson.build
index 8e65e3475d5..5df03e1df40 100644
--- a/src/amd/vulkan/meson.build
+++ b/src/amd/vulkan/meson.build
@@ -69,6 +69,7 @@ libradv_files = files(
'radv_descriptor_set.c',
'radv_descriptor_set.h',
'radv_device_generated_commands.c',
+ 'radv_event.c',
'radv_formats.c',
'radv_image.c',
'radv_instance.c',
diff --git a/src/amd/vulkan/radv_device.c b/src/amd/vulkan/radv_device.c
index 71512830cc5..ea56831fdcf 100644
--- a/src/amd/vulkan/radv_device.c
+++ b/src/amd/vulkan/radv_device.c
@@ -1758,119 +1758,6 @@ radv_BindImageMemory2(VkDevice _device, uint32_t bindInfoCount,
return VK_SUCCESS;
}
-static void
-radv_destroy_event(struct radv_device *device, const VkAllocationCallbacks *pAllocator,
- struct radv_event *event)
-{
- if (event->bo)
- device->ws->buffer_destroy(device->ws, event->bo);
-
- vk_object_base_finish(&event->base);
- vk_free2(&device->vk.alloc, pAllocator, event);
-}
-
-VkResult
-radv_create_event(struct radv_device *device, const VkEventCreateInfo *pCreateInfo,
- const VkAllocationCallbacks *pAllocator, VkEvent *pEvent, bool is_internal)
-{
- enum radeon_bo_domain bo_domain;
- enum radeon_bo_flag bo_flags;
- struct radv_event *event;
- VkResult result;
-
- event = vk_alloc2(&device->vk.alloc, pAllocator, sizeof(*event), 8,
- VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
- if (!event)
- return vk_error(device, VK_ERROR_OUT_OF_HOST_MEMORY);
-
- vk_object_base_init(&device->vk, &event->base, VK_OBJECT_TYPE_EVENT);
-
- if (pCreateInfo->flags & VK_EVENT_CREATE_DEVICE_ONLY_BIT) {
- bo_domain = RADEON_DOMAIN_VRAM;
- bo_flags = RADEON_FLAG_NO_CPU_ACCESS;
- } else {
- bo_domain = RADEON_DOMAIN_GTT;
- bo_flags = RADEON_FLAG_CPU_ACCESS;
- }
-
- result = device->ws->buffer_create(
- device->ws, 8, 8, bo_domain,
- RADEON_FLAG_VA_UNCACHED | RADEON_FLAG_NO_INTERPROCESS_SHARING | bo_flags,
- RADV_BO_PRIORITY_FENCE, 0, &event->bo);
- if (result != VK_SUCCESS) {
- radv_destroy_event(device, pAllocator, event);
- return vk_error(device, result);
- }
-
- if (!(pCreateInfo->flags & VK_EVENT_CREATE_DEVICE_ONLY_BIT)) {
- event->map = (uint64_t *)device->ws->buffer_map(event->bo);
- if (!event->map) {
- radv_destroy_event(device, pAllocator, event);
- return vk_error(device, VK_ERROR_OUT_OF_DEVICE_MEMORY);
- }
- }
-
- *pEvent = radv_event_to_handle(event);
- radv_rmv_log_event_create(device, *pEvent, pCreateInfo->flags, is_internal);
- return VK_SUCCESS;
-}
-
-VKAPI_ATTR VkResult VKAPI_CALL
-radv_CreateEvent(VkDevice _device, const VkEventCreateInfo *pCreateInfo,
- const VkAllocationCallbacks *pAllocator, VkEvent *pEvent)
-{
- RADV_FROM_HANDLE(radv_device, device, _device);
- VkResult result = radv_create_event(device, pCreateInfo, pAllocator, pEvent, false);
- if (result != VK_SUCCESS)
- return result;
-
- return VK_SUCCESS;
-}
-
-VKAPI_ATTR void VKAPI_CALL
-radv_DestroyEvent(VkDevice _device, VkEvent _event, const VkAllocationCallbacks *pAllocator)
-{
- RADV_FROM_HANDLE(radv_device, device, _device);
- RADV_FROM_HANDLE(radv_event, event, _event);
-
- if (!event)
- return;
-
- radv_destroy_event(device, pAllocator, event);
-}
-
-VKAPI_ATTR VkResult VKAPI_CALL
-radv_GetEventStatus(VkDevice _device, VkEvent _event)
-{
- RADV_FROM_HANDLE(radv_device, device, _device);
- RADV_FROM_HANDLE(radv_event, event, _event);
-
- if (vk_device_is_lost(&device->vk))
- return VK_ERROR_DEVICE_LOST;
-
- if (*event->map == 1)
- return VK_EVENT_SET;
- return VK_EVENT_RESET;
-}
-
-VKAPI_ATTR VkResult VKAPI_CALL
-radv_SetEvent(VkDevice _device, VkEvent _event)
-{
- RADV_FROM_HANDLE(radv_event, event, _event);
- *event->map = 1;
-
- return VK_SUCCESS;
-}
-
-VKAPI_ATTR VkResult VKAPI_CALL
-radv_ResetEvent(VkDevice _device, VkEvent _event)
-{
- RADV_FROM_HANDLE(radv_event, event, _event);
- *event->map = 0;
-
- return VK_SUCCESS;
-}
-
void
radv_buffer_init(struct radv_buffer *buffer, struct radv_device *device,
struct radeon_winsys_bo *bo, uint64_t size,
diff --git a/src/amd/vulkan/radv_event.c b/src/amd/vulkan/radv_event.c
new file mode 100644
index 00000000000..476d22c80e0
--- /dev/null
+++ b/src/amd/vulkan/radv_event.c
@@ -0,0 +1,141 @@
+/*
+ * Copyright © 2016 Red Hat.
+ * Copyright © 2016 Bas Nieuwenhuizen
+ *
+ * based in part on anv driver which is:
+ * Copyright © 2015 Intel Corporation
+ *
+ * Permission is hereby granted, free of charge, to any person obtaining a
+ * copy of this software and associated documentation files (the "Software"),
+ * to deal in the Software without restriction, including without limitation
+ * the rights to use, copy, modify, merge, publish, distribute, sublicense,
+ * and/or sell copies of the Software, and to permit persons to whom the
+ * Software is furnished to do so, subject to the following conditions:
+ *
+ * The above copyright notice and this permission notice (including the next
+ * paragraph) shall be included in all copies or substantial portions of the
+ * Software.
+ *
+ * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
+ * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
+ * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL
+ * THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
+ * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING
+ * FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS
+ * IN THE SOFTWARE.
+ */
+
+#include "radv_private.h"
+
+static void
+radv_destroy_event(struct radv_device *device, const VkAllocationCallbacks *pAllocator,
+ struct radv_event *event)
+{
+ if (event->bo)
+ device->ws->buffer_destroy(device->ws, event->bo);
+
+ vk_object_base_finish(&event->base);
+ vk_free2(&device->vk.alloc, pAllocator, event);
+}
+
+VkResult
+radv_create_event(struct radv_device *device, const VkEventCreateInfo *pCreateInfo,
+ const VkAllocationCallbacks *pAllocator, VkEvent *pEvent, bool is_internal)
+{
+ enum radeon_bo_domain bo_domain;
+ enum radeon_bo_flag bo_flags;
+ struct radv_event *event;
+ VkResult result;
+
+ event = vk_alloc2(&device->vk.alloc, pAllocator, sizeof(*event), 8,
+ VK_SYSTEM_ALLOCATION_SCOPE_OBJECT);
+ if (!event)
+ return vk_error(device, VK_ERROR_OUT_OF_HOST_MEMORY);
+
+ vk_object_base_init(&device->vk, &event->base, VK_OBJECT_TYPE_EVENT);
+
+ if (pCreateInfo->flags & VK_EVENT_CREATE_DEVICE_ONLY_BIT) {
+ bo_domain = RADEON_DOMAIN_VRAM;
+ bo_flags = RADEON_FLAG_NO_CPU_ACCESS;
+ } else {
+ bo_domain = RADEON_DOMAIN_GTT;
+ bo_flags = RADEON_FLAG_CPU_ACCESS;
+ }
+
+ result = device->ws->buffer_create(
+ device->ws, 8, 8, bo_domain,
+ RADEON_FLAG_VA_UNCACHED | RADEON_FLAG_NO_INTERPROCESS_SHARING | bo_flags,
+ RADV_BO_PRIORITY_FENCE, 0, &event->bo);
+ if (result != VK_SUCCESS) {
+ radv_destroy_event(device, pAllocator, event);
+ return vk_error(device, result);
+ }
+
+ if (!(pCreateInfo->flags & VK_EVENT_CREATE_DEVICE_ONLY_BIT)) {
+ event->map = (uint64_t *)device->ws->buffer_map(event->bo);
+ if (!event->map) {
+ radv_destroy_event(device, pAllocator, event);
+ return vk_error(device, VK_ERROR_OUT_OF_DEVICE_MEMORY);
+ }
+ }
+
+ *pEvent = radv_event_to_handle(event);
+ radv_rmv_log_event_create(device, *pEvent, pCreateInfo->flags, is_internal);
+ return VK_SUCCESS;
+}
+
+VKAPI_ATTR VkResult VKAPI_CALL
+radv_CreateEvent(VkDevice _device, const VkEventCreateInfo *pCreateInfo,
+ const VkAllocationCallbacks *pAllocator, VkEvent *pEvent)
+{
+ RADV_FROM_HANDLE(radv_device, device, _device);
+ VkResult result = radv_create_event(device, pCreateInfo, pAllocator, pEvent, false);
+ if (result != VK_SUCCESS)
+ return result;
+
+ return VK_SUCCESS;
+}
+
+VKAPI_ATTR void VKAPI_CALL
+radv_DestroyEvent(VkDevice _device, VkEvent _event, const VkAllocationCallbacks *pAllocator)
+{
+ RADV_FROM_HANDLE(radv_device, device, _device);
+ RADV_FROM_HANDLE(radv_event, event, _event);
+
+ if (!event)
+ return;
+
+ radv_destroy_event(device, pAllocator, event);
+}
+
+VKAPI_ATTR VkResult VKAPI_CALL
+radv_GetEventStatus(VkDevice _device, VkEvent _event)
+{
+ RADV_FROM_HANDLE(radv_device, device, _device);
+ RADV_FROM_HANDLE(radv_event, event, _event);
+
+ if (vk_device_is_lost(&device->vk))
+ return VK_ERROR_DEVICE_LOST;
+
+ if (*event->map == 1)
+ return VK_EVENT_SET;
+ return VK_EVENT_RESET;
+}
+
+VKAPI_ATTR VkResult VKAPI_CALL
+radv_SetEvent(VkDevice _device, VkEvent _event)
+{
+ RADV_FROM_HANDLE(radv_event, event, _event);
+ *event->map = 1;
+
+ return VK_SUCCESS;
+}
+
+VKAPI_ATTR VkResult VKAPI_CALL
+radv_ResetEvent(VkDevice _device, VkEvent _event)
+{
+ RADV_FROM_HANDLE(radv_event, event, _event);
+ *event->map = 0;
+
+ return VK_SUCCESS;
+}