mesa/src/imagination/pco/pco_map.py
Simon Perretta 99c8d88be1 pco: add encodings and mappings for smp integer and array flags
Acked-by: Frank Binns <frank.binns@imgtec.com>
Signed-off-by: Simon Perretta <simon.perretta@imgtec.com>
Part-of: <https://gitlab.freedesktop.org/mesa/mesa/-/merge_requests/40139>
2026-03-05 15:33:10 +00:00

3726 lines
96 KiB
Python

# Copyright © 2024 Imagination Technologies Ltd.
# SPDX-License-Identifier: MIT
from pco_isa import *
from pco_ops import *
REF_MAP = enum_type('ref_map', [
('_', '_'),
('s0', 's0'),
('s1', 's1'),
('s2', 's2'),
('s3', 's3'),
('s4', 's4'),
('s5', 's5'),
('w0', 'w0'),
('w1', 'w1'),
('is0', 'is0'),
('is1', 'is1'),
('is2', 'is2'),
('is3', 'is3'),
('is4', 'is4'),
('is5', 'is5'),
('ft0', 'ft0'),
('ft1', 'ft1'),
('ft1_invert', '~ft1'),
('ft2', 'ft2'),
('fte', 'fte'),
('ft3', 'ft3'),
('ft4', 'ft4'),
('ft5', 'ft5'),
('ftt', 'ftt'),
('p0', 'p0'),
('pe', 'pe'),
('imm', 'imm'),
('drc', 'drc'),
('temp', 'temp'),
('coeff', 'coeff'),
])
# Enum mappings.
class EnumMap(object):
def __init__(self, name, type_from, type_to, mappings, both_bitsets, pass_zero_val):
self.name = name
self.type_from = type_from
self.type_to = type_to
self.mappings = mappings
self.both_bitsets = both_bitsets
self.pass_zero_val = pass_zero_val
enum_maps = {}
def enum_map(enum_from, enum_to, mappings, pass_zero=None):
# Only allow passing zero through if this is a bitset.
assert pass_zero is None or enum_from.enum.is_bitset
key = (enum_from, enum_to)
assert key not in enum_maps.keys(), f'Duplicate enum mapping for "{enum_from.tname}" to "{enum_to.tname}".'
assert enum_from.base_type == BaseType.enum
assert enum_to.base_type == BaseType.enum
# Ensure the validity of the enum_from elements.
assert set([from_elem for from_elem, to_elem in mappings]).issubset(set(enum_from.enum.elems.keys())), f'Invalid enum_from spec in enum mapping for "{enum_from.tname}" to "{enum_to.tname}".'
# Ensure the validity of the enum_to elements.
assert set([to_elem for from_elem, to_elem in mappings]).issubset(set(enum_to.enum.elems.keys())), f'Invalid enum_to spec in enum mapping for "{enum_from.tname}" to "{enum_to.tname}".'
_mappings = []
for elem_from, elem_to in mappings:
_mappings.append((enum_from.enum.elems[elem_from].cname, enum_to.enum.elems[elem_to].cname))
pass_zero_val = None
if pass_zero is not None:
if isinstance(pass_zero, int):
pass_zero_val = str(pass_zero)
elif isinstance(pass_zero, str):
assert pass_zero in enum_to.enum.elems.keys()
pass_zero_val = enum_to.enum.elems[pass_zero].cname
elif isinstance(pass_zero, list):
assert all(elem_to in enum_to.enum.elems.keys() for elem_to in pass_zero)
pass_zero_val = ' | '.join([enum_to.enum.elems[elem_to].cname for elem_to in pass_zero])
else:
assert False
name = f'{prefix}_map_{enum_from.tname}_to_{enum_to.tname}'
both_bitsets = enum_from.enum.is_bitset and enum_to.enum.is_bitset
enum_maps[key] = EnumMap(name, enum_from.name, enum_to.name, _mappings, both_bitsets, pass_zero_val)
enum_map(OM_EXEC_CND.t, F_CC, [
('e1_zx', 'e1_zx'),
('e1_z1', 'e1_z1'),
('ex_zx', 'ex_zx'),
('e1_z0', 'e1_z0'),
])
enum_map(REG_CLASS, F_REGBANK, [
('temp', 'temp'),
('vtxin', 'vtxin'),
('coeff', 'coeff'),
('shared', 'shared'),
('index', 'idx0'),
('spec', 'special'),
('intern', 'special'),
('const', 'special'),
('pixout', 'special'),
('global', 'special'),
('slot', 'special'),
])
enum_map(REG_CLASS, F_IDXBANK, [
('temp', 'temp'),
('vtxin', 'vtxin'),
('coeff', 'coeff'),
('shared', 'shared'),
('index', 'idx'),
('pixout', 'pixout'),
])
enum_map(IO, F_IS0_SEL, [
('s0', 's0'),
('s1', 's1'),
('s2', 's2'),
('s3', 's3'),
('s4', 's4'),
('s5', 's5'),
])
enum_map(IO, F_IS1_SEL, [
('ft0', 'ft0'),
('fte', 'fte'),
])
enum_map(IO, F_IS2_SEL, [
('ft1', 'ft1'),
('fte', 'fte'),
])
enum_map(IO, F_IS3_SEL, [
('ft0', 'ft0'),
('ft1', 'ft1'),
('fte', 'fte'),
])
enum_map(IO, F_IS4_SEL, [
('ft0', 'ft0'),
('ft1', 'ft1'),
('ft2', 'ft2'),
('fte', 'fte'),
])
enum_map(IO, F_IS5_SEL, [
('ft0', 'ft0'),
('ft1', 'ft1'),
('ft2', 'ft2'),
('fte', 'fte'),
])
enum_map(OM_ITR_MODE.t, F_ITER_MODE, [
('pixel', 'pixel'),
('sample', 'sample'),
('centroid', 'centroid'),
])
enum_map(OM_PCK_FMT.t, F_PCK_FORMAT, [
('u8888', 'u8888'),
('s8888', 's8888'),
('o8888', 'o8888'),
('u1616', 'u1616'),
('s1616', 's1616'),
('o1616', 'o1616'),
('u32', 'u32'),
('s32', 's32'),
('u1010102', 'u1010102'),
('s1010102', 's1010102'),
('u111110', 'u111110'),
('s111110', 's111110'),
('f111110', 'f111110'),
('f16f16', 'f16f16'),
('f32', 'f32'),
('cov', 'cov'),
('u565u565', 'u565u565'),
('d24s8', 'd24s8'),
('s8d24', 's8d24'),
('f32_mask', 'f32_mask'),
('2f10f10f10', '2f10f10f10'),
('s8888ogl', 's8888ogl'),
('s1616ogl', 's1616ogl'),
('zero', 'zero'),
('one', 'one'),
])
enum_map(OM_SCHED.t, F_SCHED_CTRL, [
('none', 'none'),
('swap', 'swap'),
('wdf', 'wdf'),
])
enum_map(OM_MCU_CACHE_MODE_LD.t, F_CACHEMODE_LD, [
('normal', 'normal'),
('bypass', 'bypass'),
('force_line_fill', 'force_line_fill'),
])
enum_map(OM_MCU_CACHE_MODE_ST.t, F_CACHEMODE_ST, [
('write_through', 'write_through'),
('write_back', 'write_back'),
('lazy_write_back', 'write_back_lazy'),
])
enum_map(OM_TST_OP_MAIN.t, F_TST_OP, [
('zero', 'z'),
('gzero', 'gz'),
('gezero', 'gez'),
('carry', 'c'),
('equal', 'e'),
('greater', 'g'),
('gequal', 'ge'),
('notequal', 'ne'),
('less', 'l'),
('lequal', 'le'),
])
enum_map(OM_TST_TYPE_MAIN.t, F_TST_TYPE, [
('f32', 'f32'),
('u16', 'u16'),
('s16', 's16'),
('u8', 'u8'),
('s8', 's8'),
('u32', 'u32'),
('s32', 's32'),
])
enum_map(OM_LOGIOP.t, F_LOGICAL_OP, [
('or', 'or'),
('and', 'and'),
('xor', 'xor'),
('nor', 'nor'),
('nand', 'nand'),
('xnor', 'xnor'),
])
enum_map(OM_SHIFTOP.t, F_SHIFT2_OP, [
('lsl', 'lsl'),
('shr', 'shr'),
('rol', 'rol'),
('cps', 'cps'),
('asr_twb', 'asr_twb'),
('asr_pwb', 'asr_pwb'),
('asr_mtb', 'asr_mtb'),
('asr_ftb', 'asr_ftb'),
])
enum_map(RM_ELEM.t, F_UPCK_ELEM, [
('e0', 'e0'),
('e1', 'e1'),
('e2', 'e2'),
('e3', 'e3'),
], pass_zero=0)
enum_map(RM_ELEM.t, F_MASKW0, [
('e0', 'e0'),
('e1', 'e1'),
('e2', 'e2'),
('e3', 'e3'),
], pass_zero=['e0', 'e1', 'e2', 'e3'])
enum_map(OM_CND.t, F_PCND, [
('always', 'always'),
('p0_true', 'p0_true'),
('never', 'never'),
('p0_false', 'p0_false'),
])
enum_map(OM_BRANCH_CND.t, F_BPRED, [
('exec_cond', 'cc'),
('allinst', 'allp'),
('anyinst', 'anyp'),
])
enum_map(OM_ATOM_OP.t, F_ATOMIC_OP, [
('add', 'add'),
('sub', 'sub'),
('xchg', 'xchg'),
('umin', 'umin'),
('imin', 'imin'),
('umax', 'umax'),
('imax', 'imax'),
('and', 'and'),
('or', 'or'),
('xor', 'xor'),
])
enum_map(OM_FRED_TYPE.t, F_RED_TYPE, [
('sin', 'sin'),
('cos', 'cos'),
])
enum_map(OM_FRED_PART.t, F_RED_PART, [
('a', 'a'),
('b', 'b'),
])
enum_map(OM_DIM.t, F_DMN, [
('1d', '1d'),
('2d', '2d'),
('3d', '3d'),
])
enum_map(OM_LOD_MODE.t, F_LODM, [
('normal', 'normal'),
('bias', 'bias'),
('replace', 'replace'),
('gradients', 'gradients'),
])
enum_map(OM_SB_MODE.t, F_SBMODE, [
('none', 'none'),
('rawdata', 'rawdata'),
('coeffs', 'coeffs'),
('both', 'both'),
])
enum_map(OM_SCHEDSWAP.t, F_SCHED_CTRL, [
('none', 'none'),
('swap', 'swap'),
])
enum_map(OM_MUTEX_OP.t, F_LR, [
('release', 'release'),
('release_sleep', 'release_sleep'),
('release_wakeup', 'release_wakeup'),
('lock', 'lock'),
])
enum_map(OM_SAVMSK_MODE.t, F_MSK_MODE, [
('vm', 'vm'),
('icm', 'icm'),
('icmoc', 'icmoc'),
('icmi', 'icmi'),
('caxy', 'caxy'),
])
class OpRef(object):
def __init__(self, ref_type, index, mods):
self.type = ref_type
self.index = index
self.mods = mods
def SRC(index, mods=[]):
return OpRef('src', index, mods)
def DEST(index, mods=[]):
return OpRef('dest', index, mods)
encode_maps = {}
group_maps = {}
# Instruction encoding mapping.
class EncodeMap(object):
def __init__(self, name, cop_name, variants, op_ref_maps):
self.name = name
self.cop_name = cop_name
self.variants = variants
self.op_ref_maps = op_ref_maps
def encode_map(op, encodings, op_ref_maps):
assert op.bname not in encode_maps.keys(), f'Duplicate encode mapping for op "{op.name}".'
encode_variants = []
default_variant = encodings[0]
first_variant = encodings[1] if len(encodings) > 1 else None
for encoding_variant in encodings:
isa_op, isa_op_fields, *_ = encoding_variant
# Ensure we're speccing everything in the op fields.
assert set(isa_op.struct_fields.keys()) == set([field for field, val_spec in isa_op_fields]), f'Invalid field spec in isa op "{isa_op.bsname}" mapping for op "{op.name}".'
variant = isa_op.name.upper()
encode_variant = f'{isa_op.name}_encode({{0}}'
for isa_op_field, val_spec in isa_op_fields:
struct_field = isa_op.struct_fields[isa_op_field]
encode_variant += f', .{isa_op_field} = '
if isinstance(val_spec, bool):
encode_variant += str(val_spec).lower()
elif isinstance(val_spec, int):
encode_variant += str(val_spec)
elif isinstance(val_spec, str):
# Special case
if val_spec == 'target_cf_node':
assert op.has_target_cf_node
encode_variant += f'pco_branch_rel_offset({{1}}->parent_igrp, {{1}}->target_cf_node)'
elif val_spec == 'target_next_igrp':
encode_variant += f'pco_branch_rel_offset_next_igrp({{1}}->parent_igrp)'
else:
assert struct_field.type.base_type == BaseType.enum
enum = struct_field.type.enum
assert enum.parent is None
assert val_spec in enum.elems.keys(), f'Invalid enum element "{val_spec}" in field "{isa_op_field}" in isa op "{isa_op.bsname}" mapping for op "{op.name}".'
encode_variant += enum.elems[val_spec].cname
elif isinstance(val_spec, OpMod):
assert val_spec in op.op_mods, f'Op mod "{val_spec.t.tname}" was specified but not valid in isa op "{isa_op.bsname}" mapping for op "{op.name}".'
if struct_field.type.base_type == BaseType.enum:
enum_map_key = (val_spec.t, struct_field.type)
assert enum_map_key in enum_maps.keys(), f'Op mod enum "{val_spec.t.tname}" was specified but no mapping from enum "{struct_field.type.tname}" was found in mapping for op "{op.name}".'
enum_mapping = enum_maps[enum_map_key]
encode_variant += f'{enum_mapping.name}(pco_instr_get_mod({{1}}, {val_spec.cname}))'
else:
encode_variant += f'pco_instr_get_mod({{1}}, {val_spec.cname})'
elif isinstance(val_spec, tuple):
mod, _origin = val_spec
assert isinstance(_origin, OpRef)
assert not _origin.mods
origin = f'{_origin.type}[{_origin.index}]'
if isinstance(mod, RefMod):
# This is different from op mods, in that enum maps are *optional*.
assert (_origin.type == 'src' and mod in op.src_mods[_origin.index]) or (_origin.type == 'dest' and mod in op.dest_mods[_origin.index])
enum_map_key = (mod.t, struct_field.type)
if struct_field.type.base_type == BaseType.enum and enum_map_key in enum_maps.keys():
enum_mapping = enum_maps[enum_map_key]
encode_variant += f'{enum_mapping.name}({{1}}->{origin}.{mod.t.tname})'
else:
encode_variant += f'{{1}}->{origin}.{mod.t.tname}'
elif isinstance(mod, str):
encode_variant += f'{mod}({{1}}->{origin})'
else:
assert False
elif isinstance(val_spec, dict):
assert len(val_spec) == 1
_bin_op, mod_list = next(iter(val_spec.items()))
# No point doing a binop on a single item.
assert len(mod_list) > 1
# Only op mods supported for now.
assert all(isinstance(mod, OpMod) for mod in mod_list)
assert all(mod in op.op_mods for mod in mod_list)
# Make sure mods are all bools, can't do binops on other types.
assert all(mod.t.base_type == BaseType.bool for mod in mod_list)
if _bin_op == 'or':
bin_op = '||'
elif _bin_op == 'and':
bin_op = '&&'
else:
assert False
encode_variant += f' {bin_op} '.join([f'pco_instr_get_mod({{1}}, {mod.cname})' for mod in mod_list])
else:
assert False, f'Invalid value spec for field "{isa_op_field}" in isa op "{isa_op.bsname}" mapping for op "{op.name}".'
encode_variant += ')'
conds_variant = ''
if encoding_variant != default_variant:
conds_variant = 'if (' if encoding_variant == first_variant else 'else if ('
isa_op_conds = encoding_variant[2]
for i, isa_op_cond in enumerate(isa_op_conds):
if i > 0:
conds_variant += ' && '
if isinstance(isa_op_cond, tuple) and len(isa_op_cond) == 3:
mod, _origin, cond = isa_op_cond
assert isinstance(_origin, OpRef)
assert not _origin.mods
origin = f'{_origin.type}[{_origin.index}]'
assert isinstance(mod, RefMod)
assert (_origin.type == 'src' and mod in op.src_mods[_origin.index]) or (_origin.type == 'dest' and mod in op.dest_mods[_origin.index])
conds_variant += f'{{1}}->{origin}.{mod.t.tname} {cond}'
elif isinstance(isa_op_cond, tuple) and len(isa_op_cond) == 2:
if isinstance(isa_op_cond[0], OpMod):
mod, cond = isa_op_cond
assert mod in op.op_mods
conds_variant += f'pco_instr_get_mod({{1}}, {mod.cname}) {cond}'
elif isinstance(isa_op_cond[0], str):
mod, _origin = isa_op_cond
assert isinstance(_origin, OpRef)
assert not _origin.mods
origin = f'{_origin.type}[{_origin.index}]'
conds_variant += f'{mod}({{1}}->{origin})'
else:
assert False
else:
assert False
conds_variant += ')'
encode_variants.append((variant, encode_variant, conds_variant))
_op_ref_maps = []
for phase, dests, srcs in op_ref_maps:
assert phase in OP_PHASE.enum.elems.keys()
_phase = OP_PHASE.enum.elems[phase].cname
assert len(dests) == op.num_dests
assert all((isinstance(dest, str) and dest in REF_MAP.enum.elems.keys()) or \
(isinstance(dest, list) and _dest in REF_MAP.enum.elems.keys() for _dest in dest) \
for dest in dests)
_dests = []
for dest in dests:
if isinstance(dest, str):
_dests.append(f'(1U << {REF_MAP.enum.elems[dest].cname})')
elif isinstance(dest, list):
_dests.append(' | '.join(f'(1U << {REF_MAP.enum.elems[_dest].cname})' for _dest in dest))
else:
assert False
assert len(srcs) == op.num_srcs
assert all((isinstance(src, str) and src in REF_MAP.enum.elems.keys()) or \
(isinstance(src, list) and _src in REF_MAP.enum.elems.keys() for _src in src) \
for src in srcs)
_srcs = []
for src in srcs:
if isinstance(src, str):
_srcs.append(f'(1U << {REF_MAP.enum.elems[src].cname})')
elif isinstance(src, list):
_srcs.append(' | '.join(f'(1U << {REF_MAP.enum.elems[_src].cname})' for _src in src))
else:
assert False
_op_ref_maps.append((_phase, _dests, _srcs))
name = op.bname
cop_name = op.cname.upper()
encode_maps[name] = EncodeMap(name, cop_name, encode_variants, _op_ref_maps)
# Instruction group mapping.
class GroupMap(object):
def __init__(self, name, cop_name, mapping_sets, dest_intrn_map, src_intrn_map):
self.name = name
self.mapping_sets = mapping_sets
self.cop_name = cop_name
self.dest_intrn_map = dest_intrn_map
self.src_intrn_map = src_intrn_map
def group_map(op, hdr, enc_ops, srcs=[], iss=[], dests=[]):
assert op.bname not in group_maps.keys(), f'Duplicate group mapping for op "{op.name}".'
assert op.op_type != 'hw_direct', f'HW direct op "{op.name}" cannot have a group mapping.'
is_self = len(enc_ops) == 1 and enc_ops[0][1] == op
mapping_sets = []
hdr_variant, hdr_fields = hdr
# Ensure we're speccing everything in the header except length and da (need to be set later).
assert set(hdr_variant.struct_fields.keys()) == set([hdr_field for hdr_field, val_spec in hdr_fields] + ['length', 'da']), f'Invalid field spec in hdr mapping for op "{op.name}".'
# Add alutype setting after the check above, as it's actually a fixed value.
hdr_fields.append(('alutype', hdr_variant.bsname))
# Emit header mappings.
hdr_mappings = []
for hdr_field, val_spec in hdr_fields:
field = hdr_variant.bit_set.fields[hdr_field]
if isinstance(val_spec, bool):
value = str(val_spec).lower()
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {str(val_spec).lower()};')
elif isinstance(val_spec, int):
value = val_spec
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {val_spec};')
elif isinstance(val_spec, str):
assert field.field_type.base_type == BaseType.enum
enum = field.field_type.enum
assert enum.parent is None
assert val_spec in enum.elems.keys(), f'Invalid enum element "{val_spec}" in field "{hdr_field}" in hdr mapping for op "{op.name}".'
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {enum.elems[val_spec].cname};')
elif isinstance(val_spec, OpMod):
assert val_spec in op.op_mods, f'Op mod "{val_spec.t.tname}" was specified but not valid in hdr mapping for op "{op.name}".'
if field.field_type.base_type == BaseType.enum:
enum_map_key = (val_spec.t, field.field_type)
assert enum_map_key in enum_maps.keys(), f'Op mod enum "{val_spec.t.tname}" was specified but no mapping from enum "{field.field_type.tname}" was found in hdr mapping for op "{op.name}".'
enum_mapping = enum_maps[enum_map_key]
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {enum_mapping.name}(pco_instr_get_mod({{}}, {val_spec.cname}));')
else:
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = pco_instr_get_mod({{}}, {val_spec.cname});')
if val_spec.t.unset and is_self:
reset_val = 0 if val_spec.t.nzdefault is None else val_spec.t.nzdefault
hdr_mappings.append(f'pco_instr_set_mod({{1}}, {val_spec.cname}, {reset_val});')
elif isinstance(val_spec, tuple):
mod, _origin = val_spec
assert isinstance(_origin, OpRef)
assert not _origin.mods
origin = f'{_origin.type}[{_origin.index}]'
assert isinstance(mod, str) and isinstance(origin, str)
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {mod}({{}}->{origin});')
elif isinstance(val_spec, list):
assert field.field_type.base_type == BaseType.enum
enum = field.field_type.enum
assert enum.parent is None
assert enum.is_bitset
assert all(elem in enum.elems.keys() for elem in val_spec), f'Invalid enum element "{elem}" in field "{hdr_field}" in hdr mapping for op "{op.name}".'
val = ' | ' .join(enum.elems[elem].cname for elem in val_spec)
hdr_mappings.append(f'{{}}->hdr.{hdr_field} = {val};')
else:
assert False, f'Invalid value spec for field "{hdr_field}" in hdr mapping for op "{op.name}".'
assert bool(hdr_mappings)
mapping_sets.append(hdr_mappings);
# Emit instruction op mappings.
op_mappings = []
if is_self:
assert len(enc_ops[0]) == 2
_phase = enc_ops[0][0]
assert _phase in OP_PHASE.enum.elems.keys()
phase = OP_PHASE.enum.elems[_phase].cname
_enc_op = enc_ops[0][1]
assert _enc_op.bname in encode_maps.keys()
assert phase in [phase_map for phase_map, *_ in encode_maps[_enc_op.bname].op_ref_maps]
op_mappings.append(f'list_del(&{{1}}->link);')
op_mappings.append(f'{{}}->instrs[{phase}] = {{}};')
op_mappings.append(f'{{0}}->instrs[{phase}]->phase = {phase};')
op_mappings.append(f'{{0}}->instrs[{phase}]->parent_igrp = {{0}};')
op_mappings.append(f'ralloc_steal(igrp, {{1}});')
else:
for _phase, enc_op, *_enc_spec in enc_ops:
assert _phase in OP_PHASE.enum.elems.keys()
phase = OP_PHASE.enum.elems[_phase].cname
assert enc_op.bname in encode_maps.keys(), f'Op "{enc_op.name}" used in group mapping for "{op.name}" has no encode mapping defined.'
assert phase in [phase_map for phase_map, *_ in encode_maps[enc_op.bname].op_ref_maps]
enc_dests = _enc_spec[0] if len(_enc_spec) > 0 else []
enc_srcs = _enc_spec[1] if len(_enc_spec) > 1 else []
enc_op_mods = _enc_spec[2] if len(_enc_spec) > 2 else []
enc_mapping = f'{{0}}->instrs[{phase}] = {enc_op.bname}_({{1}}->parent_func'
for _ref in enc_dests + enc_srcs:
if _ref in IO.enum.elems.keys():
io = IO.enum.elems[_ref]
enc_mapping += f', pco_ref_io({io.cname})'
elif isinstance(_ref, OpRef):
origin = f'{{1}}->{_ref.type}[{_ref.index}]'
if _ref.type == 'src':
assert all(mod in enc_op.src_mods[_ref.index] for mod in _ref.mods)
else:
assert all(mod in enc_op.dest_mods[_ref.index] for mod in _ref.mods)
for mod in _ref.mods:
origin = f'pco_ref_{mod.t.tname}({origin})'
enc_mapping += f', {origin}'
elif isinstance(_ref, str):
if _ref == '_':
enc_mapping += ', pco_ref_null()'
else:
enc_mapping += f', {_ref}'
else:
assert False
for op_mod, _val in enc_op_mods:
assert isinstance(op_mod, OpMod)
assert op_mod in enc_op.op_mods
if isinstance(_val, str):
assert op_mod.t.base_type == BaseType.enum
enum = op_mod.t.enum
assert enum.parent is None
assert _val in enum.elems.keys()
val = enum.elems[_val].cname
elif isinstance(_val, bool):
assert op_mod.t.base_type == BaseType.bool
val = str(_val).lower()
elif isinstance(_val, int):
assert op_mod.t.base_type == BaseType.uint
val = str(_val)
elif isinstance(_val, OpMod):
assert op_mod in op.op_mods
val = f'pco_instr_get_mod({{1}}, {_val.cname})'
else:
assert False
enc_mapping += f', .{op_mod.t.tname} = {val}'
enc_mapping += ');'
op_mappings.append(enc_mapping)
op_mappings.append(f'{{0}}->instrs[{phase}]->phase = {phase};')
op_mappings.append(f'{{0}}->instrs[{phase}]->parent_igrp = {{0}};')
op_mappings.append(f'pco_instr_delete({{1}});')
assert bool(op_mappings)
mapping_sets.append(op_mappings);
# Emit source mappings.
src_mappings = []
for src, *_spec in srcs:
if len(_spec) == 2:
(_phase, val_spec), _io = _spec
assert _phase in OP_PHASE.enum.elems.keys()
phase = OP_PHASE.enum.elems[_phase].cname
assert isinstance(val_spec, OpRef)
assert not val_spec.mods
origin = f'{val_spec.type}[{val_spec.index}]'
assert _io in IO.enum.elems.keys()
io = IO.enum.elems[_io].cname
src_mappings.append(f'{{0}}->srcs.{src} = {{0}}->instrs[{phase}]->{origin};')
src_mappings.append(f'{{0}}->instrs[{phase}]->{origin} = pco_ref_io({io});')
src_mappings.append(f'pco_ref_xfer_mods(&{{0}}->instrs[{phase}]->{origin}, &{{0}}->srcs.{src}, true);')
elif len(_spec) == 1:
val = _spec[0]
assert isinstance(val, str)
src_mappings.append(f'{{0}}->srcs.{src} = {val};')
else:
assert False
if bool(src_mappings):
mapping_sets.append(src_mappings);
# Emit iss mappings.
iss_mappings = []
for iss, _io in iss:
if _io in IO.enum.elems.keys():
io = IO.enum.elems[_io].cname
else:
assert isinstance(_io, str)
io = _io
iss_mappings.append(f'{{}}->iss.{iss} = pco_ref_io({io});')
if bool(iss_mappings):
mapping_sets.append(iss_mappings);
# Emit destination mappings.
dest_mappings = []
for dest, (_phase, val_spec), _io in dests:
assert _phase in OP_PHASE.enum.elems.keys()
phase = OP_PHASE.enum.elems[_phase].cname
assert isinstance(val_spec, OpRef)
assert not val_spec.mods
origin = f'{val_spec.type}[{val_spec.index}]'
if _io in IO.enum.elems.keys():
io = IO.enum.elems[_io].cname
else:
assert isinstance(_io, str)
io = _io
dest_mappings.append(f'{{0}}->dests.{dest} = {{0}}->instrs[{phase}]->{origin};')
dest_mappings.append(f'{{0}}->instrs[{phase}]->{origin} = pco_ref_io({io});')
dest_mappings.append(f'pco_ref_xfer_mods(&{{0}}->instrs[{phase}]->{origin}, &{{0}}->dests.{dest}, true);')
if bool(dest_mappings):
mapping_sets.append(dest_mappings);
# Emit variant mappings.
variant_mappings = []
for _phase, enc_op, *_ in enc_ops:
assert _phase in OP_PHASE.enum.elems.keys()
phase = OP_PHASE.enum.elems[_phase].cname
variant_mappings.append(f'{{0}}->variant.instr[{phase}].{hdr_variant.bsname} = {enc_op.bname}_variant({{0}}->instrs[{phase}]);')
assert bool(variant_mappings)
mapping_sets.append(variant_mappings);
# Collect src/dest I/O
dest_intrn_map = []
src_intrn_map = []
for src, *_spec in srcs:
if len(_spec) != 2:
continue
(_phase, origin), _io = _spec
phase = OP_PHASE.enum.elems[_phase].cname
io = IO.enum.elems[_io]
if not io.string.startswith('s'):
continue
val = int(io.string[1:]) + 1
if is_self:
if origin.type == 'dest':
dest_intrn_map.append((origin.index, val))
else:
src_intrn_map.append((origin.index, val))
continue
origin_op = None
for enc_op in enc_ops:
if enc_op[0] != _phase:
continue
origin_op = enc_op
break
assert origin_op is not None
_enc_phase, enc_op, *_enc_spec = enc_op
enc_dests = _enc_spec[0] if len(_enc_spec) > 0 else []
enc_srcs = _enc_spec[1] if len(_enc_spec) > 1 else []
origin = enc_dests[origin.index] if origin.type == 'dest' else enc_srcs[origin.index]
if isinstance(origin, str):
continue
assert isinstance(origin, OpRef)
if origin.type == 'dest':
dest_intrn_map.append((origin.index, val))
else:
src_intrn_map.append((origin.index, val))
name = op.bname
cop_name = op.cname.upper()
group_maps[name] = GroupMap(name, cop_name, mapping_sets, dest_intrn_map, src_intrn_map)
# Encode mappings.
encode_map(O_FADD,
encodings=[
(I_FADD, [
('sat', OM_SAT),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s1abs', (RM_ABS, SRC(1))),
('s0flr', (RM_FLR, SRC(0)))
])
],
op_ref_maps=[
('0', ['ft0'], ['s0', 's1']),
('1', ['ft1'], ['s3', 's4'])
]
)
encode_map(O_FMUL,
encodings=[
(I_FMUL, [
('sat', OM_SAT),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s1abs', (RM_ABS, SRC(1))),
('s0flr', (RM_FLR, SRC(0)))
])
],
op_ref_maps=[
('0', ['ft0'], ['s0', 's1']),
('1', ['ft1'], ['s3', 's4'])
]
)
encode_map(O_FMAD,
encodings=[
(I_FMAD_EXT, [
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s2neg', (RM_NEG, SRC(2))),
('sat', OM_SAT),
('lp', OM_LP),
('s1abs', (RM_ABS, SRC(1))),
('s1neg', (RM_NEG, SRC(1))),
('s2flr', (RM_FLR, SRC(2))),
('s2abs', (RM_ABS, SRC(2)))
]),
(I_FMAD, [
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s2neg', (RM_NEG, SRC(2))),
('sat', OM_SAT)
], [
(OM_LP, '== false'),
(RM_ABS, SRC(1), '== false'),
(RM_NEG, SRC(1), '== false'),
(RM_FLR, SRC(2), '== false'),
(RM_ABS, SRC(2), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0', 's1', 's2']),
('1', ['ft1'], ['s3', 's4', 's5'])
]
)
encode_map(O_FRCP,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'rcp'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'rcp')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0'], ['s0'])]
)
encode_map(O_FRSQ,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'rsq'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'rsq')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0'], ['s0'])]
)
encode_map(O_FLOG,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'log'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'log')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0'], ['s0'])]
)
encode_map(O_FLOGCN,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'logcn'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'logcn')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0'], ['s0'])]
)
encode_map(O_FEXP,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'exp'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'exp')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0'], ['s0'])]
)
encode_map(O_FRED,
encodings=[
(I_FRED, [
('red_part', OM_FRED_PART),
('iter', ('pco_ref_get_imm', SRC(2))),
('red_type', OM_FRED_TYPE),
('pwen', ('!pco_ref_is_null', DEST(2))),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_NEG, SRC(0)))
])
],
op_ref_maps=[('0', [['w0', '_'], ['w1', '_'], ['p0', '_']], ['s0', ['s3', '_'], 'imm'])]
)
encode_map(O_FSINC,
encodings=[
(I_SNGL, [('sngl_op', 'sinc')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[('0', ['w0', 'p0'], ['s0'])]
)
encode_map(O_MBYP,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'byp'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'byp')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0']),
('1', ['ft1'], ['s3'])
]
)
encode_map(O_FDSX,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'dsx'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'dsx')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0']),
('1', ['ft1'], ['s3'])
]
)
encode_map(O_FDSXF,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'dsxf'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'dsx')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0']),
('1', ['ft1'], ['s3'])
]
)
encode_map(O_FDSY,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'dsy'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'dsy')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0']),
('1', ['ft1'], ['s3'])
]
)
encode_map(O_FDSYF,
encodings=[
(I_SNGL_EXT, [
('sngl_op', 'dsyf'),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0)))
]),
(I_SNGL, [('sngl_op', 'dsy')], [
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false')
])
],
op_ref_maps=[
('0', ['ft0'], ['s0']),
('1', ['ft1'], ['s3'])
]
)
encode_map(O_PCK,
encodings=[
(I_PCK, [
('prog', False),
('rtz', OM_ROUNDZERO),
('scale', OM_SCALE),
('pck_format', OM_PCK_FMT)
])
],
op_ref_maps=[('2_pck', ['ft2'], [['is3', '_']])]
)
encode_map(O_PCK_PROG,
encodings=[
(I_PCK, [
('prog', True),
('rtz', OM_ROUNDZERO),
('scale', OM_SCALE),
('pck_format', 0)
])
],
op_ref_maps=[('2_pck', ['ft2'], ['is3', 'fte'])]
)
encode_map(O_UNPCK,
encodings=[
(I_UPCK, [
('elem', (RM_ELEM, SRC(0))),
('scale_rtz', {'or': [OM_SCALE, OM_ROUNDZERO]}),
('pck_format', OM_PCK_FMT)
])
],
op_ref_maps=[('0', ['ft0'], ['s0'])]
)
encode_map(O_TST,
encodings=[
(I_TST_EXT, [
('tst_op', OM_TST_OP_MAIN),
('pwen', ('!pco_ref_is_null', DEST(1))),
('type', OM_TST_TYPE_MAIN),
('p2end', OM_PHASE2END),
('elem', (RM_ELEM, SRC(0)))
]),
(I_TST, [
('tst_op', OM_TST_OP_MAIN),
('pwen', ('!pco_ref_is_null', DEST(1))),
], [
(OM_TST_OP_MAIN, '<= PCO_TST_OP_MAIN_NOTEQUAL'),
(OM_TST_TYPE_MAIN, '== PCO_TST_TYPE_MAIN_F32'),
(OM_PHASE2END, '== false'),
(OM_TST_TYPE_MAIN, '== PCO_TST_TYPE_MAIN_F32'),
(RM_ELEM, SRC(0), '== 0'),
(RM_ELEM, SRC(1), '== 0'),
])
],
op_ref_maps=[('2_tst', ['ftt', ['p0', '_']], [['is1', '_'], ['is2', '_']])]
)
encode_map(O_MOVC,
encodings=[
(I_MOVC_EXT, [
('movw0', ('pco_ref_get_movw01', SRC(1))),
('movw1', ('pco_ref_get_movw01', SRC(3))),
('maskw0', (RM_ELEM, DEST(0))),
('aw', False),
('p2end', OM_PHASE2END)
]),
(I_MOVC, [
('movw0', ('pco_ref_get_movw01', SRC(1))),
('movw1', ('pco_ref_get_movw01', SRC(3))),
], [
(RM_ELEM, DEST(0), '== 0b1111'),
(OM_PHASE2END, '== false'),
])
],
op_ref_maps=[
('2_mov',
[['w0', '_'], ['w1', '_']],
['ftt', ['_', 'ft0', 'ft1', 'ft2', 'fte'], ['_', 'is4'], ['_', 'ft0', 'ft1', 'ft2', 'fte'], ['_', 'is5']])
]
)
encode_map(O_MOVWM,
encodings=[
(I_MOVC_EXT, [
('movw0', ('pco_ref_get_movw01', SRC(0))),
('movw1', 0),
('maskw0', (RM_ELEM, DEST(0))),
('aw', True),
('p2end', OM_PHASE2END)
])
],
op_ref_maps=[('2_mov', ['w0'], [['_', 'ft0', 'ft1', 'ft2', 'fte'], 'is4'])]
)
encode_map(O_ADD64_32,
encodings=[
(I_INT32_64_EXT, [
('s', OM_S),
('int32_64_op', 'add6432'),
('cin', ('!pco_ref_is_null', SRC(3))),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s1neg', False),
('s1abs', False),
('s2neg', (RM_NEG, SRC(2))),
('s2abs', (RM_ABS, SRC(2)))
]),
(I_INT32_64, [
('s', OM_S),
('int32_64_op', 'add6432'),
('s2neg', (RM_NEG, SRC(2))),
], [
('pco_ref_is_null', SRC(3)),
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false'),
(RM_ABS, SRC(2), '== false')
])
],
op_ref_maps=[('0', ['ft0', 'fte'], ['s0', 's1', 's2', ['_', 'p0']])]
)
encode_map(O_IMADD64,
encodings=[
(I_INT32_64_EXT, [
('s', OM_S),
('int32_64_op', 'madd64'),
('cin', ('!pco_ref_is_null', SRC(4))),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s1neg', (RM_NEG, SRC(1))),
('s1abs', (RM_ABS, SRC(1))),
('s2neg', (RM_NEG, SRC(2))),
('s2abs', (RM_ABS, SRC(2)))
]),
(I_INT32_64, [
('s', OM_S),
('int32_64_op', 'madd64'),
('s2neg', (RM_NEG, SRC(2))),
], [
('pco_ref_is_null', SRC(4)),
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false'),
(RM_NEG, SRC(1), '== false'),
(RM_ABS, SRC(1), '== false'),
(RM_ABS, SRC(2), '== false')
])
],
op_ref_maps=[('0', [['ft0', '_'], ['fte', '_']], ['s0', 's1', 's2', 'is0', ['_', 'p0']])]
)
encode_map(O_IMADD32,
encodings=[
(I_INT32_64_EXT, [
('s', OM_S),
('int32_64_op', 'madd32'),
('cin', ('!pco_ref_is_null', SRC(3))),
('s0neg', (RM_NEG, SRC(0))),
('s0abs', (RM_ABS, SRC(0))),
('s1neg', (RM_NEG, SRC(1))),
('s1abs', (RM_ABS, SRC(1))),
('s2neg', (RM_NEG, SRC(2))),
('s2abs', (RM_ABS, SRC(2)))
]),
(I_INT32_64, [
('s', OM_S),
('int32_64_op', 'madd32'),
('s2neg', (RM_NEG, SRC(2))),
], [
('pco_ref_is_null', SRC(3)),
(RM_NEG, SRC(0), '== false'),
(RM_ABS, SRC(0), '== false'),
(RM_NEG, SRC(1), '== false'),
(RM_ABS, SRC(1), '== false'),
(RM_ABS, SRC(2), '== false'),
])
],
op_ref_maps=[('0', ['ft0'], ['s0', 's1', 's2', ['_', 'p0']])]
)
encode_map(O_UVSW_WRITE,
encodings=[
(I_UVSW_WRITE_IMM, [
('dsel', 'w0'),
('imm_addr', ('pco_ref_get_imm', SRC(1)))
])
],
op_ref_maps=[('backend', [], ['w0', 'imm'])]
)
encode_map(O_UVSW_EMIT, encodings=[(I_UVSW_EMIT, [])], op_ref_maps=[('backend', [], [])])
encode_map(O_UVSW_ENDTASK, encodings=[(I_UVSW_ENDTASK, [])], op_ref_maps=[('backend', [], [])])
encode_map(O_UVSW_EMIT_ENDTASK, encodings=[(I_UVSW_EMIT_ENDTASK, [])], op_ref_maps=[('backend', [], [])])
encode_map(O_UVSW_WRITE_EMIT_ENDTASK,
encodings=[
(I_UVSW_WRITE_EMIT_ENDTASK_IMM, [
('dsel', 'w0'),
('imm_addr', ('pco_ref_get_imm', SRC(1)))
])
],
op_ref_maps=[('backend', [], ['w0', 'imm'])]
)
encode_map(O_FITR,
encodings=[
(I_FITR, [
('p', False),
('drc', ('pco_ref_get_drc', SRC(0))),
('iter_mode', OM_ITR_MODE),
('sat', OM_SAT),
('count', ('pco_ref_get_imm', SRC(2)))
])
],
op_ref_maps=[('backend', ['s3'], ['drc', 's0', 'imm'])]
)
encode_map(O_FITRP,
encodings=[
(I_FITR, [
('p', True),
('drc', ('pco_ref_get_drc', SRC(0))),
('iter_mode', OM_ITR_MODE),
('sat', OM_SAT),
('count', ('pco_ref_get_imm', SRC(3)))
])
],
op_ref_maps=[('backend', ['s3'], ['drc', 's0', 's2', 'imm'])]
)
encode_map(O_LD,
encodings=[
(I_LD_IMMBL, [
('drc', ('pco_ref_get_drc', SRC(0))),
('burstlen', ('pco_ref_get_imm', SRC(1))),
('srcseladd', ('pco_ref_srcsel', SRC(2))),
('cachemode_ld', OM_MCU_CACHE_MODE_LD)
])
],
op_ref_maps=[('backend', ['s3'], ['drc', 'imm', ['s0', 's1', 's2', 's3', 's4', 's5']])]
)
encode_map(O_LD_REGBL,
encodings=[
(I_LD_REGBL, [
('drc', ('pco_ref_get_drc', SRC(0))),
('srcseladd', ('pco_ref_srcsel', SRC(2))),
('srcselbl', ('pco_ref_srcsel', SRC(1))),
('cachemode_ld', OM_MCU_CACHE_MODE_LD)
])
],
op_ref_maps=[('backend', ['s3'], ['drc', ['s0', 's1', 's2', 's3', 's4', 's5'], ['s0', 's1', 's2', 's3', 's4', 's5']])]
)
encode_map(O_ST,
encodings=[
(I_ST_IMMBL, [
('drc', ('pco_ref_get_drc', SRC(2))),
('srcseladd', ('pco_ref_srcsel', SRC(4))),
('burstlen', ('pco_ref_get_imm', SRC(3))),
('cachemode_st', OM_MCU_CACHE_MODE_ST),
('srcseldata', ('pco_ref_srcsel', SRC(0))),
('dsize', ('pco_ref_get_imm', SRC(1)))
])
],
op_ref_maps=[('backend', [], [['s0', 's1', 's2', 's3', 's4', 's5'], 'imm', 'drc', 'imm', ['s0', 's1', 's2', 's3', 's4', 's5'], ['s0', 's1', 's2', 's3', 's4', 's5', '_']])]
)
encode_map(O_ST_REGBL,
encodings=[
(I_ST_REGBL, [
('drc', ('pco_ref_get_drc', SRC(2))),
('srcseladd', ('pco_ref_srcsel', SRC(4))),
('srcselbl', ('pco_ref_srcsel', SRC(3))),
('cachemode_st', OM_MCU_CACHE_MODE_ST),
('srcseldata', ('pco_ref_srcsel', SRC(0))),
('dsize', ('pco_ref_get_imm', SRC(1)))
])
],
op_ref_maps=[('backend', [], [['s0', 's1', 's2', 's3', 's4', 's5'], 'imm', 'drc', ['s0', 's1', 's2', 's3', 's4', 's5'], ['s0', 's1', 's2', 's3', 's4', 's5'], ['s0', 's1', 's2', 's3', 's4', 's5', '_']])]
)
encode_map(O_ST_TILED,
encodings=[
(I_ST_IMMBL_TILED, [
('drc', ('pco_ref_get_drc', SRC(2))),
('srcseladd', ('pco_ref_srcsel', SRC(4))),
('burstlen', ('pco_ref_get_imm', SRC(3))),
('cachemode_st', OM_MCU_CACHE_MODE_ST),
('srcseldata', ('pco_ref_srcsel', SRC(0))),
('dsize', ('pco_ref_get_imm', SRC(1))),
('srcmask', ('pco_ref_srcsel', SRC(5)))
])
],
op_ref_maps=[('backend', [], [['s0', 's1', 's2', 's3', 's4', 's5'], 'imm', 'drc', 'imm', ['s0', 's1', 's2', 's3', 's4', 's5'], ['s0', 's1', 's2', 's3', 's4', 's5', '_']])]
)
encode_map(O_IDF,
encodings=[
(I_IDF, [
('drc', ('pco_ref_get_drc', SRC(0))),
('srcseladd', ('pco_ref_srcsel', SRC(1)))
])
],
op_ref_maps=[('backend', [], ['drc', ['s0', 's1', 's2', 's3', 's4', 's5']])]
)
encode_map(O_ATOMIC,
encodings=[
(I_ATOMIC, [
('drc', ('pco_ref_get_drc', SRC(0))),
('atomic_op', OM_ATOM_OP),
('srcsel', ('pco_ref_srcsel', SRC(1))),
('dstsel', ('pco_ref_srcsel', DEST(0)))
])
],
op_ref_maps=[('backend', [['s0', 's1', 's2', 's3', 's4', 's5']], ['drc', ['s0', 's1', 's2', 's3', 's4', 's5']])]
)
encode_map(O_SMP,
encodings=[
(I_SMP_EXTABC, [
('fcnorm', OM_FCNORM),
('drc', ('pco_ref_get_drc', SRC(0))),
('dmn', OM_DIM),
('chan', ('pco_ref_get_imm', SRC(5))),
('lodm', OM_LOD_MODE),
('pplod', OM_PPLOD),
('proj', OM_PROJ),
('sbmode', OM_SB_MODE),
('nncoords', OM_NNCOORDS),
('sno', OM_SNO),
('soo', OM_SOO),
('tao', OM_TAO),
('f16', OM_F16),
('swap', OM_SCHEDSWAP),
('cachemode_ld', OM_MCU_CACHE_MODE_LD),
('w', OM_WRT),
('integer', OM_INTEGER),
('array', OM_ARRAY),
]),
(I_SMP_EXTAB, [
('fcnorm', OM_FCNORM),
('drc', ('pco_ref_get_drc', SRC(0))),
('dmn', OM_DIM),
('chan', ('pco_ref_get_imm', SRC(5))),
('lodm', OM_LOD_MODE),
('pplod', OM_PPLOD),
('proj', OM_PROJ),
('sbmode', OM_SB_MODE),
('nncoords', OM_NNCOORDS),
('sno', OM_SNO),
('soo', OM_SOO),
('tao', OM_TAO),
('f16', OM_F16),
('swap', OM_SCHEDSWAP),
('cachemode_ld', OM_MCU_CACHE_MODE_LD),
('w', OM_WRT)
], [
(OM_INTEGER, '== false'),
(OM_ARRAY, '== false')
]),
(I_SMP_EXTA, [
('fcnorm', OM_FCNORM),
('drc', ('pco_ref_get_drc', SRC(0))),
('dmn', OM_DIM),
('chan', ('pco_ref_get_imm', SRC(5))),
('lodm', OM_LOD_MODE),
('pplod', OM_PPLOD),
('proj', OM_PROJ),
('sbmode', OM_SB_MODE),
('nncoords', OM_NNCOORDS),
('sno', OM_SNO),
('soo', OM_SOO),
('tao', OM_TAO)
], [
(OM_INTEGER, '== false'),
(OM_ARRAY, '== false'),
(OM_F16, '== false'),
(OM_SCHEDSWAP, '== PCO_SCHEDSWAP_NONE'),
(OM_MCU_CACHE_MODE_LD, '== PCO_CACHEMODE_LD_NORMAL'),
(OM_WRT, '== false')
]),
(I_SMP_BRIEF, [
('fcnorm', OM_FCNORM),
('drc', ('pco_ref_get_drc', SRC(0))),
('dmn', OM_DIM),
('chan', ('pco_ref_get_imm', SRC(5))),
('lodm', OM_LOD_MODE)
], [
(OM_INTEGER, '== false'),
(OM_ARRAY, '== false'),
(OM_F16, '== false'),
(OM_SCHEDSWAP, '== PCO_SCHEDSWAP_NONE'),
(OM_MCU_CACHE_MODE_LD, '== PCO_CACHEMODE_LD_NORMAL'),
(OM_WRT, '== false'),
(OM_PPLOD, '== false'),
(OM_PROJ, '== false'),
(OM_SB_MODE, '== PCO_SB_MODE_NONE'),
(OM_NNCOORDS, '== false'),
(OM_SNO, '== false'),
(OM_SOO, '== false'),
(OM_TAO, '== false')
])
],
op_ref_maps=[('backend', ['s4'], ['drc', 's0', 's1', 's2', ['s3', '_'], 'imm'])]
)
encode_map(O_ALPHATST,
encodings=[
(I_VISTEST_ATST, [
('pwen', ('!pco_ref_is_null', DEST(0))),
('ifb', True)
])
],
op_ref_maps=[('backend', [['p0', '_']], ['drc', 's0', 's1', 's2'])]
)
encode_map(O_ALPHAF,
encodings=[
(I_VISTEST_ATST, [
('pwen', ('!pco_ref_is_null', DEST(0))),
('ifb', False)
])
],
op_ref_maps=[('backend', [['p0', '_']], ['drc', 's0', 's1', 's2'])]
)
encode_map(O_DEPTHF,
encodings=[(I_VISTEST_DEPTHF, [])],
op_ref_maps=[('backend', [], ['drc', 'w0'])]
)
encode_map(O_SAVMSK,
encodings=[(I_SAVMSK, [('msk_mode', OM_SAVMSK_MODE)])],
op_ref_maps=[('backend', [['w0', '_'], ['w1', '_']], [])]
)
encode_map(O_EMITPIX,
encodings=[(I_EMITPIX, [('freep', OM_FREEP)])],
op_ref_maps=[('backend', [], ['s0', 's2'])]
)
encode_map(O_BBYP0BM,
encodings=[
(I_PHASE0_SRC, [
('count_src', 's2'),
('count_op', 'byp'),
('bitmask_src_op', 'byp'),
('shift1_op', 'byp')
])
],
op_ref_maps=[('0', ['ft0', 'ft1'], ['s0', 's1'])]
)
encode_map(O_BBYP0BM_IMM32,
encodings=[
(I_PHASE0_IMM32, [
('count_src', 's2'),
('count_op', 'byp'),
('shift1_op', 'byp'),
('imm32', ('pco_ref_get_imm', SRC(1)))
])
],
op_ref_maps=[('0', ['ft0', 'ft1'], ['s0', 'imm'])]
)
encode_map(O_BBYP0S1,
encodings=[
(I_PHASE0_SRC, [
('count_src', 's2'),
('count_op', 'byp'),
('bitmask_src_op', 'byp'),
('shift1_op', 'byp')
])
],
op_ref_maps=[('0', ['ft2', 'ft3'], ['s2'])]
)
encode_map(O_MSK_BBYP0S1,
encodings=[
(I_PHASE0_SRC, [
('count_src', 's2'),
('count_op', 'byp'),
('bitmask_src_op', 'msk'),
('shift1_op', 'byp')
])
],
op_ref_maps=[('0', ['ft0', 'ft1', 'ft2'], ['s0', 's1', 's2'])]
)
encode_map(O_MSK_LSL,
encodings=[
(I_PHASE0_SRC, [
('count_src', 's2'),
('count_op', 'byp'),
('bitmask_src_op', 'msk'),
('shift1_op', 'lsl')
])
],
op_ref_maps=[('0', ['ft0', 'ft1', 'ft2'], ['s0', 's1', 's2'])]
)
encode_map(O_CBS,
encodings=[
(I_PHASE0_SRC, [
('count_src', ('pco_ref_count_src', SRC(0))),
('count_op', 'cbs'),
('bitmask_src_op', 'byp'),
('shift1_op', 'byp')
])
],
op_ref_maps=[('0', ['ft3'], [['s2', 'ft2']])]
)
encode_map(O_FTB,
encodings=[
(I_PHASE0_SRC, [
('count_src', ('pco_ref_count_src', SRC(0))),
('count_op', 'ftb'),
('bitmask_src_op', 'byp'),
('shift1_op', 'byp')
])
],
op_ref_maps=[('0', ['ft3'], [['s2', 'ft2']])]
)
encode_map(O_REV,
encodings=[
(I_PHASE0_SRC, [
('count_src', 'ft2'),
('count_op', 'byp'),
('bitmask_src_op', 'byp'),
('shift1_op', 'rev')
])
],
op_ref_maps=[('0', ['ft2'], ['s2'])]
)
encode_map(O_SHUFFLE,
encodings=[
(I_PHASE0_SRC, [
('count_src', 'ft2'),
('count_op', 'byp'),
('bitmask_src_op', 'byp'),
('shift1_op', 'shfl')
])
],
op_ref_maps=[('0', ['ft2'], ['s2', 's1'])]
)
encode_map(O_LOGICAL,
encodings=[
(I_PHASE1, [
('mskb', ('!pco_ref_is_null', SRC(2))),
('mska', ('!pco_ref_is_null', SRC(0))),
('logical_op', OM_LOGIOP),
])
],
op_ref_maps=[('1', ['ft4'], [['ft1', '_'], 'ft2', ['ft1_invert', '_'], 's3'])]
)
encode_map(O_SHIFT,
encodings=[
(I_PHASE2, [
('pwen', False),
('tst_src', 0),
('bw_tst_op', 0),
('shift2_op', OM_SHIFTOP),
])
],
op_ref_maps=[('2', ['ft5'], ['ft4', 's4', ['_', 'ft0', 'ft3']])]
)
encode_map(O_WOP, encodings=[(I_WOP, [])], op_ref_maps=[('ctrl', [], [])])
encode_map(O_WDF, encodings=[(I_WDF, [])], op_ref_maps=[('ctrl', [], ['drc'])])
encode_map(O_NOP, encodings=[(I_NOP, [])], op_ref_maps=[('ctrl', [], [])])
encode_map(O_DITR,
encodings=[
(I_DITR, [
('dest', ('pco_ref_get_temp', DEST(0))),
('coff', ('pco_ref_get_coeff', SRC(1))),
('p', 'none'),
('woff', 0),
('mode', OM_ITR_MODE),
('count', ('pco_ref_get_imm', SRC(2))),
('coff_idx_ctrl', ('pco_ref_get_reg_idx_ctrl', SRC(1))),
('woff_idx_ctrl', 'none'),
('f16', OM_F16),
('sched_ctrl', OM_SCHED),
('drc', ('pco_ref_get_drc', SRC(0))),
('sat', OM_SAT)
])
],
op_ref_maps=[('ctrl', ['temp'], ['drc', 'coeff', 'imm'])]
)
encode_map(O_DITRP,
encodings=[
(I_DITR, [
('dest', ('pco_ref_get_temp', DEST(0))),
('coff', ('pco_ref_get_coeff', SRC(1))),
('p', 'iter_mul'),
('woff', ('pco_ref_get_coeff', SRC(2))),
('mode', OM_ITR_MODE),
('count', ('pco_ref_get_imm', SRC(3))),
('coff_idx_ctrl', ('pco_ref_get_reg_idx_ctrl', SRC(1))),
('woff_idx_ctrl', ('pco_ref_get_reg_idx_ctrl', SRC(2))),
('f16', OM_F16),
('sched_ctrl', OM_SCHED),
('drc', ('pco_ref_get_drc', SRC(0))),
('sat', OM_SAT)
])
],
op_ref_maps=[('ctrl', ['temp'], ['drc', 'coeff', 'coeff', 'imm'])]
)
encode_map(O_CNDST,
encodings=[
(I_CND, [
('adjust', ('pco_ref_get_imm', SRC(1))),
('pcnd', OM_CND),
('cndinst', 'st')
])
],
op_ref_maps=[('ctrl', ['pe', 'w0'], ['s0', 'imm'])]
)
encode_map(O_CNDEF,
encodings=[
(I_CND, [
('adjust', ('pco_ref_get_imm', SRC(1))),
('pcnd', OM_CND),
('cndinst', 'ef')
])
],
op_ref_maps=[('ctrl', ['pe', 'w0'], ['s0', 'imm'])]
)
encode_map(O_CNDSM,
encodings=[
(I_CND, [
('adjust', 0),
('pcnd', OM_CND),
('cndinst', 'sm')
])
],
op_ref_maps=[('ctrl', ['pe', 'w0'], ['s0', 's2'])]
)
encode_map(O_CNDLT,
encodings=[
(I_CND, [
('adjust', ('pco_ref_get_imm', SRC(1))),
('pcnd', OM_CND),
('cndinst', 'lt')
])
],
op_ref_maps=[('ctrl', ['pe', 'w0', 'p0'], ['s0', 'imm'])]
)
encode_map(O_CNDEND,
encodings=[
(I_CND, [
('adjust', ('pco_ref_get_imm', SRC(1))),
('pcnd', 0),
('cndinst', 'end')
])
],
op_ref_maps=[('ctrl', ['pe', 'w0'], ['s0', 'imm'])]
)
encode_map(O_BR,
encodings=[
(I_BRANCH, [
('link', OM_LINK),
('bpred', OM_BRANCH_CND),
('abs', False),
('offset', 'target_cf_node')
])
],
op_ref_maps=[('ctrl', [], [])]
)
encode_map(O_BR_NEXT,
encodings=[
(I_BRANCH, [
('link', False),
('bpred', 'cc'),
('abs', False),
('offset', 'target_next_igrp')
])
],
op_ref_maps=[('ctrl', [], [])]
)
encode_map(O_MUTEX,
encodings=[
(I_MUTEX, [
('lr', OM_MUTEX_OP),
('id', ('pco_ref_get_imm', SRC(0))),
])
],
op_ref_maps=[('ctrl', [], ['imm'])]
)
# Group mappings.
group_map(O_FADD,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FADD)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1')
],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FMUL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FMUL)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1')
],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FMAD,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FMAD)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FRCP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FRCP)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_FRSQ,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FRSQ)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_FLOG,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FLOG)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_FLOGCN,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FLOGCN)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_FEXP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FEXP)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_FRED,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', ('!pco_ref_is_null', DEST(1))),
('w0p', ('!pco_ref_is_null', DEST(0))),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FRED)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('0', SRC(1)), 's3')
],
dests=[
('w[0]', ('0', DEST(0)), 'w0'),
('w[1]', ('0', DEST(1)), 'w1')
]
)
group_map(O_FSINC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FSINC)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
dests=[('w[0]', ('0', DEST(0)), 'w0')]
)
group_map(O_MBYP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_MBYP)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FDSX,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FDSX)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FDSXF,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FDSXF)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FDSY,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FDSY)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_FDSYF,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FDSYF)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_PCK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('2_pck', O_PCK)],
srcs=[('s[2]', ('2_pck', SRC(0)), 'is3')],
iss=[
('is[0]', 's2'),
('is[3]', 'fte'),
('is[4]', 'ft2')
],
dests=[('w[0]', ('2_pck', DEST(0)), 'ft2')]
)
group_map(O_PCK_PROG,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('2_pck', O_PCK_PROG, [DEST(0)], ['is3', SRC(1)], [(OM_ROUNDZERO, OM_ROUNDZERO), (OM_SCALE, OM_SCALE)])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('2_pck', SRC(1)), 'fte')
],
iss=[
('is[0]', 's3'),
('is[3]', 'ft0'),
('is[4]', 'ft2')
],
dests=[('w[0]', ('2_pck', DEST(0)), 'ft2')]
)
group_map(O_UNPCK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_UNPCK)],
srcs=[('s[0]', ('0', SRC(0)), 's0')],
iss=[('is[4]', 'ft0')],
dests=[('w[0]', ('0', DEST(0)), 'ft0')]
)
group_map(O_MOVWM,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('2_mov', O_MOVWM, [DEST(0)], ['ft0', SRC(1)], [(OM_PHASE2END, OM_PHASE2END)])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('2_mov', SRC(1)), 'is4')
],
iss=[
('is[0]', 's1'),
('is[4]', 'fte')
],
dests=[('w[0]', ('2_mov', DEST(0)), 'w0')]
)
group_map(O_MOVS1,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('2_mov', O_MOVWM, [DEST(0)], [SRC(0), 'is4'], [(OM_PHASE2END, True)])],
srcs=[('s[1]', ('2_mov', SRC(0)), 'fte')],
iss=[
('is[0]', 's1'),
('is[4]', 'fte')
],
dests=[('w[0]', ('2_mov', DEST(0)), 'w0')]
)
group_map(O_ADD64_32,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', ('!pco_ref_is_null', DEST(1))),
('w0p', ('!pco_ref_is_null', DEST(0))),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_ADD64_32)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[
('is[4]', 'ft0'),
('is[5]', 'fte')
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
('w[1]', ('0', DEST(1)), 'fte')
]
)
group_map(O_IMADD64,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
# TODO: make this change to add64_32, etc. as well
('w1p', ('!pco_ref_is_null', DEST(1))),
('w0p', ('!pco_ref_is_null', DEST(0))),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_IMADD64)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('0', SRC(3)), 'is0')
],
iss=[
('is[0]', 's3'),
('is[4]', 'ft0'),
('is[5]', 'fte')
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
('w[1]', ('0', DEST(1)), 'fte')
]
)
group_map(O_IMADD32,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_IMADD32)],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[
('is[4]', 'ft0'),
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
]
)
group_map(O_SCMP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('1', O_MBYP, ['ft1'], [SRC(1)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, OM_TST_OP_MAIN), (OM_TST_TYPE_MAIN, 'f32')]),
('2_pck', O_PCK, ['ft2'], ['_'], [(OM_PCK_FMT, 'one')]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft2', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', 'pco_zero'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's1'),
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'fte'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_BCMP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('1', O_MBYP, ['ft1'], [SRC(1)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, OM_TST_OP_MAIN), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN)]),
('2_pck', O_PCK, ['ft2'], ['_'], [(OM_PCK_FMT, 'zero')]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'fte', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', 'pco_true'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's1'),
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft2'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_BCSEL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(1)]),
('1', O_MBYP, ['ft1'], [SRC(2)]),
('2_tst', O_TST, ['ftt', '_'], [SRC(0), '_'], [(OM_TST_OP_MAIN, 'zero'), (OM_TST_TYPE_MAIN, 'u32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft1', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('2_tst', SRC(0)), 'is1'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's1'),
('is[1]', 'fte'),
('is[4]', 'ft0'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_CSEL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(1)]),
('1', O_MBYP, ['ft1'], [SRC(2)]),
('2_tst', O_TST, ['ftt', '_'], [SRC(0), '_'], [(OM_TST_OP_MAIN, OM_TST_OP_MAIN), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft0', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('2_tst', SRC(0)), 'is1'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's1'),
('is[1]', 'fte'),
('is[4]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_PSEL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_IMADD64, ['ft0', 'fte'], ['pco_zero', 'pco_zero', 'pco_zero', 'is0', SRC(0)]),
('1', O_MBYP, ['ft1'], [SRC(1)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', '_'], [(OM_TST_OP_MAIN, 'zero'), (OM_TST_TYPE_MAIN, 'u32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', SRC(2), 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(0)), 's3'),
('s[4]', ('2_mov', SRC(1)), 'fte'),
],
iss=[
('is[0]', 's4'),
('is[1]', 'ft0'),
('is[4]', 'ft1'),
],
dests=[('w[0]', ('2_mov', DEST(0)), 'w0')]
)
group_map(O_PSEL_TRIG,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_IMADD64, ['ft0', 'fte'], ['pco_zero', 'pco_zero', 'pco_zero', 'is0', SRC(0)]),
('1', O_FMUL, ['ft1'], [SRC(1), SRC(2)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', '_'], [(OM_TST_OP_MAIN, 'zero'), (OM_TST_TYPE_MAIN, 'u32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'fte', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(0)), 's3'),
('s[4]', ('1', SRC(1)), 's4'),
],
iss=[
('is[0]', 's3'),
('is[1]', 'ft0'),
('is[4]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_FSIGN,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_FMUL, ['ft0'], [SRC(0), 'pco_finf'], [(OM_SAT, True)]),
('1', O_MBYP, ['ft1'], ['pco_fnegone']),
('2_tst', O_TST, ['ftt', '_'], ['is1', '_'], [(OM_TST_OP_MAIN, 'gezero'), (OM_TST_TYPE_MAIN, 's32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft0', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's0'),
('is[1]', 'fte'),
('is[4]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_ISIGN,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_IMADD64, ['_', 'fte'], [SRC(0), 'pco_one', 'pco_zero', 'is0', '_'], [(OM_S, True)]),
('1', O_MBYP, ['ft1'], ['pco_one']),
('2_tst', O_TST, ['ftt', '_'], ['is1', '_'], [(OM_TST_OP_MAIN, 'gzero'), (OM_TST_TYPE_MAIN, 's32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft1', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[0]', 's2'),
('is[1]', 'ft0'),
('is[4]', 'fte'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_FCEIL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_FADD, ['ft0'], [SRC(0, [RM_FLR]), 'pco_fone']),
('1', O_FADD, ['ft1'], [SRC(0, [RM_FLR]), 'pco_zero']),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'equal'), (OM_TST_TYPE_MAIN, 'f32'), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft1', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[3]', ('1', SRC(0)), 's3'),
('s[4]', ('1', SRC(1)), 's4'),
],
iss=[
('is[0]', 's0'),
('is[1]', 'fte'),
('is[2]', 'ft1'),
('is[4]', 'ft0'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_MIN,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('1', O_MBYP, ['ft1'], [SRC(1)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'less'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft0', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_MAX,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('1', O_MBYP, ['ft1'], [SRC(1)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'greater'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'ft0', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3'),
],
iss=[
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_IADD32,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_IMADD32, [DEST(0)], [SRC(0), 'pco_one', SRC(1), SRC(2)], [(OM_S, OM_S)])],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[
('is[4]', 'ft0'),
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
]
)
group_map(O_IMUL32,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_IMADD32, [DEST(0)], [SRC(0), SRC(1), 'pco_zero', SRC(2)], [(OM_S, OM_S)])],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[
('is[4]', 'ft0'),
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
]
)
group_map(O_TSTZ,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p2'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', ('!pco_ref_is_null', DEST(0))),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(0)]),
('2_tst', O_TST, ['ftt', DEST(1)], ['is1', '_'], [(OM_TST_OP_MAIN, 'zero'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN)]),
('2_pck', O_PCK, ['ft2'], ['_'], [(OM_PCK_FMT, 'zero')]),
('2_mov', O_MOVC, [DEST(0), '_'], ['ftt', 'fte', 'is4', '_', '_'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', 'pco_true'),
],
iss=[
('is[0]', 's1'),
('is[1]', 'ft0'),
('is[4]', 'ft2'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
]
)
group_map(O_ST32,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_ST, [], [SRC(0), 'pco_ref_imm8(PCO_DSIZE_32BIT)', SRC(1), SRC(2), SRC(3), SRC(4)], [(OM_MCU_CACHE_MODE_ST, OM_MCU_CACHE_MODE_ST), (OM_IDF, OM_IDF)])],
srcs=[
('s[0]', ('backend', SRC(0)), 's0'),
('s[3]', ('backend', SRC(4)), 's3')
]
)
group_map(O_ST32_REGBL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_ST_REGBL, [], [SRC(0), 'pco_ref_imm8(PCO_DSIZE_32BIT)', SRC(1), SRC(2), SRC(3), SRC(4)], [(OM_MCU_CACHE_MODE_ST, OM_MCU_CACHE_MODE_ST), (OM_IDF, OM_IDF)])],
srcs=[
('s[0]', ('backend', SRC(0)), 's0'),
('s[2]', ('backend', SRC(3)), 's2'),
('s[3]', ('backend', SRC(4)), 's3')
]
)
group_map(O_ST_TILED,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_ST_TILED)],
srcs=[
('s[0]', ('backend', SRC(0)), 's0'),
('s[3]', ('backend', SRC(4)), 's3'),
('s[4]', ('backend', SRC(5)), 's4')
]
)
group_map(O_IDF,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_IDF)],
srcs=[('s[0]', ('backend', SRC(1)), 's0')]
)
group_map(O_IADD32_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_IMADD32, [DEST(1)], [SRC(0), 'pco_one', SRC(1), SRC(2)], [(OM_S, OM_S)]),
('1', O_MBYP, [DEST(0)], [SRC(0)])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[4]', 'ft1'),
('is[5]', 'ft0'),
],
dests=[
('w[0]', ('1', DEST(0)), 'ft1'),
('w[1]', ('0', DEST(0)), 'ft0'),
]
)
group_map(O_XCHG_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, [DEST(1)], [SRC(1)]),
('1', O_MBYP, [DEST(0)], [SRC(0)])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[4]', 'ft1'),
('is[5]', 'ft0'),
],
dests=[
('w[0]', ('1', DEST(0)), 'ft1'),
('w[1]', ('0', DEST(0)), 'ft0'),
]
)
group_map(O_CMPXCHG_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(1)]),
('1', O_MBYP, ['ft1'], [SRC(0)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'equal'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(1), DEST(0)], ['ftt', SRC(2), 'is4', 'ft1', 'is5'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('2_mov', SRC(1)), 'fte'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[0]', 's1'),
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft1'),
('is[5]', 'ft1'),
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
('w[1]', ('2_mov', DEST(1)), 'w1')
]
)
group_map(O_MIN_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(1)]),
('1', O_MBYP, ['ft1'], [SRC(0)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'less'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(1), DEST(0)], ['ftt', 'ft0', 'is4', 'ft1', 'is5'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft1'),
('is[5]', 'ft1')
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
('w[1]', ('2_mov', DEST(1)), 'w1')
]
)
group_map(O_MAX_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1_p2'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, ['ft0'], [SRC(1)]),
('1', O_MBYP, ['ft1'], [SRC(0)]),
('2_tst', O_TST, ['ftt', '_'], ['is1', 'is2'], [(OM_TST_OP_MAIN, 'greater'), (OM_TST_TYPE_MAIN, OM_TST_TYPE_MAIN), (OM_PHASE2END, True)]),
('2_mov', O_MOVC, [DEST(1), DEST(0)], ['ftt', 'ft0', 'is4', 'ft1', 'is5'])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[1]', 'ft0'),
('is[2]', 'ft1'),
('is[4]', 'ft1'),
('is[5]', 'ft1')
],
dests=[
('w[0]', ('2_mov', DEST(0)), 'w0'),
('w[1]', ('2_mov', DEST(1)), 'w1')
]
)
group_map(O_LOGICAL_ATOMIC,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1']),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', True),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_BBYP0S1, ['ft2', DEST(0)], [SRC(0)]),
('1', O_LOGICAL, [DEST(1)], ['_', 'ft2', '_', SRC(1)], [(OM_LOGIOP, OM_LOGIOP)])
],
srcs=[
('s[2]', ('0', SRC(0)), 's2'),
('s[3]', ('1', SRC(3)), 's3')
],
dests=[
('w[0]', ('1', DEST(0)), 'ft4'),
('w[1]', ('0', DEST(1)), 'ft3')
]
)
group_map(O_FLUSH_P0,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p2'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[
('0', O_IMADD32, ['ft0'], ['pco_zero', 'pco_zero', 'pco_zero', 'pco_p0'], [(OM_S, False)]),
('2_tst', O_TST, ['ftt', 'pco_p0'], ['is1', '_'], [(OM_TST_OP_MAIN, 'gzero'), (OM_TST_TYPE_MAIN, 'u32'), (OM_PHASE2END, True)]),
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2')
],
iss=[
('is[1]', 'ft0'),
]
)
group_map(O_MBYP2,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'p0_p1'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MBYP, [DEST(0)], [SRC(0)]),
('1', O_MBYP, [DEST(1)], [SRC(1)])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[3]', ('1', SRC(0)), 's3')
],
iss=[
('is[4]', 'ft0'),
('is[5]', 'ft1'),
],
dests=[
('w[0]', ('0', DEST(0)), 'ft0'),
('w[1]', ('1', DEST(0)), 'ft1'),
]
)
group_map(O_UVSW_WRITE,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', False),
('atom', False),
('rpt', OM_RPT)
]),
enc_ops=[('backend', O_UVSW_WRITE)],
srcs=[('s[0]', ('backend', SRC(0)), 'w0')],
iss=[
('is[0]', 's0'),
('is[4]', 'fte')
]
)
group_map(O_UVSW_EMIT,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', False),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_UVSW_EMIT)]
)
group_map(O_UVSW_ENDTASK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_UVSW_ENDTASK)]
)
group_map(O_UVSW_EMIT_ENDTASK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_UVSW_EMIT_ENDTASK)]
)
group_map(O_UVSW_WRITE_EMIT_ENDTASK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_UVSW_WRITE_EMIT_ENDTASK)],
srcs=[('s[0]', ('backend', SRC(0)), 'w0')],
iss=[
('is[0]', 's0'),
('is[4]', 'fte')
]
)
group_map(O_FITR,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_FITR)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[3]', ('backend', DEST(0)), 's3')
]
)
group_map(O_FITRP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_FITRP)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[2]', ('backend', SRC(2)), 's2'),
('s[3]', ('backend', DEST(0)), 's3')
]
)
group_map(O_LD,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_LD)],
srcs=[
('s[0]', ('backend', SRC(2)), 's0'),
('s[3]', ('backend', DEST(0)), 's3')
]
)
group_map(O_LD_REGBL,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_LD_REGBL)],
srcs=[
('s[0]', ('backend', SRC(2)), 's0'),
('s[1]', ('backend', SRC(1)), 's1'),
('s[3]', ('backend', DEST(0)), 's3')
]
)
group_map(O_ATOMIC,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_ATOMIC)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[3]', ('backend', DEST(0)), 's3')
]
)
group_map(O_SMP,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', False),
('rpt', 1)
]),
enc_ops=[('backend', O_SMP)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[1]', ('backend', SRC(2)), 's1'),
('s[2]', ('backend', SRC(3)), 's2'),
('s[3]', ('backend', SRC(4)), 's3'),
('s[4]', ('backend', DEST(0)), 's4')
]
)
group_map(O_ALPHATST,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_ALPHATST)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[1]', ('backend', SRC(2)), 's1'),
('s[2]', ('backend', SRC(3)), 's2'),
]
)
group_map(O_ALPHAF,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_ALPHAF)],
srcs=[
('s[0]', ('backend', SRC(1)), 's0'),
('s[1]', ('backend', SRC(2)), 's1'),
('s[2]', ('backend', SRC(3)), 's2'),
]
)
group_map(O_DEPTHF,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_DEPTHF)],
srcs=[('s[0]', ('backend', SRC(1)), 'w0')],
iss=[
('is[0]', 's0'),
('is[4]', 'fte')
]
)
group_map(O_SAVMSK,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', ('!pco_ref_is_null', DEST(1))),
('w0p', ('!pco_ref_is_null', DEST(0))),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_SAVMSK)],
dests=[
('w[0]', ('backend', DEST(0)), 'w0'),
('w[1]', ('backend', DEST(1)), 'w1')
]
)
group_map(O_EMITPIX,
hdr=(I_IGRP_HDR_MAIN, [
('oporg', 'be'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', 1)
]),
enc_ops=[('backend', O_EMITPIX)],
srcs=[
('s[0]', ('backend', SRC(0)), 's0'),
('s[2]', ('backend', SRC(1)), 's2')
]
)
group_map(O_MOVI32,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', 'p0'),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_BBYP0BM_IMM32, ['ft0', DEST(0)], ['s0', SRC(0)])],
dests=[('w[0]', ('0', DEST(1)), 'ft1')]
)
group_map(O_CBS,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', 'p0'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_CBS)],
srcs=[('s[2]', ('0', SRC(0)), 's2')],
dests=[('w[1]', ('0', DEST(0)), 'ft3')]
)
group_map(O_FTB,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', 'p0'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_FTB)],
srcs=[('s[2]', ('0', SRC(0)), 's2')],
dests=[('w[1]', ('0', DEST(0)), 'ft3')]
)
group_map(O_REV,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', 'p0'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_REV)],
srcs=[('s[2]', ('0', SRC(0)), 's2')],
dests=[('w[1]', ('0', DEST(0)), 'ft2')]
)
group_map(O_SHUFFLE,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', 'p0'),
('olchk', OM_OLCHK),
('w1p', True),
('w0p', False),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[('0', O_SHUFFLE)],
srcs=[
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(0)), 's2')
],
dests=[('w[1]', ('0', DEST(0)), 'ft2')]
)
group_map(O_LOGICAL,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_BBYP0S1, ['ft2', 'ft3'], [SRC(1)]),
('1', O_LOGICAL, [DEST(0)], [SRC(0), 'ft2', SRC(2), SRC(3)], [(OM_LOGIOP, OM_LOGIOP)])
],
srcs=[
('s[2]', ('0', SRC(0)), 's2'),
('s[3]', ('1', SRC(3)), 's3')
],
dests=[('w[0]', ('1', DEST(0)), 'ft4')]
)
group_map(O_SHIFT,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p2']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_BBYP0BM, ['ft0', 'ft1'], ['s0', SRC(0)]),
('2', O_SHIFT, [DEST(0)], ['ft4', SRC(1), SRC(2)], [(OM_SHIFTOP, OM_SHIFTOP)])
],
srcs=[
('s[1]', ('0', SRC(1)), 's1'),
('s[4]', ('2', SRC(1)), 's4')
],
dests=[('w[0]', ('2', DEST(0)), 'ft5')]
)
group_map(O_COPYSIGN,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MSK_BBYP0S1, ['ft0', 'ft1', 'ft2'], ['pco_31', 'pco_zero', SRC(0)]),
('1', O_LOGICAL, [DEST(0)], ['ft1', 'ft2', 'ft1_invert', SRC(1)], [(OM_LOGIOP, 'or')])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(3)), 's3')
],
dests=[('w[0]', ('1', DEST(0)), 'ft4')]
)
group_map(O_IBFE,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1', 'p2']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MSK_BBYP0S1, ['ft0', 'ft1', 'ft2'], [SRC(2), SRC(1), SRC(0)]),
('1', O_LOGICAL, ['ft4'], ['ft1', 'ft2', 'ft1_invert', 'pco_zero'], [(OM_LOGIOP, 'or')]),
('2', O_SHIFT, [DEST(0)], ['ft4', SRC(1), 'ft0'], [(OM_SHIFTOP, 'asr_mtb')])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(3)), 's3'),
('s[4]', ('2', SRC(1)), 's4')
],
dests=[('w[0]', ('2', DEST(0)), 'ft5')]
)
group_map(O_UBFE,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1', 'p2']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MSK_BBYP0S1, ['ft0', 'ft1', 'ft2'], [SRC(2), SRC(1), SRC(0)]),
('1', O_LOGICAL, ['ft4'], ['ft1', 'ft2', 'ft1_invert', 'pco_zero'], [(OM_LOGIOP, 'or')]),
('2', O_SHIFT, [DEST(0)], ['ft4', SRC(1), '_'], [(OM_SHIFTOP, 'shr')])
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(3)), 's3'),
('s[4]', ('2', SRC(1)), 's4')
],
dests=[('w[0]', ('2', DEST(0)), 'ft5')]
)
group_map(O_BFI,
hdr=(I_IGRP_HDR_BITWISE, [
('opcnt', ['p0', 'p1']),
('olchk', OM_OLCHK),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('end', OM_END),
('atom', OM_ATOM),
('rpt', OM_RPT)
]),
enc_ops=[
('0', O_MSK_LSL, ['ft0', 'ft1', 'ft2'], [SRC(3), SRC(2), SRC(1)]),
('1', O_LOGICAL, [DEST(0)], ['ft1', 'ft2', 'ft1_invert', SRC(0)], [(OM_LOGIOP, 'or')]),
],
srcs=[
('s[0]', ('0', SRC(0)), 's0'),
('s[1]', ('0', SRC(1)), 's1'),
('s[2]', ('0', SRC(2)), 's2'),
('s[3]', ('1', SRC(3)), 's3'),
],
dests=[('w[0]', ('1', DEST(0)), 'ft4')]
)
group_map(O_WOP,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('miscctl', 0),
('ctrlop', 'wop')
]),
enc_ops=[('ctrl', O_WOP),]
)
group_map(O_WDF,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('miscctl', ('pco_ref_get_drc', SRC(0))),
('ctrlop', 'wdf')
]),
enc_ops=[('ctrl', O_WDF)]
)
group_map(O_NOP,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('miscctl', OM_END),
('ctrlop', 'nop')
]),
enc_ops=[('ctrl', O_NOP)]
)
group_map(O_DITR,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'ditr')
]),
enc_ops=[('ctrl', O_DITR)]
)
group_map(O_DITRP,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'ditr')
]),
enc_ops=[('ctrl', O_DITRP)]
)
group_map(O_CNDST,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'cnd')
]),
enc_ops=[('ctrl', O_CNDST)],
srcs=[
('s[0]', ('ctrl', SRC(0)), 's0'),
('s[3]', 'pco_zero')
],
dests=[('w[0]', ('ctrl', DEST(1)), 'w0')]
)
group_map(O_CNDEF,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'cnd')
]),
enc_ops=[('ctrl', O_CNDEF)],
srcs=[
('s[0]', ('ctrl', SRC(0)), 's0'),
('s[3]', 'pco_zero')
],
dests=[('w[0]', ('ctrl', DEST(1)), 'w0')]
)
group_map(O_CNDSM,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'cnd')
]),
enc_ops=[('ctrl', O_CNDSM)],
srcs=[
('s[0]', ('ctrl', SRC(0)), 's0'),
('s[2]', ('ctrl', SRC(1)), 's2'),
('s[3]', 'pco_zero')
],
dests=[('w[0]', ('ctrl', DEST(1)), 'w0')]
)
group_map(O_CNDLT,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'cnd')
]),
enc_ops=[('ctrl', O_CNDLT)],
srcs=[
('s[0]', ('ctrl', SRC(0)), 's0'),
('s[3]', 'pco_zero')
],
dests=[('w[0]', ('ctrl', DEST(1)), 'w0')]
)
group_map(O_CNDEND,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', True),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'cnd')
]),
enc_ops=[('ctrl', O_CNDEND)],
srcs=[
('s[0]', ('ctrl', SRC(0)), 's0'),
('s[3]', 'pco_zero')
],
dests=[('w[0]', ('ctrl', DEST(1)), 'w0')]
)
group_map(O_BR,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'b')
]),
enc_ops=[('ctrl', O_BR)]
)
group_map(O_BR_NEXT,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', OM_EXEC_CND),
('miscctl', False),
('ctrlop', 'b')
]),
enc_ops=[('ctrl', O_BR_NEXT)]
)
group_map(O_MUTEX,
hdr=(I_IGRP_HDR_CONTROL, [
('olchk', False),
('w1p', False),
('w0p', False),
('cc', 'e1_zx'),
('miscctl', False),
('ctrlop', 'mutex')
]),
enc_ops=[('ctrl', O_MUTEX)]
)