aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorzccrs <zccrs@live.com>2022-05-23 21:54:36 +0800
committerSimon Ser <contact@emersion.fr>2022-11-08 12:56:38 +0100
commit270914d379bd24aed1f5be219fa3469cc57d9d36 (patch)
tree41738cff99e7fbbfedf6c832a612bfc24da5bbb6
parent9fefeb69d6fc1136cfad7d690e1d7385c058fd72 (diff)
render/vulkan: add some interfaces to allow compositors to integrate
Added wlr_vk_renderer_get_* functions to allow get the VkInstance, VkPhysicalDevice, VkDevice, queue family of a wlr_vk_renderer. Added wlr_vk_renderer_get_current_image_attribs function to allow get the VkImage of current renderer buffer to use on compositors. Added wlr_renderer_is_vk function, it's like the wlr_renderer_is_gles2, returns true if the wlr_renderer is a wlr_vk_renderer. Added wlr_vk_image_get_attribs function to get a VkImage and it's extras information (e.g. a VkImageLayout and VkImageFormat of the VkImage) from a wlr_texture.
-rw-r--r--include/wlr/render/vulkan.h19
-rw-r--r--render/vulkan/renderer.c38
-rw-r--r--render/vulkan/texture.c13
3 files changed, 66 insertions, 4 deletions
diff --git a/include/wlr/render/vulkan.h b/include/wlr/render/vulkan.h
index 0302d85b..aec3a3c2 100644
--- a/include/wlr/render/vulkan.h
+++ b/include/wlr/render/vulkan.h
@@ -9,10 +9,29 @@
#ifndef WLR_RENDER_VULKAN_H
#define WLR_RENDER_VULKAN_H
+#include <vulkan/vulkan_core.h>
#include <wlr/render/wlr_renderer.h>
+struct wlr_vk_image_attribs {
+ VkImage image;
+ VkImageLayout layout;
+ VkFormat format;
+};
+
struct wlr_renderer *wlr_vk_renderer_create_with_drm_fd(int drm_fd);
+
+VkInstance wlr_vk_renderer_get_instance(struct wlr_renderer *renderer);
+VkPhysicalDevice wlr_vk_renderer_get_physical_device(struct wlr_renderer *renderer);
+VkDevice wlr_vk_renderer_get_device(struct wlr_renderer *renderer);
+uint32_t wlr_vk_renderer_get_queue_family(struct wlr_renderer *renderer);
+void wlr_vk_renderer_get_current_image_attribs(struct wlr_renderer *renderer,
+ struct wlr_vk_image_attribs *attribs);
+
+bool wlr_renderer_is_vk(struct wlr_renderer *wlr_renderer);
bool wlr_texture_is_vk(struct wlr_texture *texture);
+void wlr_vk_texture_get_image_attribs(struct wlr_texture *texture,
+ struct wlr_vk_image_attribs *attribs);
+
#endif
diff --git a/render/vulkan/renderer.c b/render/vulkan/renderer.c
index 8bf01b1d..e620b42e 100644
--- a/render/vulkan/renderer.c
+++ b/render/vulkan/renderer.c
@@ -42,8 +42,12 @@ static bool default_debug = true;
static const struct wlr_renderer_impl renderer_impl;
+bool wlr_renderer_is_vk(struct wlr_renderer *wlr_renderer) {
+ return wlr_renderer->impl == &renderer_impl;
+}
+
struct wlr_vk_renderer *vulkan_get_renderer(struct wlr_renderer *wlr_renderer) {
- assert(wlr_renderer->impl == &renderer_impl);
+ assert(wlr_renderer_is_vk(wlr_renderer));
return (struct wlr_vk_renderer *)wlr_renderer;
}
@@ -1817,3 +1821,35 @@ struct wlr_renderer *wlr_vk_renderer_create_with_drm_fd(int drm_fd) {
return vulkan_renderer_create_for_device(dev);
}
+
+VkInstance wlr_vk_renderer_get_instance(struct wlr_renderer *renderer)
+{
+ struct wlr_vk_renderer *vk_renderer = vulkan_get_renderer(renderer);
+ return vk_renderer->dev->instance->instance;
+}
+
+VkPhysicalDevice wlr_vk_renderer_get_physical_device(struct wlr_renderer *renderer)
+{
+ struct wlr_vk_renderer *vk_renderer = vulkan_get_renderer(renderer);
+ return vk_renderer->dev->phdev;
+}
+
+VkDevice wlr_vk_renderer_get_device(struct wlr_renderer *renderer)
+{
+ struct wlr_vk_renderer *vk_renderer = vulkan_get_renderer(renderer);
+ return vk_renderer->dev->dev;
+}
+
+uint32_t wlr_vk_renderer_get_queue_family(struct wlr_renderer *renderer)
+{
+ struct wlr_vk_renderer *vk_renderer = vulkan_get_renderer(renderer);
+ return vk_renderer->dev->queue_family;
+}
+
+void wlr_vk_renderer_get_current_image_attribs(struct wlr_renderer *renderer,
+ struct wlr_vk_image_attribs *attribs) {
+ struct wlr_vk_renderer *vk_renderer = vulkan_get_renderer(renderer);
+ attribs->image = vk_renderer->current_render_buffer->image;
+ attribs->format = vk_renderer->current_render_buffer->render_setup->render_format;
+ attribs->layout = VK_IMAGE_LAYOUT_UNDEFINED;
+}
diff --git a/render/vulkan/texture.c b/render/vulkan/texture.c
index 3eaab3ae..5776233c 100644
--- a/render/vulkan/texture.c
+++ b/render/vulkan/texture.c
@@ -283,8 +283,6 @@ static struct wlr_texture *vulkan_texture_from_pixels(
.usage = VK_IMAGE_USAGE_SAMPLED_BIT | VK_IMAGE_USAGE_TRANSFER_DST_BIT,
};
- VkImageLayout layout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL;
-
res = vkCreateImage(dev, &img_info, NULL, &texture->image);
if (res != VK_SUCCESS) {
wlr_vk_error("vkCreateImage failed", res);
@@ -362,7 +360,7 @@ static struct wlr_texture *vulkan_texture_from_pixels(
VkDescriptorImageInfo ds_img_info = {
.imageView = texture->image_view,
- .imageLayout = layout,
+ .imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL,
};
VkWriteDescriptorSet ds_write = {
@@ -771,3 +769,12 @@ struct wlr_texture *vulkan_texture_from_buffer(struct wlr_renderer *wlr_renderer
return NULL;
}
}
+
+void wlr_vk_texture_get_image_attribs(struct wlr_texture *texture,
+ struct wlr_vk_image_attribs *attribs) {
+ struct wlr_vk_texture *vk_texture = vulkan_get_texture(texture);
+ attribs->image = vk_texture->image;
+ attribs->format = vk_texture->format->vk_format;
+ attribs->layout = vk_texture->transitioned ?
+ VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL : VK_IMAGE_LAYOUT_UNDEFINED;
+}