diff --git a/llvm/docs/GlobalISel/GenericOpcode.rst b/llvm/docs/GlobalISel/GenericOpcode.rst --- a/llvm/docs/GlobalISel/GenericOpcode.rst +++ b/llvm/docs/GlobalISel/GenericOpcode.rst @@ -798,9 +798,21 @@ G_JUMP_TABLE ^^^^^^^^^^^^ -.. caution:: +This generic jump table opcode generates a pointer to the address of the jump +table specified by the source operand, which is a jump table index. (A jump +table is an array of addresses the CPU should jump to based on certain +conditions.) +It can be used in conjunction with G_BRJT opcode to support jump table codegen +with GlobalISel. + +.. code-block:: none + + %dst:_(s32) = G_JUMP_TABLE %jump-table.0 + +The above example shows assignment of pointer to jump table of given index. +Source operand must be a jump table index. +Destination operand must have a pointer type. - I found no documentation for this instruction at the time of writing. G_INTRINSIC, G_INTRINSIC_W_SIDE_EFFECTS ^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^^