summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorMatthias Clasen <mclasen@redhat.com>2017-09-29 22:38:59 -0400
committerMatthias Clasen <mclasen@redhat.com>2017-09-29 23:08:14 -0400
commite382f956f3d31ac48317daecb453ab759fe06ecf (patch)
treec6fe6d517b3854799190445a3829a8b95606da2a
parent5577fde990c7ca36eb64fd179965c4782f33bad8 (diff)
downloadgtk+-e382f956f3d31ac48317daecb453ab759fe06ecf.tar.gz
vulkan: Move sampler creation down
This is in preparation of allowing multiple samplers.
-rw-r--r--gsk/gskvulkanrender.c89
-rw-r--r--gsk/gskvulkanrenderer.c32
-rw-r--r--gsk/gskvulkanrenderprivate.h3
3 files changed, 72 insertions, 52 deletions
diff --git a/gsk/gskvulkanrender.c b/gsk/gskvulkanrender.c
index 0dc0056a08..27ee71ff31 100644
--- a/gsk/gskvulkanrender.c
+++ b/gsk/gskvulkanrender.c
@@ -52,6 +52,8 @@ struct _GskVulkanRender
GskVulkanImage *target;
+ VkSampler sampler;
+
GList *render_passes;
GSList *cleanup_images;
@@ -87,6 +89,9 @@ gsk_vulkan_render_setup (GskVulkanRender *self,
}
}
+static guint desc_set_index_hash (gconstpointer v);
+static gboolean desc_set_index_equal (gconstpointer v1, gconstpointer v2);
+
GskVulkanRender *
gsk_vulkan_render_new (GskRenderer *renderer,
GdkVulkanContext *context)
@@ -99,7 +104,7 @@ gsk_vulkan_render_new (GskRenderer *renderer,
self->vulkan = context;
self->renderer = renderer;
self->framebuffers = g_hash_table_new (g_direct_hash, g_direct_equal);
- self->descriptor_set_indexes = g_hash_table_new (g_direct_hash, g_direct_equal);
+ self->descriptor_set_indexes = g_hash_table_new_full (desc_set_index_hash, desc_set_index_equal, NULL, g_free);
device = gdk_vulkan_context_get_device (self->vulkan);
@@ -184,7 +189,6 @@ gsk_vulkan_render_new (GskRenderer *renderer,
NULL,
&self->descriptor_set_layout);
-
for (guint i = 0; i < 3; i++)
{
VkDescriptorSetLayout layouts[3] = {
@@ -205,6 +209,21 @@ gsk_vulkan_render_new (GskRenderer *renderer,
&self->pipeline_layout[i]);
}
+ GSK_VK_CHECK (vkCreateSampler, device,
+ &(VkSamplerCreateInfo) {
+ .sType = VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO,
+ .magFilter = VK_FILTER_LINEAR,
+ .minFilter = VK_FILTER_LINEAR,
+ .addressModeU = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,
+ .addressModeV = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,
+ .addressModeW = VK_SAMPLER_ADDRESS_MODE_REPEAT,
+ .borderColor = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK,
+ .unnormalizedCoordinates = VK_FALSE,
+ .maxAnisotropy = 1.0,
+ },
+ NULL,
+ &self->sampler);
+
self->uploader = gsk_vulkan_uploader_new (self->vulkan, self->command_pool);
#ifdef G_ENABLE_DEBUG
@@ -424,30 +443,56 @@ gsk_vulkan_render_get_descriptor_set (GskVulkanRender *self,
return self->descriptor_sets[id];
}
+typedef struct {
+ gsize index;
+ GskVulkanImage *image;
+} HashDescriptorSetIndexEntry;
+
+static guint
+desc_set_index_hash (gconstpointer v)
+{
+ const HashDescriptorSetIndexEntry *e = v;
+
+ return GPOINTER_TO_UINT (e->image);
+}
+
+static gboolean
+desc_set_index_equal (gconstpointer v1, gconstpointer v2)
+{
+ const HashDescriptorSetIndexEntry *e1 = v1;
+ const HashDescriptorSetIndexEntry *e2 = v2;
+
+ return e1->image == e2->image;
+}
+
gsize
gsk_vulkan_render_reserve_descriptor_set (GskVulkanRender *self,
GskVulkanImage *source)
{
- gpointer id_plus_one;
+ HashDescriptorSetIndexEntry lookup;
+ HashDescriptorSetIndexEntry *entry;
g_assert (source != NULL);
- id_plus_one = g_hash_table_lookup (self->descriptor_set_indexes, source);
- if (id_plus_one)
- return GPOINTER_TO_SIZE (id_plus_one) - 1;
+ lookup.image = source;
- id_plus_one = GSIZE_TO_POINTER (g_hash_table_size (self->descriptor_set_indexes) + 1);
- g_hash_table_insert (self->descriptor_set_indexes, source, id_plus_one);
-
- return GPOINTER_TO_SIZE (id_plus_one) - 1;
+ entry = g_hash_table_lookup (self->descriptor_set_indexes, &lookup);
+ if (entry)
+ return entry->index;
+
+ entry = g_new (HashDescriptorSetIndexEntry, 1);
+ entry->image = source;
+ entry->index = g_hash_table_size (self->descriptor_set_indexes);
+ g_hash_table_add (self->descriptor_set_indexes, entry);
+
+ return entry->index;
}
static void
-gsk_vulkan_render_prepare_descriptor_sets (GskVulkanRender *self,
- VkSampler sampler)
+gsk_vulkan_render_prepare_descriptor_sets (GskVulkanRender *self)
{
GHashTableIter iter;
- gpointer key, value;
+ gpointer key;
VkDevice device;
GList *l;
guint i, needed_sets;
@@ -513,10 +558,11 @@ gsk_vulkan_render_prepare_descriptor_sets (GskVulkanRender *self,
self->descriptor_sets);
g_hash_table_iter_init (&iter, self->descriptor_set_indexes);
- while (g_hash_table_iter_next (&iter, &key, &value))
+ while (g_hash_table_iter_next (&iter, &key, NULL))
{
- GskVulkanImage *image = key;
- gsize id = GPOINTER_TO_SIZE (value) - 1;
+ HashDescriptorSetIndexEntry *entry = key;
+ GskVulkanImage *image = entry->image;
+ gsize id = entry->index;
vkUpdateDescriptorSets (device,
1,
@@ -529,7 +575,7 @@ gsk_vulkan_render_prepare_descriptor_sets (GskVulkanRender *self,
.descriptorCount = 1,
.descriptorType = VK_DESCRIPTOR_TYPE_COMBINED_IMAGE_SAMPLER,
.pImageInfo = &(VkDescriptorImageInfo) {
- .sampler = sampler,
+ .sampler = self->sampler,
.imageView = gsk_vulkan_image_get_image_view (image),
.imageLayout = VK_IMAGE_LAYOUT_SHADER_READ_ONLY_OPTIMAL
}
@@ -540,8 +586,7 @@ gsk_vulkan_render_prepare_descriptor_sets (GskVulkanRender *self,
}
void
-gsk_vulkan_render_draw (GskVulkanRender *self,
- VkSampler sampler)
+gsk_vulkan_render_draw (GskVulkanRender *self)
{
GList *l;
@@ -550,7 +595,7 @@ gsk_vulkan_render_draw (GskVulkanRender *self,
gsk_profiler_timer_begin (gsk_renderer_get_profiler (self->renderer), self->gpu_time_timer);
#endif
- gsk_vulkan_render_prepare_descriptor_sets (self, sampler);
+ gsk_vulkan_render_prepare_descriptor_sets (self);
for (l = self->render_passes; l; l = l->next)
{
@@ -690,6 +735,10 @@ gsk_vulkan_render_free (GskVulkanRender *self)
self->fence,
NULL);
+ vkDestroySampler (device,
+ self->sampler,
+ NULL);
+
gsk_vulkan_command_pool_free (self->command_pool);
g_slice_free (GskVulkanRender, self);
diff --git a/gsk/gskvulkanrenderer.c b/gsk/gskvulkanrenderer.c
index 20c204f8dd..a0e79ab53d 100644
--- a/gsk/gskvulkanrenderer.c
+++ b/gsk/gskvulkanrenderer.c
@@ -45,8 +45,6 @@ struct _GskVulkanRenderer
guint n_targets;
GskVulkanImage **targets;
- VkSampler sampler;
-
GskVulkanRender *render;
GSList *textures;
@@ -114,29 +112,11 @@ gsk_vulkan_renderer_realize (GskRenderer *renderer,
GError **error)
{
GskVulkanRenderer *self = GSK_VULKAN_RENDERER (renderer);
- VkDevice device;
self->vulkan = gdk_window_create_vulkan_context (window, error);
if (self->vulkan == NULL)
return FALSE;
- device = gdk_vulkan_context_get_device (self->vulkan);
-
- GSK_VK_CHECK (vkCreateSampler, device,
- &(VkSamplerCreateInfo) {
- .sType = VK_STRUCTURE_TYPE_SAMPLER_CREATE_INFO,
- .magFilter = VK_FILTER_LINEAR,
- .minFilter = VK_FILTER_LINEAR,
- .addressModeU = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,
- .addressModeV = VK_SAMPLER_ADDRESS_MODE_CLAMP_TO_BORDER,
- .addressModeW = VK_SAMPLER_ADDRESS_MODE_REPEAT,
- .borderColor = VK_BORDER_COLOR_FLOAT_TRANSPARENT_BLACK,
- .unnormalizedCoordinates = VK_FALSE,
- .maxAnisotropy = 1.0,
- },
- NULL,
- &self->sampler);
-
g_signal_connect (self->vulkan,
"images-updated",
G_CALLBACK (gsk_vulkan_renderer_update_images_cb),
@@ -154,7 +134,6 @@ static void
gsk_vulkan_renderer_unrealize (GskRenderer *renderer)
{
GskVulkanRenderer *self = GSK_VULKAN_RENDERER (renderer);
- VkDevice device;
GSList *l;
g_clear_object (&self->glyph_cache);
@@ -170,18 +149,11 @@ gsk_vulkan_renderer_unrealize (GskRenderer *renderer)
g_clear_pointer (&self->render, gsk_vulkan_render_free);
- device = gdk_vulkan_context_get_device (self->vulkan);
-
gsk_vulkan_renderer_free_targets (self);
g_signal_handlers_disconnect_by_func(self->vulkan,
gsk_vulkan_renderer_update_images_cb,
self);
- vkDestroySampler (device,
- self->sampler,
- NULL);
- self->sampler = VK_NULL_HANDLE;
-
g_clear_object (&self->vulkan);
}
@@ -218,7 +190,7 @@ gsk_vulkan_renderer_render_texture (GskRenderer *renderer,
gsk_vulkan_render_upload (render);
- gsk_vulkan_render_draw (render, self->sampler);
+ gsk_vulkan_render_draw (render);
texture = gsk_vulkan_render_download_target (render);
@@ -261,7 +233,7 @@ gsk_vulkan_renderer_render (GskRenderer *renderer,
gsk_vulkan_render_upload (render);
- gsk_vulkan_render_draw (render, self->sampler);
+ gsk_vulkan_render_draw (render);
#ifdef G_ENABLE_DEBUG
gsk_profiler_counter_inc (profiler, self->profile_counters.frames);
diff --git a/gsk/gskvulkanrenderprivate.h b/gsk/gskvulkanrenderprivate.h
index c7647632d5..553699b46e 100644
--- a/gsk/gskvulkanrenderprivate.h
+++ b/gsk/gskvulkanrenderprivate.h
@@ -85,8 +85,7 @@ VkDescriptorSet gsk_vulkan_render_get_descriptor_set (GskVulk
gsize id);
gsize gsk_vulkan_render_reserve_descriptor_set (GskVulkanRender *self,
GskVulkanImage *source);
-void gsk_vulkan_render_draw (GskVulkanRender *self,
- VkSampler sampler);
+void gsk_vulkan_render_draw (GskVulkanRender *self);
void gsk_vulkan_render_submit (GskVulkanRender *self);