return epilog_entry->data;
}
+uint32_t
+radv_hash_tcs_epilog(const void *key_)
+{
+ const struct radv_tcs_epilog_key *key = key_;
+ return _mesa_hash_data(key, sizeof(*key));
+}
+
+bool
+radv_cmp_tcs_epilog(const void *a_, const void *b_)
+{
+ const struct radv_tcs_epilog_key *a = a_;
+ const struct radv_tcs_epilog_key *b = b_;
+ return memcmp(a, b, sizeof(*a)) == 0;
+}
+
static void
radv_emit_msaa_state(struct radv_cmd_buffer *cmd_buffer)
{
}
}
+static VkResult
+radv_device_init_tcs_epilogs(struct radv_device *device)
+{
+ u_rwlock_init(&device->tcs_epilogs_lock);
+
+ device->tcs_epilogs = _mesa_hash_table_create(NULL, &radv_hash_tcs_epilog, &radv_cmp_tcs_epilog);
+ if (!device->tcs_epilogs)
+ return vk_error(device->physical_device->instance, VK_ERROR_OUT_OF_HOST_MEMORY);
+
+ return VK_SUCCESS;
+}
+
+static void
+radv_device_finish_tcs_epilogs(struct radv_device *device)
+{
+ if (device->tcs_epilogs) {
+ hash_table_foreach (device->tcs_epilogs, entry) {
+ free((void *)entry->key);
+ radv_shader_part_unref(device, entry->data);
+ }
+ _mesa_hash_table_destroy(device->tcs_epilogs, NULL);
+ }
+}
+
VkResult
radv_device_init_vrs_state(struct radv_device *device)
{
bool attachment_vrs_enabled = false;
bool image_float32_atomics = false;
bool vs_prologs = false;
+ UNUSED bool tcs_epilogs = false; /* TODO: Enable for shader object */
bool ps_epilogs = false;
bool global_bo_list = false;
bool image_2d_view_of_3d = false;
goto fail;
}
+ if (tcs_epilogs) {
+ result = radv_device_init_tcs_epilogs(device);
+ if (result != VK_SUCCESS)
+ goto fail;
+ }
+
if (ps_epilogs) {
result = radv_device_init_ps_epilogs(device);
if (result != VK_SUCCESS)
radv_device_finish_notifier(device);
radv_device_finish_vs_prologs(device);
+ radv_device_finish_tcs_epilogs(device);
radv_device_finish_ps_epilogs(device);
radv_device_finish_border_color(device);
radv_device_finish_notifier(device);
radv_device_finish_vs_prologs(device);
+ radv_device_finish_tcs_epilogs(device);
radv_device_finish_ps_epilogs(device);
radv_device_finish_border_color(device);
radv_device_finish_vrs_image(device);
struct u_rwlock ps_epilogs_lock;
struct hash_table *ps_epilogs;
+ /* TCS epilogs */
+ struct u_rwlock tcs_epilogs_lock;
+ struct hash_table *tcs_epilogs;
+
simple_mtx_t trace_mtx;
/* Whether per-vertex VRS is forced. */
const struct radv_ps_epilog_state *state,
bool disable_mrt_compaction);
+uint32_t radv_hash_tcs_epilog(const void *key_);
+bool radv_cmp_tcs_epilog(const void *a_, const void *b_);
+
bool radv_needs_null_export_workaround(const struct radv_device *device, const struct radv_shader *ps,
unsigned custom_blend_mode);