99 lines
3.3 KiB
Python
99 lines
3.3 KiB
Python
"""
|
|
The `cretonne.immediates` module predefines all the Cretonne immediate operand
|
|
types.
|
|
"""
|
|
from __future__ import absolute_import
|
|
from cdsl.operands import ImmediateKind
|
|
|
|
#: A 64-bit immediate integer operand.
|
|
#:
|
|
#: This type of immediate integer can interact with SSA values with any
|
|
#: :py:class:`cretonne.IntType` type.
|
|
imm64 = ImmediateKind('imm64', 'A 64-bit immediate integer.')
|
|
|
|
#: An unsigned 8-bit immediate integer operand.
|
|
#:
|
|
#: This small operand is used to indicate lane indexes in SIMD vectors and
|
|
#: immediate bit counts on shift instructions.
|
|
uimm8 = ImmediateKind('uimm8', 'An 8-bit immediate unsigned integer.')
|
|
|
|
#: A 32-bit immediate signed offset.
|
|
#:
|
|
#: This is used to represent an immediate address offset in load/store
|
|
#: instructions.
|
|
offset32 = ImmediateKind(
|
|
'offset32',
|
|
'A 32-bit immediate signed offset.',
|
|
default_member='offset')
|
|
|
|
#: A 32-bit immediate unsigned offset.
|
|
#:
|
|
#: This is used to represent an immediate address offset in WebAssembly memory
|
|
#: instructions.
|
|
uoffset32 = ImmediateKind(
|
|
'uoffset32',
|
|
'A 32-bit immediate unsigned offset.',
|
|
default_member='offset')
|
|
|
|
#: A 32-bit immediate floating point operand.
|
|
#:
|
|
#: IEEE 754-2008 binary32 interchange format.
|
|
ieee32 = ImmediateKind('ieee32', 'A 32-bit immediate floating point number.')
|
|
|
|
#: A 64-bit immediate floating point operand.
|
|
#:
|
|
#: IEEE 754-2008 binary64 interchange format.
|
|
ieee64 = ImmediateKind('ieee64', 'A 64-bit immediate floating point number.')
|
|
|
|
#: A condition code for comparing integer values.
|
|
#:
|
|
#: This enumerated operand kind is used for the :cton:inst:`icmp` instruction
|
|
#: and corresponds to the `condcodes::IntCC` Rust type.
|
|
intcc = ImmediateKind(
|
|
'intcc',
|
|
'An integer comparison condition code.',
|
|
default_member='cond', rust_type='IntCC',
|
|
values={
|
|
'eq': 'Equal',
|
|
'ne': 'NotEqual',
|
|
'sge': 'SignedGreaterThanOrEqual',
|
|
'sgt': 'SignedGreaterThan',
|
|
'sle': 'SignedLessThanOrEqual',
|
|
'slt': 'SignedLessThan',
|
|
'uge': 'UnsignedGreaterThanOrEqual',
|
|
'ugt': 'UnsignedGreaterThan',
|
|
'ule': 'UnsignedLessThanOrEqual',
|
|
'ult': 'UnsignedLessThan',
|
|
})
|
|
|
|
#: A condition code for comparing floating point values.
|
|
#:
|
|
#: This enumerated operand kind is used for the :cton:inst:`fcmp` instruction
|
|
#: and corresponds to the `condcodes::FloatCC` Rust type.
|
|
floatcc = ImmediateKind(
|
|
'floatcc',
|
|
'A floating point comparison condition code.',
|
|
default_member='cond', rust_type='FloatCC',
|
|
values={
|
|
'ord': 'Ordered',
|
|
'uno': 'Unordered',
|
|
'eq': 'Equal',
|
|
'ne': 'NotEqual',
|
|
'one': 'OrderedNotEqual',
|
|
'ueq': 'UnorderedOrEqual',
|
|
'lt': 'LessThan',
|
|
'le': 'LessThanOrEqual',
|
|
'gt': 'GreaterThan',
|
|
'ge': 'GreaterThanOrEqual',
|
|
'ult': 'UnorderedOrLessThan',
|
|
'ule': 'UnorderedOrLessThanOrEqual',
|
|
'ugt': 'UnorderedOrGreaterThan',
|
|
'uge': 'UnorderedOrGreaterThanOrEqual',
|
|
})
|
|
|
|
#: Flags for memory operations like :inst:`load` and :inst:`store`.
|
|
memflags = ImmediateKind(
|
|
'memflags',
|
|
'Memory operation flags',
|
|
default_member='flags', rust_type='MemFlags')
|