[gtk+/wip/otte/vulkan: 12/28] vulkan: Make the GskVulkanRender struct private
- From: Benjamin Otte <otte src gnome org>
- To: commits-list gnome org
- Cc:
- Subject: [gtk+/wip/otte/vulkan: 12/28] vulkan: Make the GskVulkanRender struct private
- Date: Fri, 9 Dec 2016 06:28:03 +0000 (UTC)
commit 728e26a09976e8ddab1eb025bd895a8656709ac0
Author: Benjamin Otte <otte redhat com>
Date: Thu Dec 8 17:55:32 2016 +0100
vulkan: Make the GskVulkanRender struct private
gsk/gskvulkanrender.c | 27 +++++++++++++++++++++++++--
gsk/gskvulkanrenderpass.c | 22 +++++++++++++---------
gsk/gskvulkanrenderpassprivate.h | 6 ++++--
gsk/gskvulkanrenderprivate.h | 20 ++------------------
4 files changed, 44 insertions(+), 31 deletions(-)
---
diff --git a/gsk/gskvulkanrender.c b/gsk/gskvulkanrender.c
index 2cf99ac..571ed29 100644
--- a/gsk/gskvulkanrender.c
+++ b/gsk/gskvulkanrender.c
@@ -10,6 +10,23 @@
#define ORTHO_NEAR_PLANE -10000
#define ORTHO_FAR_PLANE 10000
+struct _GskVulkanRender
+{
+ GskRenderer *renderer;
+ GdkVulkanContext *vulkan;
+
+ graphene_matrix_t mvp;
+ int scale_factor;
+ VkExtent2D size;
+ VkRect2D scissor;
+
+ VkCommandPool command_pool;
+ VkCommandBuffer command_buffer;
+
+ GSList *render_passes;
+ GSList *cleanup_images;
+};
+
static void
gsk_vulkan_render_compute_mvp (GskVulkanRender *self)
{
@@ -95,7 +112,7 @@ gsk_vulkan_render_upload (GskVulkanRender *self)
for (l = self->render_passes; l; l = l->next)
{
- gsk_vulkan_render_pass_upload (l->data, self);
+ gsk_vulkan_render_pass_upload (l->data, self, self->command_buffer);
}
}
@@ -219,7 +236,7 @@ gsk_vulkan_render_draw (GskVulkanRender *self,
for (l = self->render_passes; l; l = l->next)
{
- gsk_vulkan_render_pass_draw (l->data, self);
+ gsk_vulkan_render_pass_draw (l->data, self, self->command_buffer);
}
vkCmdEndRenderPass (self->command_buffer);
@@ -275,3 +292,9 @@ gsk_vulkan_render_free (GskVulkanRender *self)
g_slice_free (GskVulkanRender, self);
}
+
+GskRenderer *
+gsk_vulkan_render_get_renderer (GskVulkanRender *self)
+{
+ return self->renderer;
+}
diff --git a/gsk/gskvulkanrenderpass.c b/gsk/gskvulkanrenderpass.c
index 373bc6c..731498b 100644
--- a/gsk/gskvulkanrenderpass.c
+++ b/gsk/gskvulkanrenderpass.c
@@ -64,8 +64,10 @@ gsk_vulkan_render_pass_add_node (GskVulkanRenderPass *self,
}
static void
-gsk_vulkan_render_pass_upload_fallback (GskVulkanRenderOp *op,
- GskVulkanRender *render)
+gsk_vulkan_render_pass_upload_fallback (GskVulkanRenderPass *self,
+ GskVulkanRenderOp *op,
+ GskVulkanRender *render,
+ VkCommandBuffer command_buffer)
{
graphene_rect_t bounds;
GskRenderer *fallback;
@@ -80,7 +82,7 @@ gsk_vulkan_render_pass_upload_fallback (GskVulkanRenderOp *op,
cr = cairo_create (surface);
cairo_translate (cr, bounds.origin.x, bounds.origin.y);
- fallback = gsk_renderer_create_fallback (render->renderer,
+ fallback = gsk_renderer_create_fallback (gsk_vulkan_render_get_renderer (render),
&bounds,
cr);
gsk_renderer_render (fallback, op->node, NULL);
@@ -88,8 +90,8 @@ gsk_vulkan_render_pass_upload_fallback (GskVulkanRenderOp *op,
cairo_destroy (cr);
- op->source = gsk_vulkan_image_new_from_data (render->vulkan,
- render->command_buffer,
+ op->source = gsk_vulkan_image_new_from_data (self->vulkan,
+ command_buffer,
cairo_image_surface_get_data (surface),
cairo_image_surface_get_width (surface),
cairo_image_surface_get_height (surface),
@@ -102,7 +104,8 @@ gsk_vulkan_render_pass_upload_fallback (GskVulkanRenderOp *op,
void
gsk_vulkan_render_pass_upload (GskVulkanRenderPass *self,
- GskVulkanRender *render)
+ GskVulkanRender *render,
+ VkCommandBuffer command_buffer)
{
GskVulkanRenderOp *op;
guint i;
@@ -114,7 +117,7 @@ gsk_vulkan_render_pass_upload (GskVulkanRenderPass *self,
switch (op->type)
{
case GSK_VULKAN_OP_FALLBACK:
- gsk_vulkan_render_pass_upload_fallback (op, render);
+ gsk_vulkan_render_pass_upload_fallback (self, op, render, command_buffer);
break;
default:
@@ -217,7 +220,8 @@ gsk_vulkan_render_pass_update_descriptor_sets (GskVulkanRenderPass *self,
void
gsk_vulkan_render_pass_draw (GskVulkanRenderPass *self,
- GskVulkanRender *render)
+ GskVulkanRender *render,
+ VkCommandBuffer command_buffer)
{
GskVulkanRenderOp *op;
guint i;
@@ -226,7 +230,7 @@ gsk_vulkan_render_pass_draw (GskVulkanRenderPass *self,
{
op = &g_array_index (self->render_ops, GskVulkanRenderOp, i);
- vkCmdDraw (render->command_buffer,
+ vkCmdDraw (command_buffer,
op->vertex_count, 1,
op->vertex_offset, 0);
}
diff --git a/gsk/gskvulkanrenderpassprivate.h b/gsk/gskvulkanrenderpassprivate.h
index eb22761..886e7c2 100644
--- a/gsk/gskvulkanrenderpassprivate.h
+++ b/gsk/gskvulkanrenderpassprivate.h
@@ -18,7 +18,8 @@ void gsk_vulkan_render_pass_add_node (GskVulk
GskRenderNode *node);
void gsk_vulkan_render_pass_upload (GskVulkanRenderPass *self,
- GskVulkanRender *render);
+ GskVulkanRender *render,
+ VkCommandBuffer
command_buffer);
gsize gsk_vulkan_render_pass_count_vertices (GskVulkanRenderPass *self);
gsize gsk_vulkan_render_pass_collect_vertices (GskVulkanRenderPass *self,
@@ -30,7 +31,8 @@ void gsk_vulkan_render_pass_update_descriptor_sets (GskVulk
VkDescriptorSet
descriptor_set,
VkSampler sampler);
void gsk_vulkan_render_pass_draw (GskVulkanRenderPass *self,
- GskVulkanRender *render);
+ GskVulkanRender *render,
+ VkCommandBuffer
command_buffer);
G_END_DECLS
diff --git a/gsk/gskvulkanrenderprivate.h b/gsk/gskvulkanrenderprivate.h
index de4dc80..55c454e 100644
--- a/gsk/gskvulkanrenderprivate.h
+++ b/gsk/gskvulkanrenderprivate.h
@@ -12,24 +12,6 @@ G_BEGIN_DECLS
typedef struct _GskVulkanRender GskVulkanRender;
typedef struct _GskVulkanVertex GskVulkanVertex;
-struct _GskVulkanRender
-{
- GskRenderer *renderer;
- GdkVulkanContext *vulkan;
-
- graphene_matrix_t mvp;
- int scale_factor;
- VkExtent2D size;
- VkRect2D scissor;
-
-
- VkCommandPool command_pool;
- VkCommandBuffer command_buffer;
-
- GSList *render_passes;
- GSList *cleanup_images;
-};
-
struct _GskVulkanVertex
{
float x;
@@ -43,6 +25,8 @@ GskVulkanRender * gsk_vulkan_render_new (GskRend
VkCommandPool
command_pool);
void gsk_vulkan_render_free (GskVulkanRender *self);
+GskRenderer * gsk_vulkan_render_get_renderer (GskVulkanRender *self);
+
void gsk_vulkan_render_add_cleanup_image (GskVulkanRender *self,
GskVulkanImage *image);
[
Date Prev][
Date Next] [
Thread Prev][
Thread Next]
[
Thread Index]
[
Date Index]
[
Author Index]