agx: Implement load_helper_invocation
Passes dEQP-GLES31.functional.shaders.helper_invocation.* Signed-off-by: Alyssa Rosenzweig <alyssa@rosenzweig.io> Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/21265>
This commit is contained in:

committed by
Marge Bot

parent
6214c9921a
commit
e785ae6125
@@ -763,6 +763,14 @@ agx_emit_intrinsic(agx_builder *b, nir_intrinsic_instr *instr)
|
|||||||
case nir_intrinsic_load_back_face_agx:
|
case nir_intrinsic_load_back_face_agx:
|
||||||
return agx_get_sr_to(b, dst, AGX_SR_BACKFACING);
|
return agx_get_sr_to(b, dst, AGX_SR_BACKFACING);
|
||||||
|
|
||||||
|
case nir_intrinsic_load_helper_invocation:
|
||||||
|
/* Compare special register to zero. We could lower this in NIR (letting
|
||||||
|
* us fold in an inot) but meh?
|
||||||
|
*/
|
||||||
|
return agx_icmpsel_to(b, dst, agx_get_sr(b, 32, AGX_SR_IS_ACTIVE_THREAD),
|
||||||
|
agx_zero(), agx_immediate(1), agx_zero(),
|
||||||
|
AGX_ICOND_UEQ);
|
||||||
|
|
||||||
case nir_intrinsic_load_vertex_id:
|
case nir_intrinsic_load_vertex_id:
|
||||||
return agx_mov_to(b, dst, agx_abs(agx_vertex_id(b)));
|
return agx_mov_to(b, dst, agx_abs(agx_vertex_id(b)));
|
||||||
|
|
||||||
|
@@ -138,6 +138,7 @@ SR = enum("sr", {
|
|||||||
56: 'active_thread_index_in_quad',
|
56: 'active_thread_index_in_quad',
|
||||||
58: 'active_thread_index_in_subgroup',
|
58: 'active_thread_index_in_subgroup',
|
||||||
62: 'backfacing',
|
62: 'backfacing',
|
||||||
|
63: 'is_active_thread',
|
||||||
80: 'thread_position_in_grid.x',
|
80: 'thread_position_in_grid.x',
|
||||||
81: 'thread_position_in_grid.y',
|
81: 'thread_position_in_grid.y',
|
||||||
82: 'thread_position_in_grid.z',
|
82: 'thread_position_in_grid.z',
|
||||||
|
Reference in New Issue
Block a user