+<%
+def sysval_decl_list(opcode):
+ res = ''
+ if opcode.indices:
+ res += ', unsigned ' + opcode.indices[0].lower()
+ if opcode.dest_components == 0:
+ res += ', unsigned num_components'
+ if len(opcode.bit_sizes) != 1:
+ res += ', unsigned bit_size'
+ return res
+
+def sysval_arg_list(opcode):
+ args = []
+ if opcode.indices:
+ args.append(opcode.indices[0].lower())
+ else:
+ args.append('0')
+
+ if opcode.dest_components == 0:
+ args.append('num_components')
+ else:
+ args.append(str(opcode.dest_components))
+
+ if len(opcode.bit_sizes) == 1:
+ bit_size = opcode.bit_sizes[0]
+ args.append(str(bit_size))
+ else:
+ args.append('bit_size')
+
+ return ', '.join(args)
+%>
+
+% for name, opcode in filter(lambda v: v[1].sysval, sorted(INTR_OPCODES.items())):
+<% assert len(opcode.bit_sizes) > 0 %>