radv: track if subpasses have color attachments
authorSamuel Pitoiset <samuel.pitoiset@gmail.com>
Tue, 29 Jan 2019 21:18:58 +0000 (22:18 +0100)
committerSamuel Pitoiset <samuel.pitoiset@gmail.com>
Mon, 4 Feb 2019 12:19:14 +0000 (13:19 +0100)
Signed-off-by: Samuel Pitoiset <samuel.pitoiset@gmail.com>
Reviewed-by: Bas Nieuwenhuizen <bas@basnieuwenhuizen.nl>
src/amd/vulkan/radv_pass.c
src/amd/vulkan/radv_pipeline.c
src/amd/vulkan/radv_private.h

index b5b06b75b927a895e9cc106771b559ff84e52de4..4d9fb0bf7dfff7cb0acd4dfca9aaba7ea34fd6cc 100644 (file)
@@ -81,12 +81,15 @@ radv_render_pass_compile(struct radv_render_pass *pass)
                        pass_att->last_subpass_idx = i;
                }
 
+               subpass->has_color_att = false;
                for (uint32_t j = 0; j < subpass->color_count; j++) {
                        struct radv_subpass_attachment *subpass_att =
                                &subpass->color_attachments[j];
                        if (subpass_att->attachment == VK_ATTACHMENT_UNUSED)
                                continue;
 
+                       subpass->has_color_att = true;
+
                        struct radv_render_pass_attachment *pass_att =
                                &pass->attachments[subpass_att->attachment];
 
index c96f86bff63e21e6fecff8dde3b846e6af2a3080..ab56a273a2c8d388eb1b870112b31f280221d9ae 100644 (file)
@@ -1375,15 +1375,7 @@ radv_pipeline_init_dynamic_state(struct radv_pipeline *pipeline,
         *    disabled or if the subpass of the render pass the pipeline is
         *    created against does not use any color attachments.
         */
-       bool uses_color_att = false;
-       for (unsigned i = 0; i < subpass->color_count; ++i) {
-               if (subpass->color_attachments[i].attachment != VK_ATTACHMENT_UNUSED) {
-                       uses_color_att = true;
-                       break;
-               }
-       }
-
-       if (uses_color_att && states & RADV_DYNAMIC_BLEND_CONSTANTS) {
+       if (subpass->has_color_att && states & RADV_DYNAMIC_BLEND_CONSTANTS) {
                assert(pCreateInfo->pColorBlendState);
                typed_memcpy(dynamic->blend_constants,
                             pCreateInfo->pColorBlendState->blendConstants, 4);
index 3d1782b559d2cfdbd928bd3264394e228e1c5e48..d4a9e9f0e9553f004e4db13320d9ab067d0938fc 100644 (file)
@@ -1828,6 +1828,9 @@ struct radv_subpass {
        /** Subpass has at least one resolve attachment */
        bool                                         has_resolve;
 
+       /** Subpass has at least one color attachment */
+       bool                                         has_color_att;
+
        struct radv_subpass_barrier                  start_barrier;
 
        uint32_t                                     view_mask;