mirror of
https://github.com/capstone-engine/llvm-capstone.git
synced 2025-01-05 23:52:45 +00:00
43153024ab
Currently if you use -{start,stop}-{before,after}, it picks the first instance with the matching pass name. If you run the same pass multiple times, there's no way to distinguish them. Allow specifying a run index wih ,N to specify which you mean. llvm-svn: 348285
776 lines
22 KiB
ReStructuredText
776 lines
22 KiB
ReStructuredText
========================================
|
|
Machine IR (MIR) Format Reference Manual
|
|
========================================
|
|
|
|
.. contents::
|
|
:local:
|
|
|
|
.. warning::
|
|
This is a work in progress.
|
|
|
|
Introduction
|
|
============
|
|
|
|
This document is a reference manual for the Machine IR (MIR) serialization
|
|
format. MIR is a human readable serialization format that is used to represent
|
|
LLVM's :ref:`machine specific intermediate representation
|
|
<machine code representation>`.
|
|
|
|
The MIR serialization format is designed to be used for testing the code
|
|
generation passes in LLVM.
|
|
|
|
Overview
|
|
========
|
|
|
|
The MIR serialization format uses a YAML container. YAML is a standard
|
|
data serialization language, and the full YAML language spec can be read at
|
|
`yaml.org
|
|
<http://www.yaml.org/spec/1.2/spec.html#Introduction>`_.
|
|
|
|
A MIR file is split up into a series of `YAML documents`_. The first document
|
|
can contain an optional embedded LLVM IR module, and the rest of the documents
|
|
contain the serialized machine functions.
|
|
|
|
.. _YAML documents: http://www.yaml.org/spec/1.2/spec.html#id2800132
|
|
|
|
MIR Testing Guide
|
|
=================
|
|
|
|
You can use the MIR format for testing in two different ways:
|
|
|
|
- You can write MIR tests that invoke a single code generation pass using the
|
|
``-run-pass`` option in llc.
|
|
|
|
- You can use llc's ``-stop-after`` option with existing or new LLVM assembly
|
|
tests and check the MIR output of a specific code generation pass.
|
|
|
|
Testing Individual Code Generation Passes
|
|
-----------------------------------------
|
|
|
|
The ``-run-pass`` option in llc allows you to create MIR tests that invoke just
|
|
a single code generation pass. When this option is used, llc will parse an
|
|
input MIR file, run the specified code generation pass(es), and output the
|
|
resulting MIR code.
|
|
|
|
You can generate an input MIR file for the test by using the ``-stop-after`` or
|
|
``-stop-before`` option in llc. For example, if you would like to write a test
|
|
for the post register allocation pseudo instruction expansion pass, you can
|
|
specify the machine copy propagation pass in the ``-stop-after`` option, as it
|
|
runs just before the pass that we are trying to test:
|
|
|
|
``llc -stop-after=machine-cp bug-trigger.ll > test.mir``
|
|
|
|
If the same pass is run multiple times, a run index can be included
|
|
after the name with a comma.
|
|
|
|
``llc -stop-after=dead-mi-elimination,1 bug-trigger.ll > test.mir``
|
|
|
|
After generating the input MIR file, you'll have to add a run line that uses
|
|
the ``-run-pass`` option to it. In order to test the post register allocation
|
|
pseudo instruction expansion pass on X86-64, a run line like the one shown
|
|
below can be used:
|
|
|
|
``# RUN: llc -o - %s -mtriple=x86_64-- -run-pass=postrapseudos | FileCheck %s``
|
|
|
|
The MIR files are target dependent, so they have to be placed in the target
|
|
specific test directories (``lib/CodeGen/TARGETNAME``). They also need to
|
|
specify a target triple or a target architecture either in the run line or in
|
|
the embedded LLVM IR module.
|
|
|
|
Simplifying MIR files
|
|
^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
The MIR code coming out of ``-stop-after``/``-stop-before`` is very verbose;
|
|
Tests are more accessible and future proof when simplified:
|
|
|
|
- Use the ``-simplify-mir`` option with llc.
|
|
|
|
- Machine function attributes often have default values or the test works just
|
|
as well with default values. Typical candidates for this are: `alignment:`,
|
|
`exposesReturnsTwice`, `legalized`, `regBankSelected`, `selected`.
|
|
The whole `frameInfo` section is often unnecessary if there is no special
|
|
frame usage in the function. `tracksRegLiveness` on the other hand is often
|
|
necessary for some passes that care about block livein lists.
|
|
|
|
- The (global) `liveins:` list is typically only interesting for early
|
|
instruction selection passes and can be removed when testing later passes.
|
|
The per-block `liveins:` on the other hand are necessary if
|
|
`tracksRegLiveness` is true.
|
|
|
|
- Branch probability data in block `successors:` lists can be dropped if the
|
|
test doesn't depend on it. Example:
|
|
`successors: %bb.1(0x40000000), %bb.2(0x40000000)` can be replaced with
|
|
`successors: %bb.1, %bb.2`.
|
|
|
|
- MIR code contains a whole IR module. This is necessary because there are
|
|
no equivalents in MIR for global variables, references to external functions,
|
|
function attributes, metadata, debug info. Instead some MIR data references
|
|
the IR constructs. You can often remove them if the test doesn't depend on
|
|
them.
|
|
|
|
- Alias Analysis is performed on IR values. These are referenced by memory
|
|
operands in MIR. Example: `:: (load 8 from %ir.foobar, !alias.scope !9)`.
|
|
If the test doesn't depend on (good) alias analysis the references can be
|
|
dropped: `:: (load 8)`
|
|
|
|
- MIR blocks can reference IR blocks for debug printing, profile information
|
|
or debug locations. Example: `bb.42.myblock` in MIR references the IR block
|
|
`myblock`. It is usually possible to drop the `.myblock` reference and simply
|
|
use `bb.42`.
|
|
|
|
- If there are no memory operands or blocks referencing the IR then the
|
|
IR function can be replaced by a parameterless dummy function like
|
|
`define @func() { ret void }`.
|
|
|
|
- It is possible to drop the whole IR section of the MIR file if it only
|
|
contains dummy functions (see above). The .mir loader will create the
|
|
IR functions automatically in this case.
|
|
|
|
.. _limitations:
|
|
|
|
Limitations
|
|
-----------
|
|
|
|
Currently the MIR format has several limitations in terms of which state it
|
|
can serialize:
|
|
|
|
- The target-specific state in the target-specific ``MachineFunctionInfo``
|
|
subclasses isn't serialized at the moment.
|
|
|
|
- The target-specific ``MachineConstantPoolValue`` subclasses (in the ARM and
|
|
SystemZ backends) aren't serialized at the moment.
|
|
|
|
- The ``MCSymbol`` machine operands don't support temporary or local symbols.
|
|
|
|
- A lot of the state in ``MachineModuleInfo`` isn't serialized - only the CFI
|
|
instructions and the variable debug information from MMI is serialized right
|
|
now.
|
|
|
|
These limitations impose restrictions on what you can test with the MIR format.
|
|
For now, tests that would like to test some behaviour that depends on the state
|
|
of temporary or local ``MCSymbol`` operands or the exception handling state in
|
|
MMI, can't use the MIR format. As well as that, tests that test some behaviour
|
|
that depends on the state of the target specific ``MachineFunctionInfo`` or
|
|
``MachineConstantPoolValue`` subclasses can't use the MIR format at the moment.
|
|
|
|
High Level Structure
|
|
====================
|
|
|
|
.. _embedded-module:
|
|
|
|
Embedded Module
|
|
---------------
|
|
|
|
When the first YAML document contains a `YAML block literal string`_, the MIR
|
|
parser will treat this string as an LLVM assembly language string that
|
|
represents an embedded LLVM IR module.
|
|
Here is an example of a YAML document that contains an LLVM module:
|
|
|
|
.. code-block:: llvm
|
|
|
|
define i32 @inc(i32* %x) {
|
|
entry:
|
|
%0 = load i32, i32* %x
|
|
%1 = add i32 %0, 1
|
|
store i32 %1, i32* %x
|
|
ret i32 %1
|
|
}
|
|
|
|
.. _YAML block literal string: http://www.yaml.org/spec/1.2/spec.html#id2795688
|
|
|
|
Machine Functions
|
|
-----------------
|
|
|
|
The remaining YAML documents contain the machine functions. This is an example
|
|
of such YAML document:
|
|
|
|
.. code-block:: text
|
|
|
|
---
|
|
name: inc
|
|
tracksRegLiveness: true
|
|
liveins:
|
|
- { reg: '$rdi' }
|
|
body: |
|
|
bb.0.entry:
|
|
liveins: $rdi
|
|
|
|
$eax = MOV32rm $rdi, 1, _, 0, _
|
|
$eax = INC32r killed $eax, implicit-def dead $eflags
|
|
MOV32mr killed $rdi, 1, _, 0, _, $eax
|
|
RETQ $eax
|
|
...
|
|
|
|
The document above consists of attributes that represent the various
|
|
properties and data structures in a machine function.
|
|
|
|
The attribute ``name`` is required, and its value should be identical to the
|
|
name of a function that this machine function is based on.
|
|
|
|
The attribute ``body`` is a `YAML block literal string`_. Its value represents
|
|
the function's machine basic blocks and their machine instructions.
|
|
|
|
Machine Instructions Format Reference
|
|
=====================================
|
|
|
|
The machine basic blocks and their instructions are represented using a custom,
|
|
human readable serialization language. This language is used in the
|
|
`YAML block literal string`_ that corresponds to the machine function's body.
|
|
|
|
A source string that uses this language contains a list of machine basic
|
|
blocks, which are described in the section below.
|
|
|
|
Machine Basic Blocks
|
|
--------------------
|
|
|
|
A machine basic block is defined in a single block definition source construct
|
|
that contains the block's ID.
|
|
The example below defines two blocks that have an ID of zero and one:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0:
|
|
<instructions>
|
|
bb.1:
|
|
<instructions>
|
|
|
|
A machine basic block can also have a name. It should be specified after the ID
|
|
in the block's definition:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0.entry: ; This block's name is "entry"
|
|
<instructions>
|
|
|
|
The block's name should be identical to the name of the IR block that this
|
|
machine block is based on.
|
|
|
|
.. _block-references:
|
|
|
|
Block References
|
|
^^^^^^^^^^^^^^^^
|
|
|
|
The machine basic blocks are identified by their ID numbers. Individual
|
|
blocks are referenced using the following syntax:
|
|
|
|
.. code-block:: text
|
|
|
|
%bb.<id>
|
|
|
|
Example:
|
|
|
|
.. code-block:: llvm
|
|
|
|
%bb.0
|
|
|
|
The following syntax is also supported, but the former syntax is preferred for
|
|
block references:
|
|
|
|
.. code-block:: text
|
|
|
|
%bb.<id>[.<name>]
|
|
|
|
Example:
|
|
|
|
.. code-block:: llvm
|
|
|
|
%bb.1.then
|
|
|
|
Successors
|
|
^^^^^^^^^^
|
|
|
|
The machine basic block's successors have to be specified before any of the
|
|
instructions:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0.entry:
|
|
successors: %bb.1.then, %bb.2.else
|
|
<instructions>
|
|
bb.1.then:
|
|
<instructions>
|
|
bb.2.else:
|
|
<instructions>
|
|
|
|
The branch weights can be specified in brackets after the successor blocks.
|
|
The example below defines a block that has two successors with branch weights
|
|
of 32 and 16:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0.entry:
|
|
successors: %bb.1.then(32), %bb.2.else(16)
|
|
|
|
.. _bb-liveins:
|
|
|
|
Live In Registers
|
|
^^^^^^^^^^^^^^^^^
|
|
|
|
The machine basic block's live in registers have to be specified before any of
|
|
the instructions:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0.entry:
|
|
liveins: $edi, $esi
|
|
|
|
The list of live in registers and successors can be empty. The language also
|
|
allows multiple live in register and successor lists - they are combined into
|
|
one list by the parser.
|
|
|
|
Miscellaneous Attributes
|
|
^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
The attributes ``IsAddressTaken``, ``IsLandingPad`` and ``Alignment`` can be
|
|
specified in brackets after the block's definition:
|
|
|
|
.. code-block:: text
|
|
|
|
bb.0.entry (address-taken):
|
|
<instructions>
|
|
bb.2.else (align 4):
|
|
<instructions>
|
|
bb.3(landing-pad, align 4):
|
|
<instructions>
|
|
|
|
.. TODO: Describe the way the reference to an unnamed LLVM IR block can be
|
|
preserved.
|
|
|
|
Machine Instructions
|
|
--------------------
|
|
|
|
A machine instruction is composed of a name,
|
|
:ref:`machine operands <machine-operands>`,
|
|
:ref:`instruction flags <instruction-flags>`, and machine memory operands.
|
|
|
|
The instruction's name is usually specified before the operands. The example
|
|
below shows an instance of the X86 ``RETQ`` instruction with a single machine
|
|
operand:
|
|
|
|
.. code-block:: text
|
|
|
|
RETQ $eax
|
|
|
|
However, if the machine instruction has one or more explicitly defined register
|
|
operands, the instruction's name has to be specified after them. The example
|
|
below shows an instance of the AArch64 ``LDPXpost`` instruction with three
|
|
defined register operands:
|
|
|
|
.. code-block:: text
|
|
|
|
$sp, $fp, $lr = LDPXpost $sp, 2
|
|
|
|
The instruction names are serialized using the exact definitions from the
|
|
target's ``*InstrInfo.td`` files, and they are case sensitive. This means that
|
|
similar instruction names like ``TSTri`` and ``tSTRi`` represent different
|
|
machine instructions.
|
|
|
|
.. _instruction-flags:
|
|
|
|
Instruction Flags
|
|
^^^^^^^^^^^^^^^^^
|
|
|
|
The flag ``frame-setup`` or ``frame-destroy`` can be specified before the
|
|
instruction's name:
|
|
|
|
.. code-block:: text
|
|
|
|
$fp = frame-setup ADDXri $sp, 0, 0
|
|
|
|
.. code-block:: text
|
|
|
|
$x21, $x20 = frame-destroy LDPXi $sp
|
|
|
|
.. _registers:
|
|
|
|
Bundled Instructions
|
|
^^^^^^^^^^^^^^^^^^^^
|
|
|
|
The syntax for bundled instructions is the following:
|
|
|
|
.. code-block:: text
|
|
|
|
BUNDLE implicit-def $r0, implicit-def $r1, implicit $r2 {
|
|
$r0 = SOME_OP $r2
|
|
$r1 = ANOTHER_OP internal $r0
|
|
}
|
|
|
|
The first instruction is often a bundle header. The instructions between ``{``
|
|
and ``}`` are bundled with the first instruction.
|
|
|
|
Registers
|
|
---------
|
|
|
|
Registers are one of the key primitives in the machine instructions
|
|
serialization language. They are primarily used in the
|
|
:ref:`register machine operands <register-operands>`,
|
|
but they can also be used in a number of other places, like the
|
|
:ref:`basic block's live in list <bb-liveins>`.
|
|
|
|
The physical registers are identified by their name and by the '$' prefix sigil.
|
|
They use the following syntax:
|
|
|
|
.. code-block:: text
|
|
|
|
$<name>
|
|
|
|
The example below shows three X86 physical registers:
|
|
|
|
.. code-block:: text
|
|
|
|
$eax
|
|
$r15
|
|
$eflags
|
|
|
|
The virtual registers are identified by their ID number and by the '%' sigil.
|
|
They use the following syntax:
|
|
|
|
.. code-block:: text
|
|
|
|
%<id>
|
|
|
|
Example:
|
|
|
|
.. code-block:: text
|
|
|
|
%0
|
|
|
|
The null registers are represented using an underscore ('``_``'). They can also be
|
|
represented using a '``$noreg``' named register, although the former syntax
|
|
is preferred.
|
|
|
|
.. _machine-operands:
|
|
|
|
Machine Operands
|
|
----------------
|
|
|
|
There are seventeen different kinds of machine operands, and all of them can be
|
|
serialized.
|
|
|
|
Immediate Operands
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
The immediate machine operands are untyped, 64-bit signed integers. The
|
|
example below shows an instance of the X86 ``MOV32ri`` instruction that has an
|
|
immediate machine operand ``-42``:
|
|
|
|
.. code-block:: text
|
|
|
|
$eax = MOV32ri -42
|
|
|
|
An immediate operand is also used to represent a subregister index when the
|
|
machine instruction has one of the following opcodes:
|
|
|
|
- ``EXTRACT_SUBREG``
|
|
|
|
- ``INSERT_SUBREG``
|
|
|
|
- ``REG_SEQUENCE``
|
|
|
|
- ``SUBREG_TO_REG``
|
|
|
|
In case this is true, the Machine Operand is printed according to the target.
|
|
|
|
For example:
|
|
|
|
In AArch64RegisterInfo.td:
|
|
|
|
.. code-block:: text
|
|
|
|
def sub_32 : SubRegIndex<32>;
|
|
|
|
If the third operand is an immediate with the value ``15`` (target-dependent
|
|
value), based on the instruction's opcode and the operand's index the operand
|
|
will be printed as ``%subreg.sub_32``:
|
|
|
|
.. code-block:: text
|
|
|
|
%1:gpr64 = SUBREG_TO_REG 0, %0, %subreg.sub_32
|
|
|
|
For integers > 64bit, we use a special machine operand, ``MO_CImmediate``,
|
|
which stores the immediate in a ``ConstantInt`` using an ``APInt`` (LLVM's
|
|
arbitrary precision integers).
|
|
|
|
.. TODO: Describe the FPIMM immediate operands.
|
|
|
|
.. _register-operands:
|
|
|
|
Register Operands
|
|
^^^^^^^^^^^^^^^^^
|
|
|
|
The :ref:`register <registers>` primitive is used to represent the register
|
|
machine operands. The register operands can also have optional
|
|
:ref:`register flags <register-flags>`,
|
|
:ref:`a subregister index <subregister-indices>`,
|
|
and a reference to the tied register operand.
|
|
The full syntax of a register operand is shown below:
|
|
|
|
.. code-block:: text
|
|
|
|
[<flags>] <register> [ :<subregister-idx-name> ] [ (tied-def <tied-op>) ]
|
|
|
|
This example shows an instance of the X86 ``XOR32rr`` instruction that has
|
|
5 register operands with different register flags:
|
|
|
|
.. code-block:: text
|
|
|
|
dead $eax = XOR32rr undef $eax, undef $eax, implicit-def dead $eflags, implicit-def $al
|
|
|
|
.. _register-flags:
|
|
|
|
Register Flags
|
|
~~~~~~~~~~~~~~
|
|
|
|
The table below shows all of the possible register flags along with the
|
|
corresponding internal ``llvm::RegState`` representation:
|
|
|
|
.. list-table::
|
|
:header-rows: 1
|
|
|
|
* - Flag
|
|
- Internal Value
|
|
|
|
* - ``implicit``
|
|
- ``RegState::Implicit``
|
|
|
|
* - ``implicit-def``
|
|
- ``RegState::ImplicitDefine``
|
|
|
|
* - ``def``
|
|
- ``RegState::Define``
|
|
|
|
* - ``dead``
|
|
- ``RegState::Dead``
|
|
|
|
* - ``killed``
|
|
- ``RegState::Kill``
|
|
|
|
* - ``undef``
|
|
- ``RegState::Undef``
|
|
|
|
* - ``internal``
|
|
- ``RegState::InternalRead``
|
|
|
|
* - ``early-clobber``
|
|
- ``RegState::EarlyClobber``
|
|
|
|
* - ``debug-use``
|
|
- ``RegState::Debug``
|
|
|
|
* - ``renamable``
|
|
- ``RegState::Renamable``
|
|
|
|
.. _subregister-indices:
|
|
|
|
Subregister Indices
|
|
~~~~~~~~~~~~~~~~~~~
|
|
|
|
The register machine operands can reference a portion of a register by using
|
|
the subregister indices. The example below shows an instance of the ``COPY``
|
|
pseudo instruction that uses the X86 ``sub_8bit`` subregister index to copy 8
|
|
lower bits from the 32-bit virtual register 0 to the 8-bit virtual register 1:
|
|
|
|
.. code-block:: text
|
|
|
|
%1 = COPY %0:sub_8bit
|
|
|
|
The names of the subregister indices are target specific, and are typically
|
|
defined in the target's ``*RegisterInfo.td`` file.
|
|
|
|
Constant Pool Indices
|
|
^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
A constant pool index (CPI) operand is printed using its index in the
|
|
function's ``MachineConstantPool`` and an offset.
|
|
|
|
For example, a CPI with the index 1 and offset 8:
|
|
|
|
.. code-block:: text
|
|
|
|
%1:gr64 = MOV64ri %const.1 + 8
|
|
|
|
For a CPI with the index 0 and offset -12:
|
|
|
|
.. code-block:: text
|
|
|
|
%1:gr64 = MOV64ri %const.0 - 12
|
|
|
|
A constant pool entry is bound to a LLVM IR ``Constant`` or a target-specific
|
|
``MachineConstantPoolValue``. When serializing all the function's constants the
|
|
following format is used:
|
|
|
|
.. code-block:: text
|
|
|
|
constants:
|
|
- id: <index>
|
|
value: <value>
|
|
alignment: <alignment>
|
|
isTargetSpecific: <target-specific>
|
|
|
|
where ``<index>`` is a 32-bit unsigned integer, ``<value>`` is a `LLVM IR Constant
|
|
<https://www.llvm.org/docs/LangRef.html#constants>`_, alignment is a 32-bit
|
|
unsigned integer, and ``<target-specific>`` is either true or false.
|
|
|
|
Example:
|
|
|
|
.. code-block:: text
|
|
|
|
constants:
|
|
- id: 0
|
|
value: 'double 3.250000e+00'
|
|
alignment: 8
|
|
- id: 1
|
|
value: 'g-(LPC0+8)'
|
|
alignment: 4
|
|
isTargetSpecific: true
|
|
|
|
Global Value Operands
|
|
^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
The global value machine operands reference the global values from the
|
|
:ref:`embedded LLVM IR module <embedded-module>`.
|
|
The example below shows an instance of the X86 ``MOV64rm`` instruction that has
|
|
a global value operand named ``G``:
|
|
|
|
.. code-block:: text
|
|
|
|
$rax = MOV64rm $rip, 1, _, @G, _
|
|
|
|
The named global values are represented using an identifier with the '@' prefix.
|
|
If the identifier doesn't match the regular expression
|
|
`[-a-zA-Z$._][-a-zA-Z$._0-9]*`, then this identifier must be quoted.
|
|
|
|
The unnamed global values are represented using an unsigned numeric value with
|
|
the '@' prefix, like in the following examples: ``@0``, ``@989``.
|
|
|
|
Target-dependent Index Operands
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
A target index operand is a target-specific index and an offset. The
|
|
target-specific index is printed using target-specific names and a positive or
|
|
negative offset.
|
|
|
|
For example, the ``amdgpu-constdata-start`` is associated with the index ``0``
|
|
in the AMDGPU backend. So if we have a target index operand with the index 0
|
|
and the offset 8:
|
|
|
|
.. code-block:: text
|
|
|
|
$sgpr2 = S_ADD_U32 _, target-index(amdgpu-constdata-start) + 8, implicit-def _, implicit-def _
|
|
|
|
Jump-table Index Operands
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
A jump-table index operand with the index 0 is printed as following:
|
|
|
|
.. code-block:: text
|
|
|
|
tBR_JTr killed $r0, %jump-table.0
|
|
|
|
A machine jump-table entry contains a list of ``MachineBasicBlocks``. When serializing all the function's jump-table entries, the following format is used:
|
|
|
|
.. code-block:: text
|
|
|
|
jumpTable:
|
|
kind: <kind>
|
|
entries:
|
|
- id: <index>
|
|
blocks: [ <bbreference>, <bbreference>, ... ]
|
|
|
|
where ``<kind>`` is describing how the jump table is represented and emitted (plain address, relocations, PIC, etc.), and each ``<index>`` is a 32-bit unsigned integer and ``blocks`` contains a list of :ref:`machine basic block references <block-references>`.
|
|
|
|
Example:
|
|
|
|
.. code-block:: text
|
|
|
|
jumpTable:
|
|
kind: inline
|
|
entries:
|
|
- id: 0
|
|
blocks: [ '%bb.3', '%bb.9', '%bb.4.d3' ]
|
|
- id: 1
|
|
blocks: [ '%bb.7', '%bb.7', '%bb.4.d3', '%bb.5' ]
|
|
|
|
External Symbol Operands
|
|
^^^^^^^^^^^^^^^^^^^^^^^^^
|
|
|
|
An external symbol operand is represented using an identifier with the ``&``
|
|
prefix. The identifier is surrounded with ""'s and escaped if it has any
|
|
special non-printable characters in it.
|
|
|
|
Example:
|
|
|
|
.. code-block:: text
|
|
|
|
CALL64pcrel32 &__stack_chk_fail, csr_64, implicit $rsp, implicit-def $rsp
|
|
|
|
MCSymbol Operands
|
|
^^^^^^^^^^^^^^^^^
|
|
|
|
A MCSymbol operand is holding a pointer to a ``MCSymbol``. For the limitations
|
|
of this operand in MIR, see :ref:`limitations <limitations>`.
|
|
|
|
The syntax is:
|
|
|
|
.. code-block:: text
|
|
|
|
EH_LABEL <mcsymbol Ltmp1>
|
|
|
|
CFIIndex Operands
|
|
^^^^^^^^^^^^^^^^^
|
|
|
|
A CFI Index operand is holding an index into a per-function side-table,
|
|
``MachineFunction::getFrameInstructions()``, which references all the frame
|
|
instructions in a ``MachineFunction``. A ``CFI_INSTRUCTION`` may look like it
|
|
contains multiple operands, but the only operand it contains is the CFI Index.
|
|
The other operands are tracked by the ``MCCFIInstruction`` object.
|
|
|
|
The syntax is:
|
|
|
|
.. code-block:: text
|
|
|
|
CFI_INSTRUCTION offset $w30, -16
|
|
|
|
which may be emitted later in the MC layer as:
|
|
|
|
.. code-block:: text
|
|
|
|
.cfi_offset w30, -16
|
|
|
|
IntrinsicID Operands
|
|
^^^^^^^^^^^^^^^^^^^^
|
|
|
|
An Intrinsic ID operand contains a generic intrinsic ID or a target-specific ID.
|
|
|
|
The syntax for the ``returnaddress`` intrinsic is:
|
|
|
|
.. code-block:: text
|
|
|
|
$x0 = COPY intrinsic(@llvm.returnaddress)
|
|
|
|
Predicate Operands
|
|
^^^^^^^^^^^^^^^^^^
|
|
|
|
A Predicate operand contains an IR predicate from ``CmpInst::Predicate``, like
|
|
``ICMP_EQ``, etc.
|
|
|
|
For an int eq predicate ``ICMP_EQ``, the syntax is:
|
|
|
|
.. code-block:: text
|
|
|
|
%2:gpr(s32) = G_ICMP intpred(eq), %0, %1
|
|
|
|
.. TODO: Describe the parsers default behaviour when optional YAML attributes
|
|
are missing.
|
|
.. TODO: Describe the syntax for virtual register YAML definitions.
|
|
.. TODO: Describe the machine function's YAML flag attributes.
|
|
.. TODO: Describe the syntax for the register mask machine operands.
|
|
.. TODO: Describe the frame information YAML mapping.
|
|
.. TODO: Describe the syntax of the stack object machine operands and their
|
|
YAML definitions.
|
|
.. TODO: Describe the syntax of the block address machine operands.
|
|
.. TODO: Describe the syntax of the metadata machine operands, and the
|
|
instructions debug location attribute.
|
|
.. TODO: Describe the syntax of the register live out machine operands.
|
|
.. TODO: Describe the syntax of the machine memory operands.
|