From: Konstantin Seurer Date: Tue, 19 Apr 2022 14:13:28 +0000 (+0200) Subject: radv: Do not discard hits with t=tmax X-Git-Url: http://review.tizen.org/git/?a=commitdiff_plain;h=b3896fa8c7129fa91a181c49c7eb43e99c19f7ad;p=platform%2Fupstream%2Fmesa.git radv: Do not discard hits with t=tmax Fixes dEQP-VK.ray_tracing_pipeline.inside_aabbs.chit.ray_end_tmax_zero.* Signed-off-by: Konstantin Seurer Reviewed-by: Bas Nieuwenhuizen Part-of: --- diff --git a/src/amd/vulkan/radv_nir_lower_ray_queries.c b/src/amd/vulkan/radv_nir_lower_ray_queries.c index 37a214e..b5567de 100644 --- a/src/amd/vulkan/radv_nir_lower_ray_queries.c +++ b/src/amd/vulkan/radv_nir_lower_ray_queries.c @@ -322,7 +322,7 @@ static void lower_rq_generate_intersection(nir_builder *b, nir_ssa_def *index, nir_intrinsic_instr *instr, struct ray_query_vars *vars) { - nir_push_if(b, nir_iand(b, nir_flt(b, instr->src[1].ssa, rq_load_var(b, index, vars->closest.t)), + nir_push_if(b, nir_iand(b, nir_fge(b, rq_load_var(b, index, vars->closest.t), instr->src[1].ssa), nir_fge(b, instr->src[1].ssa, rq_load_var(b, index, vars->tmin)))); { copy_candidate_to_closest(b, index, vars); @@ -538,7 +538,7 @@ insert_traversal_triangle_case(struct radv_device *device, nir_builder *b, nir_s 0))); nir_push_if(b, nir_iand(b, - nir_iand(b, nir_flt(b, dist, rq_load_var(b, index, vars->closest.t)), + nir_iand(b, nir_fge(b, rq_load_var(b, index, vars->closest.t), dist), nir_fge(b, dist, rq_load_var(b, index, vars->tmin))), not_cull)); { @@ -635,7 +635,7 @@ insert_traversal_aabb_case(struct radv_device *device, nir_builder *b, nir_ssa_d nir_ssa_def *t_max = nir_fmin(b, nir_channel(b, t2_vec, 0), nir_channel(b, t2_vec, 1)); t_max = nir_fmin(b, t_max, nir_channel(b, t2_vec, 2)); - nir_push_if(b, nir_iand(b, nir_flt(b, t_min, rq_load_var(b, index, vars->closest.t)), + nir_push_if(b, nir_iand(b, nir_fge(b, rq_load_var(b, index, vars->closest.t), t_min), nir_fge(b, t_max, rq_load_var(b, index, vars->tmin)))); { rq_store_var(b, index, vars->candidate.t, diff --git a/src/amd/vulkan/radv_pipeline_rt.c b/src/amd/vulkan/radv_pipeline_rt.c index b550f7e..07a4106 100644 --- a/src/amd/vulkan/radv_pipeline_rt.c +++ b/src/amd/vulkan/radv_pipeline_rt.c @@ -642,7 +642,7 @@ lower_rt_instructions(nir_shader *shader, struct rt_variables *vars, unsigned ca &b_shader, nir_iand( &b_shader, - nir_flt(&b_shader, intr->src[0].ssa, nir_load_var(&b_shader, vars->tmax)), + nir_fge(&b_shader, nir_load_var(&b_shader, vars->tmax), intr->src[0].ssa), nir_fge(&b_shader, intr->src[0].ssa, nir_load_var(&b_shader, vars->tmin)))); { nir_store_var(&b_shader, vars->ahit_status, nir_imm_int(&b_shader, 0), 1); @@ -1112,7 +1112,7 @@ insert_traversal_triangle_case(struct radv_device *device, 0))); nir_push_if(b, nir_iand(b, - nir_iand(b, nir_flt(b, dist, nir_load_var(b, vars->tmax)), + nir_iand(b, nir_fge(b, nir_load_var(b, vars->tmax), dist), nir_fge(b, dist, nir_load_var(b, vars->tmin))), not_cull)); { @@ -1319,7 +1319,7 @@ insert_traversal_aabb_case(struct radv_device *device, nir_ssa_def *t_max = nir_fmin(b, nir_channel(b, t2_vec, 0), nir_channel(b, t2_vec, 1)); t_max = nir_fmin(b, t_max, nir_channel(b, t2_vec, 2)); - nir_push_if(b, nir_iand(b, nir_flt(b, t_min, nir_load_var(b, vars->tmax)), + nir_push_if(b, nir_iand(b, nir_fge(b, nir_load_var(b, vars->tmax), t_min), nir_fge(b, t_max, nir_load_var(b, vars->tmin)))); { nir_store_var(b, vars->ahit_status, nir_imm_int(b, 0), 1);