Commit 80db331c authored by Karol Herbst's avatar Karol Herbst 🐧

nir: add const_index parameters to system value builder function

this allows to replace some nir_load_system_value calls with the specific
system value constructor
Reviewed-by: Jason Ekstrand's avatarJason Ekstrand <>
Reviewed-by: Eric Anholt's avatarEric Anholt <>
Signed-off-by: Karol Herbst's avatarKarol Herbst <>
parent 95b513c9
......@@ -55,11 +55,28 @@ nir_load_system_value(nir_builder *build, nir_intrinsic_op op, int index)
return &load->dest.ssa;
def sysval_decl_list(opcode):
res = ''
if opcode.indices:
res += ', unsigned ' + opcode.indices[0].lower()
return res
def sysval_arg_list(opcode):
args = []
if opcode.indices:
return ', '.join(args)
% for name, opcode in filter(lambda v: v[1].sysval, sorted(INTR_OPCODES.items())):
static inline nir_ssa_def *
nir_${name}(nir_builder *build)
nir_${name}(nir_builder *build${sysval_decl_list(opcode)})
return nir_load_system_value(build, nir_intrinsic_${name}, 0);
return nir_load_system_value(build, nir_intrinsic_${name},
% endfor
Markdown is supported
0% or .
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment