Mesa (main): vulkan/overlay: support Vulkan 1.2

GitLab Mirror gitlab-mirror at kemper.freedesktop.org
Thu Jan 13 02:29:28 UTC 2022


Module: Mesa
Branch: main
Commit: 64a51293c8f604da49f118a46e6e62c0abe4c254
URL:    http://cgit.freedesktop.org/mesa/mesa/commit/?id=64a51293c8f604da49f118a46e6e62c0abe4c254

Author: Caleb Callaway <caleb.callaway at intel.com>
Date:   Mon Nov 22 12:06:14 2021 -0800

vulkan/overlay: support Vulkan 1.2

Closes: https://gitlab.freedesktop.org/mesa/mesa/-/issues/5602
Reviewed-by: Lionel Landwerlin <lionel.g.landwerlin at intel.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/14465>

---

 src/vulkan/overlay-layer/VkLayer_MESA_overlay.json |  2 +-
 src/vulkan/overlay-layer/overlay.cpp               | 41 ++++++++++++++++++++++
 2 files changed, 42 insertions(+), 1 deletion(-)

diff --git a/src/vulkan/overlay-layer/VkLayer_MESA_overlay.json b/src/vulkan/overlay-layer/VkLayer_MESA_overlay.json
index 6877c3a3ecd..f2a0f2ee11b 100644
--- a/src/vulkan/overlay-layer/VkLayer_MESA_overlay.json
+++ b/src/vulkan/overlay-layer/VkLayer_MESA_overlay.json
@@ -4,7 +4,7 @@
         "name": "VK_LAYER_MESA_overlay",
         "type": "GLOBAL",
         "library_path": "libVkLayer_MESA_overlay.so",
-        "api_version": "1.1.73",
+        "api_version": "1.2.199",
         "implementation_version": "1",
         "description": "Mesa Overlay layer"
     }
diff --git a/src/vulkan/overlay-layer/overlay.cpp b/src/vulkan/overlay-layer/overlay.cpp
index 270dd9b39e1..55d745d10c6 100644
--- a/src/vulkan/overlay-layer/overlay.cpp
+++ b/src/vulkan/overlay-layer/overlay.cpp
@@ -2452,6 +2452,46 @@ static VkResult overlay_QueueSubmit(
    return device_data->vtable.QueueSubmit(queue, submitCount, pSubmits, fence);
 }
 
+static VkResult overlay_QueueSubmit2KHR(
+    VkQueue                                     queue,
+    uint32_t                                    submitCount,
+    const VkSubmitInfo2KHR*                     pSubmits,
+    VkFence                                     fence)
+{
+   struct queue_data *queue_data = FIND(struct queue_data, queue);
+   struct device_data *device_data = queue_data->device;
+
+   device_data->frame_stats.stats[OVERLAY_PARAM_ENABLED_submit]++;
+
+   for (uint32_t s = 0; s < submitCount; s++) {
+      for (uint32_t c = 0; c < pSubmits[s].commandBufferInfoCount; c++) {
+         struct command_buffer_data *cmd_buffer_data =
+            FIND(struct command_buffer_data, pSubmits[s].pCommandBufferInfos[c].commandBuffer);
+
+         /* Merge the submitted command buffer stats into the device. */
+         for (uint32_t st = 0; st < OVERLAY_PARAM_ENABLED_MAX; st++)
+            device_data->frame_stats.stats[st] += cmd_buffer_data->stats.stats[st];
+
+         /* Attach the command buffer to the queue so we remember to read its
+         * pipeline statistics & timestamps at QueuePresent().
+         */
+         if (!cmd_buffer_data->pipeline_query_pool &&
+            !cmd_buffer_data->timestamp_query_pool)
+            continue;
+
+         if (list_is_empty(&cmd_buffer_data->link)) {
+            list_addtail(&cmd_buffer_data->link,
+                        &queue_data->running_command_buffer);
+         } else {
+            fprintf(stderr, "Command buffer submitted multiple times before present.\n"
+                  "This could lead to invalid data.\n");
+         }
+      }
+   }
+
+   return device_data->vtable.QueueSubmit2KHR(queue, submitCount, pSubmits, fence);
+}
+
 static VkResult overlay_CreateDevice(
     VkPhysicalDevice                            physicalDevice,
     const VkDeviceCreateInfo*                   pCreateInfo,
@@ -2626,6 +2666,7 @@ static const struct {
    ADD_HOOK(AcquireNextImage2KHR),
 
    ADD_HOOK(QueueSubmit),
+   ADD_HOOK(QueueSubmit2KHR),
 
    ADD_HOOK(CreateDevice),
    ADD_HOOK(DestroyDevice),



More information about the mesa-commit mailing list