gotosocial/vendor/github.com/tetratelabs/wazero/internal/wasm/instruction.go

1867 lines
84 KiB
Go

package wasm
// Opcode is the binary Opcode of an instruction. See also InstructionName
type Opcode = byte
const (
// OpcodeUnreachable causes an unconditional trap.
OpcodeUnreachable Opcode = 0x00
// OpcodeNop does nothing
OpcodeNop Opcode = 0x01
// OpcodeBlock brackets a sequence of instructions. A branch instruction on an if label breaks out to after its
// OpcodeEnd.
OpcodeBlock Opcode = 0x02
// OpcodeLoop brackets a sequence of instructions. A branch instruction on a loop label will jump back to the
// beginning of its block.
OpcodeLoop Opcode = 0x03
// OpcodeIf brackets a sequence of instructions. When the top of the stack evaluates to 1, the block is executed.
// Zero jumps to the optional OpcodeElse. A branch instruction on an if label breaks out to after its OpcodeEnd.
OpcodeIf Opcode = 0x04
// OpcodeElse brackets a sequence of instructions enclosed by an OpcodeIf. A branch instruction on a then label
// breaks out to after the OpcodeEnd on the enclosing OpcodeIf.
OpcodeElse Opcode = 0x05
// OpcodeEnd terminates a control instruction OpcodeBlock, OpcodeLoop or OpcodeIf.
OpcodeEnd Opcode = 0x0b
// OpcodeBr is a stack-polymorphic opcode that performs an unconditional branch. How the stack is modified depends
// on whether the "br" is enclosed by a loop, and if CoreFeatureMultiValue is enabled.
//
// Here are the rules in pseudocode about how the stack is modified based on the "br" operand L (label):
// if L is loop: append(L.originalStackWithoutInputs, N-values popped from the stack) where N == L.inputs
// else: append(L.originalStackWithoutInputs, N-values popped from the stack) where N == L.results
//
// In WebAssembly 1.0 (20191205), N can be zero or one. When CoreFeatureMultiValue is enabled, N can be more than one,
// depending on the type use of the label L.
//
// See https://www.w3.org/TR/2019/REC-wasm-core-1-20191205/#-hrefsyntax-instr-controlmathsfbrl
OpcodeBr Opcode = 0x0c
OpcodeBrIf Opcode = 0x0d
OpcodeBrTable Opcode = 0x0e
OpcodeReturn Opcode = 0x0f
OpcodeCall Opcode = 0x10
OpcodeCallIndirect Opcode = 0x11
// parametric instructions
OpcodeDrop Opcode = 0x1a
OpcodeSelect Opcode = 0x1b
OpcodeTypedSelect Opcode = 0x1c
// variable instructions
OpcodeLocalGet Opcode = 0x20
OpcodeLocalSet Opcode = 0x21
OpcodeLocalTee Opcode = 0x22
OpcodeGlobalGet Opcode = 0x23
OpcodeGlobalSet Opcode = 0x24
// Below are toggled with CoreFeatureReferenceTypes
OpcodeTableGet Opcode = 0x25
OpcodeTableSet Opcode = 0x26
// memory instructions
OpcodeI32Load Opcode = 0x28
OpcodeI64Load Opcode = 0x29
OpcodeF32Load Opcode = 0x2a
OpcodeF64Load Opcode = 0x2b
OpcodeI32Load8S Opcode = 0x2c
OpcodeI32Load8U Opcode = 0x2d
OpcodeI32Load16S Opcode = 0x2e
OpcodeI32Load16U Opcode = 0x2f
OpcodeI64Load8S Opcode = 0x30
OpcodeI64Load8U Opcode = 0x31
OpcodeI64Load16S Opcode = 0x32
OpcodeI64Load16U Opcode = 0x33
OpcodeI64Load32S Opcode = 0x34
OpcodeI64Load32U Opcode = 0x35
OpcodeI32Store Opcode = 0x36
OpcodeI64Store Opcode = 0x37
OpcodeF32Store Opcode = 0x38
OpcodeF64Store Opcode = 0x39
OpcodeI32Store8 Opcode = 0x3a
OpcodeI32Store16 Opcode = 0x3b
OpcodeI64Store8 Opcode = 0x3c
OpcodeI64Store16 Opcode = 0x3d
OpcodeI64Store32 Opcode = 0x3e
OpcodeMemorySize Opcode = 0x3f
OpcodeMemoryGrow Opcode = 0x40
// const instructions
OpcodeI32Const Opcode = 0x41
OpcodeI64Const Opcode = 0x42
OpcodeF32Const Opcode = 0x43
OpcodeF64Const Opcode = 0x44
// numeric instructions
OpcodeI32Eqz Opcode = 0x45
OpcodeI32Eq Opcode = 0x46
OpcodeI32Ne Opcode = 0x47
OpcodeI32LtS Opcode = 0x48
OpcodeI32LtU Opcode = 0x49
OpcodeI32GtS Opcode = 0x4a
OpcodeI32GtU Opcode = 0x4b
OpcodeI32LeS Opcode = 0x4c
OpcodeI32LeU Opcode = 0x4d
OpcodeI32GeS Opcode = 0x4e
OpcodeI32GeU Opcode = 0x4f
OpcodeI64Eqz Opcode = 0x50
OpcodeI64Eq Opcode = 0x51
OpcodeI64Ne Opcode = 0x52
OpcodeI64LtS Opcode = 0x53
OpcodeI64LtU Opcode = 0x54
OpcodeI64GtS Opcode = 0x55
OpcodeI64GtU Opcode = 0x56
OpcodeI64LeS Opcode = 0x57
OpcodeI64LeU Opcode = 0x58
OpcodeI64GeS Opcode = 0x59
OpcodeI64GeU Opcode = 0x5a
OpcodeF32Eq Opcode = 0x5b
OpcodeF32Ne Opcode = 0x5c
OpcodeF32Lt Opcode = 0x5d
OpcodeF32Gt Opcode = 0x5e
OpcodeF32Le Opcode = 0x5f
OpcodeF32Ge Opcode = 0x60
OpcodeF64Eq Opcode = 0x61
OpcodeF64Ne Opcode = 0x62
OpcodeF64Lt Opcode = 0x63
OpcodeF64Gt Opcode = 0x64
OpcodeF64Le Opcode = 0x65
OpcodeF64Ge Opcode = 0x66
OpcodeI32Clz Opcode = 0x67
OpcodeI32Ctz Opcode = 0x68
OpcodeI32Popcnt Opcode = 0x69
OpcodeI32Add Opcode = 0x6a
OpcodeI32Sub Opcode = 0x6b
OpcodeI32Mul Opcode = 0x6c
OpcodeI32DivS Opcode = 0x6d
OpcodeI32DivU Opcode = 0x6e
OpcodeI32RemS Opcode = 0x6f
OpcodeI32RemU Opcode = 0x70
OpcodeI32And Opcode = 0x71
OpcodeI32Or Opcode = 0x72
OpcodeI32Xor Opcode = 0x73
OpcodeI32Shl Opcode = 0x74
OpcodeI32ShrS Opcode = 0x75
OpcodeI32ShrU Opcode = 0x76
OpcodeI32Rotl Opcode = 0x77
OpcodeI32Rotr Opcode = 0x78
OpcodeI64Clz Opcode = 0x79
OpcodeI64Ctz Opcode = 0x7a
OpcodeI64Popcnt Opcode = 0x7b
OpcodeI64Add Opcode = 0x7c
OpcodeI64Sub Opcode = 0x7d
OpcodeI64Mul Opcode = 0x7e
OpcodeI64DivS Opcode = 0x7f
OpcodeI64DivU Opcode = 0x80
OpcodeI64RemS Opcode = 0x81
OpcodeI64RemU Opcode = 0x82
OpcodeI64And Opcode = 0x83
OpcodeI64Or Opcode = 0x84
OpcodeI64Xor Opcode = 0x85
OpcodeI64Shl Opcode = 0x86
OpcodeI64ShrS Opcode = 0x87
OpcodeI64ShrU Opcode = 0x88
OpcodeI64Rotl Opcode = 0x89
OpcodeI64Rotr Opcode = 0x8a
OpcodeF32Abs Opcode = 0x8b
OpcodeF32Neg Opcode = 0x8c
OpcodeF32Ceil Opcode = 0x8d
OpcodeF32Floor Opcode = 0x8e
OpcodeF32Trunc Opcode = 0x8f
OpcodeF32Nearest Opcode = 0x90
OpcodeF32Sqrt Opcode = 0x91
OpcodeF32Add Opcode = 0x92
OpcodeF32Sub Opcode = 0x93
OpcodeF32Mul Opcode = 0x94
OpcodeF32Div Opcode = 0x95
OpcodeF32Min Opcode = 0x96
OpcodeF32Max Opcode = 0x97
OpcodeF32Copysign Opcode = 0x98
OpcodeF64Abs Opcode = 0x99
OpcodeF64Neg Opcode = 0x9a
OpcodeF64Ceil Opcode = 0x9b
OpcodeF64Floor Opcode = 0x9c
OpcodeF64Trunc Opcode = 0x9d
OpcodeF64Nearest Opcode = 0x9e
OpcodeF64Sqrt Opcode = 0x9f
OpcodeF64Add Opcode = 0xa0
OpcodeF64Sub Opcode = 0xa1
OpcodeF64Mul Opcode = 0xa2
OpcodeF64Div Opcode = 0xa3
OpcodeF64Min Opcode = 0xa4
OpcodeF64Max Opcode = 0xa5
OpcodeF64Copysign Opcode = 0xa6
OpcodeI32WrapI64 Opcode = 0xa7
OpcodeI32TruncF32S Opcode = 0xa8
OpcodeI32TruncF32U Opcode = 0xa9
OpcodeI32TruncF64S Opcode = 0xaa
OpcodeI32TruncF64U Opcode = 0xab
OpcodeI64ExtendI32S Opcode = 0xac
OpcodeI64ExtendI32U Opcode = 0xad
OpcodeI64TruncF32S Opcode = 0xae
OpcodeI64TruncF32U Opcode = 0xaf
OpcodeI64TruncF64S Opcode = 0xb0
OpcodeI64TruncF64U Opcode = 0xb1
OpcodeF32ConvertI32S Opcode = 0xb2
OpcodeF32ConvertI32U Opcode = 0xb3
OpcodeF32ConvertI64S Opcode = 0xb4
OpcodeF32ConvertI64U Opcode = 0xb5
OpcodeF32DemoteF64 Opcode = 0xb6
OpcodeF64ConvertI32S Opcode = 0xb7
OpcodeF64ConvertI32U Opcode = 0xb8
OpcodeF64ConvertI64S Opcode = 0xb9
OpcodeF64ConvertI64U Opcode = 0xba
OpcodeF64PromoteF32 Opcode = 0xbb
OpcodeI32ReinterpretF32 Opcode = 0xbc
OpcodeI64ReinterpretF64 Opcode = 0xbd
OpcodeF32ReinterpretI32 Opcode = 0xbe
OpcodeF64ReinterpretI64 Opcode = 0xbf
// OpcodeRefNull pushes a null reference value whose type is specified by immediate to this opcode.
// This is defined in the reference-types proposal, but necessary for CoreFeatureBulkMemoryOperations as well.
//
// Currently only supported in the constant expression in element segments.
OpcodeRefNull = 0xd0
// OpcodeRefIsNull pops a reference value, and pushes 1 if it is null, 0 otherwise.
// This is defined in the reference-types proposal, but necessary for CoreFeatureBulkMemoryOperations as well.
//
// Currently not supported.
OpcodeRefIsNull = 0xd1
// OpcodeRefFunc pushes a funcref value whose index equals the immediate to this opcode.
// This is defined in the reference-types proposal, but necessary for CoreFeatureBulkMemoryOperations as well.
//
// Currently, this is only supported in the constant expression in element segments.
OpcodeRefFunc = 0xd2
// Below are toggled with CoreFeatureSignExtensionOps
// OpcodeI32Extend8S extends a signed 8-bit integer to a 32-bit integer.
// Note: This is dependent on the flag CoreFeatureSignExtensionOps
OpcodeI32Extend8S Opcode = 0xc0
// OpcodeI32Extend16S extends a signed 16-bit integer to a 32-bit integer.
// Note: This is dependent on the flag CoreFeatureSignExtensionOps
OpcodeI32Extend16S Opcode = 0xc1
// OpcodeI64Extend8S extends a signed 8-bit integer to a 64-bit integer.
// Note: This is dependent on the flag CoreFeatureSignExtensionOps
OpcodeI64Extend8S Opcode = 0xc2
// OpcodeI64Extend16S extends a signed 16-bit integer to a 64-bit integer.
// Note: This is dependent on the flag CoreFeatureSignExtensionOps
OpcodeI64Extend16S Opcode = 0xc3
// OpcodeI64Extend32S extends a signed 32-bit integer to a 64-bit integer.
// Note: This is dependent on the flag CoreFeatureSignExtensionOps
OpcodeI64Extend32S Opcode = 0xc4
// OpcodeMiscPrefix is the prefix of various multi-byte opcodes.
// Introduced in CoreFeatureNonTrappingFloatToIntConversion, but used in other
// features, such as CoreFeatureBulkMemoryOperations.
OpcodeMiscPrefix Opcode = 0xfc
// OpcodeVecPrefix is the prefix of all vector isntructions introduced in
// CoreFeatureSIMD.
OpcodeVecPrefix Opcode = 0xfd
// OpcodeAtomicPrefix is the prefix of all atomic instructions introduced in
// CoreFeatureThreads.
OpcodeAtomicPrefix Opcode = 0xfe
)
// OpcodeMisc represents opcodes of the miscellaneous operations.
// Such an operations has multi-byte encoding which is prefixed by OpcodeMiscPrefix.
type OpcodeMisc = byte
const (
// Below are toggled with CoreFeatureNonTrappingFloatToIntConversion.
// https://github.com/WebAssembly/spec/blob/ce4b6c4d47eb06098cc7ab2e81f24748da822f20/proposals/nontrapping-float-to-int-conversion/Overview.md
OpcodeMiscI32TruncSatF32S OpcodeMisc = 0x00
OpcodeMiscI32TruncSatF32U OpcodeMisc = 0x01
OpcodeMiscI32TruncSatF64S OpcodeMisc = 0x02
OpcodeMiscI32TruncSatF64U OpcodeMisc = 0x03
OpcodeMiscI64TruncSatF32S OpcodeMisc = 0x04
OpcodeMiscI64TruncSatF32U OpcodeMisc = 0x05
OpcodeMiscI64TruncSatF64S OpcodeMisc = 0x06
OpcodeMiscI64TruncSatF64U OpcodeMisc = 0x07
// Below are toggled with CoreFeatureBulkMemoryOperations.
// Opcodes are those new in document/core/appendix/index-instructions.rst (the commit that merged the feature).
// See https://github.com/WebAssembly/spec/commit/7fa2f20a6df4cf1c114582c8cb60f5bfcdbf1be1
// See https://www.w3.org/TR/2022/WD-wasm-core-2-20220419/appendix/changes.html#bulk-memory-and-table-instructions
OpcodeMiscMemoryInit OpcodeMisc = 0x08
OpcodeMiscDataDrop OpcodeMisc = 0x09
OpcodeMiscMemoryCopy OpcodeMisc = 0x0a
OpcodeMiscMemoryFill OpcodeMisc = 0x0b
OpcodeMiscTableInit OpcodeMisc = 0x0c
OpcodeMiscElemDrop OpcodeMisc = 0x0d
OpcodeMiscTableCopy OpcodeMisc = 0x0e
// Below are toggled with CoreFeatureReferenceTypes
OpcodeMiscTableGrow OpcodeMisc = 0x0f
OpcodeMiscTableSize OpcodeMisc = 0x10
OpcodeMiscTableFill OpcodeMisc = 0x11
)
// OpcodeVec represents an opcode of a vector instructions which has
// multi-byte encoding and is prefixed by OpcodeMiscPrefix.
//
// These opcodes are toggled with CoreFeatureSIMD.
type OpcodeVec = byte
const (
// Loads and stores.
OpcodeVecV128Load OpcodeVec = 0x00
OpcodeVecV128Load8x8s OpcodeVec = 0x01
OpcodeVecV128Load8x8u OpcodeVec = 0x02
OpcodeVecV128Load16x4s OpcodeVec = 0x03
OpcodeVecV128Load16x4u OpcodeVec = 0x04
OpcodeVecV128Load32x2s OpcodeVec = 0x05
OpcodeVecV128Load32x2u OpcodeVec = 0x06
OpcodeVecV128Load8Splat OpcodeVec = 0x07
OpcodeVecV128Load16Splat OpcodeVec = 0x08
OpcodeVecV128Load32Splat OpcodeVec = 0x09
OpcodeVecV128Load64Splat OpcodeVec = 0x0a
OpcodeVecV128Load32zero OpcodeVec = 0x5c
OpcodeVecV128Load64zero OpcodeVec = 0x5d
OpcodeVecV128Store OpcodeVec = 0x0b
OpcodeVecV128Load8Lane OpcodeVec = 0x54
OpcodeVecV128Load16Lane OpcodeVec = 0x55
OpcodeVecV128Load32Lane OpcodeVec = 0x56
OpcodeVecV128Load64Lane OpcodeVec = 0x57
OpcodeVecV128Store8Lane OpcodeVec = 0x58
OpcodeVecV128Store16Lane OpcodeVec = 0x59
OpcodeVecV128Store32Lane OpcodeVec = 0x5a
OpcodeVecV128Store64Lane OpcodeVec = 0x5b
// OpcodeVecV128Const is the vector const instruction.
OpcodeVecV128Const OpcodeVec = 0x0c
// OpcodeVecV128i8x16Shuffle is the vector shuffle instruction.
OpcodeVecV128i8x16Shuffle OpcodeVec = 0x0d
// Extrac and replaces.
OpcodeVecI8x16ExtractLaneS OpcodeVec = 0x15
OpcodeVecI8x16ExtractLaneU OpcodeVec = 0x16
OpcodeVecI8x16ReplaceLane OpcodeVec = 0x17
OpcodeVecI16x8ExtractLaneS OpcodeVec = 0x18
OpcodeVecI16x8ExtractLaneU OpcodeVec = 0x19
OpcodeVecI16x8ReplaceLane OpcodeVec = 0x1a
OpcodeVecI32x4ExtractLane OpcodeVec = 0x1b
OpcodeVecI32x4ReplaceLane OpcodeVec = 0x1c
OpcodeVecI64x2ExtractLane OpcodeVec = 0x1d
OpcodeVecI64x2ReplaceLane OpcodeVec = 0x1e
OpcodeVecF32x4ExtractLane OpcodeVec = 0x1f
OpcodeVecF32x4ReplaceLane OpcodeVec = 0x20
OpcodeVecF64x2ExtractLane OpcodeVec = 0x21
OpcodeVecF64x2ReplaceLane OpcodeVec = 0x22
// Splat and swizzle.
OpcodeVecI8x16Swizzle OpcodeVec = 0x0e
OpcodeVecI8x16Splat OpcodeVec = 0x0f
OpcodeVecI16x8Splat OpcodeVec = 0x10
OpcodeVecI32x4Splat OpcodeVec = 0x11
OpcodeVecI64x2Splat OpcodeVec = 0x12
OpcodeVecF32x4Splat OpcodeVec = 0x13
OpcodeVecF64x2Splat OpcodeVec = 0x14
// i8 comparisons.
OpcodeVecI8x16Eq OpcodeVec = 0x23
OpcodeVecI8x16Ne OpcodeVec = 0x24
OpcodeVecI8x16LtS OpcodeVec = 0x25
OpcodeVecI8x16LtU OpcodeVec = 0x26
OpcodeVecI8x16GtS OpcodeVec = 0x27
OpcodeVecI8x16GtU OpcodeVec = 0x28
OpcodeVecI8x16LeS OpcodeVec = 0x29
OpcodeVecI8x16LeU OpcodeVec = 0x2a
OpcodeVecI8x16GeS OpcodeVec = 0x2b
OpcodeVecI8x16GeU OpcodeVec = 0x2c
// i16 comparisons.
OpcodeVecI16x8Eq OpcodeVec = 0x2d
OpcodeVecI16x8Ne OpcodeVec = 0x2e
OpcodeVecI16x8LtS OpcodeVec = 0x2f
OpcodeVecI16x8LtU OpcodeVec = 0x30
OpcodeVecI16x8GtS OpcodeVec = 0x31
OpcodeVecI16x8GtU OpcodeVec = 0x32
OpcodeVecI16x8LeS OpcodeVec = 0x33
OpcodeVecI16x8LeU OpcodeVec = 0x34
OpcodeVecI16x8GeS OpcodeVec = 0x35
OpcodeVecI16x8GeU OpcodeVec = 0x36
// i32 comparisons.
OpcodeVecI32x4Eq OpcodeVec = 0x37
OpcodeVecI32x4Ne OpcodeVec = 0x38
OpcodeVecI32x4LtS OpcodeVec = 0x39
OpcodeVecI32x4LtU OpcodeVec = 0x3a
OpcodeVecI32x4GtS OpcodeVec = 0x3b
OpcodeVecI32x4GtU OpcodeVec = 0x3c
OpcodeVecI32x4LeS OpcodeVec = 0x3d
OpcodeVecI32x4LeU OpcodeVec = 0x3e
OpcodeVecI32x4GeS OpcodeVec = 0x3f
OpcodeVecI32x4GeU OpcodeVec = 0x40
// i64 comparisons.
OpcodeVecI64x2Eq OpcodeVec = 0xd6
OpcodeVecI64x2Ne OpcodeVec = 0xd7
OpcodeVecI64x2LtS OpcodeVec = 0xd8
OpcodeVecI64x2GtS OpcodeVec = 0xd9
OpcodeVecI64x2LeS OpcodeVec = 0xda
OpcodeVecI64x2GeS OpcodeVec = 0xdb
// f32 comparisons.
OpcodeVecF32x4Eq OpcodeVec = 0x41
OpcodeVecF32x4Ne OpcodeVec = 0x42
OpcodeVecF32x4Lt OpcodeVec = 0x43
OpcodeVecF32x4Gt OpcodeVec = 0x44
OpcodeVecF32x4Le OpcodeVec = 0x45
OpcodeVecF32x4Ge OpcodeVec = 0x46
// f64 comparisons.
OpcodeVecF64x2Eq OpcodeVec = 0x47
OpcodeVecF64x2Ne OpcodeVec = 0x48
OpcodeVecF64x2Lt OpcodeVec = 0x49
OpcodeVecF64x2Gt OpcodeVec = 0x4a
OpcodeVecF64x2Le OpcodeVec = 0x4b
OpcodeVecF64x2Ge OpcodeVec = 0x4c
// v128 logical instructions.
OpcodeVecV128Not OpcodeVec = 0x4d
OpcodeVecV128And OpcodeVec = 0x4e
OpcodeVecV128AndNot OpcodeVec = 0x4f
OpcodeVecV128Or OpcodeVec = 0x50
OpcodeVecV128Xor OpcodeVec = 0x51
OpcodeVecV128Bitselect OpcodeVec = 0x52
OpcodeVecV128AnyTrue OpcodeVec = 0x53
// i8 misc.
OpcodeVecI8x16Abs OpcodeVec = 0x60
OpcodeVecI8x16Neg OpcodeVec = 0x61
OpcodeVecI8x16Popcnt OpcodeVec = 0x62
OpcodeVecI8x16AllTrue OpcodeVec = 0x63
OpcodeVecI8x16BitMask OpcodeVec = 0x64
OpcodeVecI8x16NarrowI16x8S OpcodeVec = 0x65
OpcodeVecI8x16NarrowI16x8U OpcodeVec = 0x66
OpcodeVecI8x16Shl OpcodeVec = 0x6b
OpcodeVecI8x16ShrS OpcodeVec = 0x6c
OpcodeVecI8x16ShrU OpcodeVec = 0x6d
OpcodeVecI8x16Add OpcodeVec = 0x6e
OpcodeVecI8x16AddSatS OpcodeVec = 0x6f
OpcodeVecI8x16AddSatU OpcodeVec = 0x70
OpcodeVecI8x16Sub OpcodeVec = 0x71
OpcodeVecI8x16SubSatS OpcodeVec = 0x72
OpcodeVecI8x16SubSatU OpcodeVec = 0x73
OpcodeVecI8x16MinS OpcodeVec = 0x76
OpcodeVecI8x16MinU OpcodeVec = 0x77
OpcodeVecI8x16MaxS OpcodeVec = 0x78
OpcodeVecI8x16MaxU OpcodeVec = 0x79
OpcodeVecI8x16AvgrU OpcodeVec = 0x7b
// i16 misc.
OpcodeVecI16x8ExtaddPairwiseI8x16S OpcodeVec = 0x7c
OpcodeVecI16x8ExtaddPairwiseI8x16U OpcodeVec = 0x7d
OpcodeVecI16x8Abs OpcodeVec = 0x80
OpcodeVecI16x8Neg OpcodeVec = 0x81
OpcodeVecI16x8Q15mulrSatS OpcodeVec = 0x82
OpcodeVecI16x8AllTrue OpcodeVec = 0x83
OpcodeVecI16x8BitMask OpcodeVec = 0x84
OpcodeVecI16x8NarrowI32x4S OpcodeVec = 0x85
OpcodeVecI16x8NarrowI32x4U OpcodeVec = 0x86
OpcodeVecI16x8ExtendLowI8x16S OpcodeVec = 0x87
OpcodeVecI16x8ExtendHighI8x16S OpcodeVec = 0x88
OpcodeVecI16x8ExtendLowI8x16U OpcodeVec = 0x89
OpcodeVecI16x8ExtendHighI8x16U OpcodeVec = 0x8a
OpcodeVecI16x8Shl OpcodeVec = 0x8b
OpcodeVecI16x8ShrS OpcodeVec = 0x8c
OpcodeVecI16x8ShrU OpcodeVec = 0x8d
OpcodeVecI16x8Add OpcodeVec = 0x8e
OpcodeVecI16x8AddSatS OpcodeVec = 0x8f
OpcodeVecI16x8AddSatU OpcodeVec = 0x90
OpcodeVecI16x8Sub OpcodeVec = 0x91
OpcodeVecI16x8SubSatS OpcodeVec = 0x92
OpcodeVecI16x8SubSatU OpcodeVec = 0x93
OpcodeVecI16x8Mul OpcodeVec = 0x95
OpcodeVecI16x8MinS OpcodeVec = 0x96
OpcodeVecI16x8MinU OpcodeVec = 0x97
OpcodeVecI16x8MaxS OpcodeVec = 0x98
OpcodeVecI16x8MaxU OpcodeVec = 0x99
OpcodeVecI16x8AvgrU OpcodeVec = 0x9b
OpcodeVecI16x8ExtMulLowI8x16S OpcodeVec = 0x9c
OpcodeVecI16x8ExtMulHighI8x16S OpcodeVec = 0x9d
OpcodeVecI16x8ExtMulLowI8x16U OpcodeVec = 0x9e
OpcodeVecI16x8ExtMulHighI8x16U OpcodeVec = 0x9f
// i32 misc.
OpcodeVecI32x4ExtaddPairwiseI16x8S OpcodeVec = 0x7e
OpcodeVecI32x4ExtaddPairwiseI16x8U OpcodeVec = 0x7f
OpcodeVecI32x4Abs OpcodeVec = 0xa0
OpcodeVecI32x4Neg OpcodeVec = 0xa1
OpcodeVecI32x4AllTrue OpcodeVec = 0xa3
OpcodeVecI32x4BitMask OpcodeVec = 0xa4
OpcodeVecI32x4ExtendLowI16x8S OpcodeVec = 0xa7
OpcodeVecI32x4ExtendHighI16x8S OpcodeVec = 0xa8
OpcodeVecI32x4ExtendLowI16x8U OpcodeVec = 0xa9
OpcodeVecI32x4ExtendHighI16x8U OpcodeVec = 0xaa
OpcodeVecI32x4Shl OpcodeVec = 0xab
OpcodeVecI32x4ShrS OpcodeVec = 0xac
OpcodeVecI32x4ShrU OpcodeVec = 0xad
OpcodeVecI32x4Add OpcodeVec = 0xae
OpcodeVecI32x4Sub OpcodeVec = 0xb1
OpcodeVecI32x4Mul OpcodeVec = 0xb5
OpcodeVecI32x4MinS OpcodeVec = 0xb6
OpcodeVecI32x4MinU OpcodeVec = 0xb7
OpcodeVecI32x4MaxS OpcodeVec = 0xb8
OpcodeVecI32x4MaxU OpcodeVec = 0xb9
OpcodeVecI32x4DotI16x8S OpcodeVec = 0xba
OpcodeVecI32x4ExtMulLowI16x8S OpcodeVec = 0xbc
OpcodeVecI32x4ExtMulHighI16x8S OpcodeVec = 0xbd
OpcodeVecI32x4ExtMulLowI16x8U OpcodeVec = 0xbe
OpcodeVecI32x4ExtMulHighI16x8U OpcodeVec = 0xbf
// i64 misc.
OpcodeVecI64x2Abs OpcodeVec = 0xc0
OpcodeVecI64x2Neg OpcodeVec = 0xc1
OpcodeVecI64x2AllTrue OpcodeVec = 0xc3
OpcodeVecI64x2BitMask OpcodeVec = 0xc4
OpcodeVecI64x2ExtendLowI32x4S OpcodeVec = 0xc7
OpcodeVecI64x2ExtendHighI32x4S OpcodeVec = 0xc8
OpcodeVecI64x2ExtendLowI32x4U OpcodeVec = 0xc9
OpcodeVecI64x2ExtendHighI32x4U OpcodeVec = 0xca
OpcodeVecI64x2Shl OpcodeVec = 0xcb
OpcodeVecI64x2ShrS OpcodeVec = 0xcc
OpcodeVecI64x2ShrU OpcodeVec = 0xcd
OpcodeVecI64x2Add OpcodeVec = 0xce
OpcodeVecI64x2Sub OpcodeVec = 0xd1
OpcodeVecI64x2Mul OpcodeVec = 0xd5
OpcodeVecI64x2ExtMulLowI32x4S OpcodeVec = 0xdc
OpcodeVecI64x2ExtMulHighI32x4S OpcodeVec = 0xdd
OpcodeVecI64x2ExtMulLowI32x4U OpcodeVec = 0xde
OpcodeVecI64x2ExtMulHighI32x4U OpcodeVec = 0xdf
// f32 misc.
OpcodeVecF32x4Ceil OpcodeVec = 0x67
OpcodeVecF32x4Floor OpcodeVec = 0x68
OpcodeVecF32x4Trunc OpcodeVec = 0x69
OpcodeVecF32x4Nearest OpcodeVec = 0x6a
OpcodeVecF32x4Abs OpcodeVec = 0xe0
OpcodeVecF32x4Neg OpcodeVec = 0xe1
OpcodeVecF32x4Sqrt OpcodeVec = 0xe3
OpcodeVecF32x4Add OpcodeVec = 0xe4
OpcodeVecF32x4Sub OpcodeVec = 0xe5
OpcodeVecF32x4Mul OpcodeVec = 0xe6
OpcodeVecF32x4Div OpcodeVec = 0xe7
OpcodeVecF32x4Min OpcodeVec = 0xe8
OpcodeVecF32x4Max OpcodeVec = 0xe9
OpcodeVecF32x4Pmin OpcodeVec = 0xea
OpcodeVecF32x4Pmax OpcodeVec = 0xeb
// f64 misc.
OpcodeVecF64x2Ceil OpcodeVec = 0x74
OpcodeVecF64x2Floor OpcodeVec = 0x75
OpcodeVecF64x2Trunc OpcodeVec = 0x7a
OpcodeVecF64x2Nearest OpcodeVec = 0x94
OpcodeVecF64x2Abs OpcodeVec = 0xec
OpcodeVecF64x2Neg OpcodeVec = 0xed
OpcodeVecF64x2Sqrt OpcodeVec = 0xef
OpcodeVecF64x2Add OpcodeVec = 0xf0
OpcodeVecF64x2Sub OpcodeVec = 0xf1
OpcodeVecF64x2Mul OpcodeVec = 0xf2
OpcodeVecF64x2Div OpcodeVec = 0xf3
OpcodeVecF64x2Min OpcodeVec = 0xf4
OpcodeVecF64x2Max OpcodeVec = 0xf5
OpcodeVecF64x2Pmin OpcodeVec = 0xf6
OpcodeVecF64x2Pmax OpcodeVec = 0xf7
// conversions.
OpcodeVecI32x4TruncSatF32x4S OpcodeVec = 0xf8
OpcodeVecI32x4TruncSatF32x4U OpcodeVec = 0xf9
OpcodeVecF32x4ConvertI32x4S OpcodeVec = 0xfa
OpcodeVecF32x4ConvertI32x4U OpcodeVec = 0xfb
OpcodeVecI32x4TruncSatF64x2SZero OpcodeVec = 0xfc
OpcodeVecI32x4TruncSatF64x2UZero OpcodeVec = 0xfd
OpcodeVecF64x2ConvertLowI32x4S OpcodeVec = 0xfe
OpcodeVecF64x2ConvertLowI32x4U OpcodeVec = 0xff
OpcodeVecF32x4DemoteF64x2Zero OpcodeVec = 0x5e
OpcodeVecF64x2PromoteLowF32x4Zero OpcodeVec = 0x5f
)
// OpcodeAtomic represents an opcode of atomic instructions which has
// multi-byte encoding and is prefixed by OpcodeAtomicPrefix.
//
// These opcodes are toggled with CoreFeaturesThreads.
type OpcodeAtomic = byte
const (
// OpcodeAtomicMemoryNotify represents the instruction memory.atomic.notify.
OpcodeAtomicMemoryNotify OpcodeAtomic = 0x00
// OpcodeAtomicMemoryWait32 represents the instruction memory.atomic.wait32.
OpcodeAtomicMemoryWait32 OpcodeAtomic = 0x01
// OpcodeAtomicMemoryWait64 represents the instruction memory.atomic.wait64.
OpcodeAtomicMemoryWait64 OpcodeAtomic = 0x02
// OpcodeAtomicFence represents the instruction atomic.fence.
OpcodeAtomicFence OpcodeAtomic = 0x03
// OpcodeAtomicI32Load represents the instruction i32.atomic.load.
OpcodeAtomicI32Load OpcodeAtomic = 0x10
// OpcodeAtomicI64Load represents the instruction i64.atomic.load.
OpcodeAtomicI64Load OpcodeAtomic = 0x11
// OpcodeAtomicI32Load8U represents the instruction i32.atomic.load8_u.
OpcodeAtomicI32Load8U OpcodeAtomic = 0x12
// OpcodeAtomicI32Load16U represents the instruction i32.atomic.load16_u.
OpcodeAtomicI32Load16U OpcodeAtomic = 0x13
// OpcodeAtomicI64Load8U represents the instruction i64.atomic.load8_u.
OpcodeAtomicI64Load8U OpcodeAtomic = 0x14
// OpcodeAtomicI64Load16U represents the instruction i64.atomic.load16_u.
OpcodeAtomicI64Load16U OpcodeAtomic = 0x15
// OpcodeAtomicI64Load32U represents the instruction i64.atomic.load32_u.
OpcodeAtomicI64Load32U OpcodeAtomic = 0x16
// OpcodeAtomicI32Store represents the instruction i32.atomic.store.
OpcodeAtomicI32Store OpcodeAtomic = 0x17
// OpcodeAtomicI64Store represents the instruction i64.atomic.store.
OpcodeAtomicI64Store OpcodeAtomic = 0x18
// OpcodeAtomicI32Store8 represents the instruction i32.atomic.store8.
OpcodeAtomicI32Store8 OpcodeAtomic = 0x19
// OpcodeAtomicI32Store16 represents the instruction i32.atomic.store16.
OpcodeAtomicI32Store16 OpcodeAtomic = 0x1a
// OpcodeAtomicI64Store8 represents the instruction i64.atomic.store8.
OpcodeAtomicI64Store8 OpcodeAtomic = 0x1b
// OpcodeAtomicI64Store16 represents the instruction i64.atomic.store16.
OpcodeAtomicI64Store16 OpcodeAtomic = 0x1c
// OpcodeAtomicI64Store32 represents the instruction i64.atomic.store32.
OpcodeAtomicI64Store32 OpcodeAtomic = 0x1d
// OpcodeAtomicI32RmwAdd represents the instruction i32.atomic.rmw.add.
OpcodeAtomicI32RmwAdd OpcodeAtomic = 0x1e
// OpcodeAtomicI64RmwAdd represents the instruction i64.atomic.rmw.add.
OpcodeAtomicI64RmwAdd OpcodeAtomic = 0x1f
// OpcodeAtomicI32Rmw8AddU represents the instruction i32.atomic.rmw8.add_u.
OpcodeAtomicI32Rmw8AddU OpcodeAtomic = 0x20
// OpcodeAtomicI32Rmw16AddU represents the instruction i32.atomic.rmw16.add_u.
OpcodeAtomicI32Rmw16AddU OpcodeAtomic = 0x21
// OpcodeAtomicI64Rmw8AddU represents the instruction i64.atomic.rmw8.add_u.
OpcodeAtomicI64Rmw8AddU OpcodeAtomic = 0x22
// OpcodeAtomicI64Rmw16AddU represents the instruction i64.atomic.rmw16.add_u.
OpcodeAtomicI64Rmw16AddU OpcodeAtomic = 0x23
// OpcodeAtomicI64Rmw32AddU represents the instruction i64.atomic.rmw32.add_u.
OpcodeAtomicI64Rmw32AddU OpcodeAtomic = 0x24
// OpcodeAtomicI32RmwSub represents the instruction i32.atomic.rmw.sub.
OpcodeAtomicI32RmwSub OpcodeAtomic = 0x25
// OpcodeAtomicI64RmwSub represents the instruction i64.atomic.rmw.sub.
OpcodeAtomicI64RmwSub OpcodeAtomic = 0x26
// OpcodeAtomicI32Rmw8SubU represents the instruction i32.atomic.rmw8.sub_u.
OpcodeAtomicI32Rmw8SubU OpcodeAtomic = 0x27
// OpcodeAtomicI32Rmw16SubU represents the instruction i32.atomic.rmw16.sub_u.
OpcodeAtomicI32Rmw16SubU OpcodeAtomic = 0x28
// OpcodeAtomicI64Rmw8SubU represents the instruction i64.atomic.rmw8.sub_u.
OpcodeAtomicI64Rmw8SubU OpcodeAtomic = 0x29
// OpcodeAtomicI64Rmw16SubU represents the instruction i64.atomic.rmw16.sub_u.
OpcodeAtomicI64Rmw16SubU OpcodeAtomic = 0x2a
// OpcodeAtomicI64Rmw32SubU represents the instruction i64.atomic.rmw32.sub_u.
OpcodeAtomicI64Rmw32SubU OpcodeAtomic = 0x2b
// OpcodeAtomicI32RmwAnd represents the instruction i32.atomic.rmw.and.
OpcodeAtomicI32RmwAnd OpcodeAtomic = 0x2c
// OpcodeAtomicI64RmwAnd represents the instruction i64.atomic.rmw.and.
OpcodeAtomicI64RmwAnd OpcodeAtomic = 0x2d
// OpcodeAtomicI32Rmw8AndU represents the instruction i32.atomic.rmw8.and_u.
OpcodeAtomicI32Rmw8AndU OpcodeAtomic = 0x2e
// OpcodeAtomicI32Rmw16AndU represents the instruction i32.atomic.rmw16.and_u.
OpcodeAtomicI32Rmw16AndU OpcodeAtomic = 0x2f
// OpcodeAtomicI64Rmw8AndU represents the instruction i64.atomic.rmw8.and_u.
OpcodeAtomicI64Rmw8AndU OpcodeAtomic = 0x30
// OpcodeAtomicI64Rmw16AndU represents the instruction i64.atomic.rmw16.and_u.
OpcodeAtomicI64Rmw16AndU OpcodeAtomic = 0x31
// OpcodeAtomicI64Rmw32AndU represents the instruction i64.atomic.rmw32.and_u.
OpcodeAtomicI64Rmw32AndU OpcodeAtomic = 0x32
// OpcodeAtomicI32RmwOr represents the instruction i32.atomic.rmw.or.
OpcodeAtomicI32RmwOr OpcodeAtomic = 0x33
// OpcodeAtomicI64RmwOr represents the instruction i64.atomic.rmw.or.
OpcodeAtomicI64RmwOr OpcodeAtomic = 0x34
// OpcodeAtomicI32Rmw8OrU represents the instruction i32.atomic.rmw8.or_u.
OpcodeAtomicI32Rmw8OrU OpcodeAtomic = 0x35
// OpcodeAtomicI32Rmw16OrU represents the instruction i32.atomic.rmw16.or_u.
OpcodeAtomicI32Rmw16OrU OpcodeAtomic = 0x36
// OpcodeAtomicI64Rmw8OrU represents the instruction i64.atomic.rmw8.or_u.
OpcodeAtomicI64Rmw8OrU OpcodeAtomic = 0x37
// OpcodeAtomicI64Rmw16OrU represents the instruction i64.atomic.rmw16.or_u.
OpcodeAtomicI64Rmw16OrU OpcodeAtomic = 0x38
// OpcodeAtomicI64Rmw32OrU represents the instruction i64.atomic.rmw32.or_u.
OpcodeAtomicI64Rmw32OrU OpcodeAtomic = 0x39
// OpcodeAtomicI32RmwXor represents the instruction i32.atomic.rmw.xor.
OpcodeAtomicI32RmwXor OpcodeAtomic = 0x3a
// OpcodeAtomicI64RmwXor represents the instruction i64.atomic.rmw.xor.
OpcodeAtomicI64RmwXor OpcodeAtomic = 0x3b
// OpcodeAtomicI32Rmw8XorU represents the instruction i32.atomic.rmw8.xor_u.
OpcodeAtomicI32Rmw8XorU OpcodeAtomic = 0x3c
// OpcodeAtomicI32Rmw16XorU represents the instruction i32.atomic.rmw16.xor_u.
OpcodeAtomicI32Rmw16XorU OpcodeAtomic = 0x3d
// OpcodeAtomicI64Rmw8XorU represents the instruction i64.atomic.rmw8.xor_u.
OpcodeAtomicI64Rmw8XorU OpcodeAtomic = 0x3e
// OpcodeAtomicI64Rmw16XorU represents the instruction i64.atomic.rmw16.xor_u.
OpcodeAtomicI64Rmw16XorU OpcodeAtomic = 0x3f
// OpcodeAtomicI64Rmw32XorU represents the instruction i64.atomic.rmw32.xor_u.
OpcodeAtomicI64Rmw32XorU OpcodeAtomic = 0x40
// OpcodeAtomicI32RmwXchg represents the instruction i32.atomic.rmw.xchg.
OpcodeAtomicI32RmwXchg OpcodeAtomic = 0x41
// OpcodeAtomicI64RmwXchg represents the instruction i64.atomic.rmw.xchg.
OpcodeAtomicI64RmwXchg OpcodeAtomic = 0x42
// OpcodeAtomicI32Rmw8XchgU represents the instruction i32.atomic.rmw8.xchg_u.
OpcodeAtomicI32Rmw8XchgU OpcodeAtomic = 0x43
// OpcodeAtomicI32Rmw16XchgU represents the instruction i32.atomic.rmw16.xchg_u.
OpcodeAtomicI32Rmw16XchgU OpcodeAtomic = 0x44
// OpcodeAtomicI64Rmw8XchgU represents the instruction i64.atomic.rmw8.xchg_u.
OpcodeAtomicI64Rmw8XchgU OpcodeAtomic = 0x45
// OpcodeAtomicI64Rmw16XchgU represents the instruction i64.atomic.rmw16.xchg_u.
OpcodeAtomicI64Rmw16XchgU OpcodeAtomic = 0x46
// OpcodeAtomicI64Rmw32XchgU represents the instruction i64.atomic.rmw32.xchg_u.
OpcodeAtomicI64Rmw32XchgU OpcodeAtomic = 0x47
// OpcodeAtomicI32RmwCmpxchg represents the instruction i32.atomic.rmw.cmpxchg.
OpcodeAtomicI32RmwCmpxchg OpcodeAtomic = 0x48
// OpcodeAtomicI64RmwCmpxchg represents the instruction i64.atomic.rmw.cmpxchg.
OpcodeAtomicI64RmwCmpxchg OpcodeAtomic = 0x49
// OpcodeAtomicI32Rmw8CmpxchgU represents the instruction i32.atomic.rmw8.cmpxchg_u.
OpcodeAtomicI32Rmw8CmpxchgU OpcodeAtomic = 0x4a
// OpcodeAtomicI32Rmw16CmpxchgU represents the instruction i32.atomic.rmw16.cmpxchg_u.
OpcodeAtomicI32Rmw16CmpxchgU OpcodeAtomic = 0x4b
// OpcodeAtomicI64Rmw8CmpxchgU represents the instruction i64.atomic.rmw8.cmpxchg_u.
OpcodeAtomicI64Rmw8CmpxchgU OpcodeAtomic = 0x4c
// OpcodeAtomicI64Rmw16CmpxchgU represents the instruction i64.atomic.rmw16.cmpxchg_u.
OpcodeAtomicI64Rmw16CmpxchgU OpcodeAtomic = 0x4d
// OpcodeAtomicI64Rmw32CmpxchgU represents the instruction i64.atomic.rmw32.cmpxchg_u.
OpcodeAtomicI64Rmw32CmpxchgU OpcodeAtomic = 0x4e
)
const (
OpcodeUnreachableName = "unreachable"
OpcodeNopName = "nop"
OpcodeBlockName = "block"
OpcodeLoopName = "loop"
OpcodeIfName = "if"
OpcodeElseName = "else"
OpcodeEndName = "end"
OpcodeBrName = "br"
OpcodeBrIfName = "br_if"
OpcodeBrTableName = "br_table"
OpcodeReturnName = "return"
OpcodeCallName = "call"
OpcodeCallIndirectName = "call_indirect"
OpcodeDropName = "drop"
OpcodeSelectName = "select"
OpcodeTypedSelectName = "typed_select"
OpcodeLocalGetName = "local.get"
OpcodeLocalSetName = "local.set"
OpcodeLocalTeeName = "local.tee"
OpcodeGlobalGetName = "global.get"
OpcodeGlobalSetName = "global.set"
OpcodeI32LoadName = "i32.load"
OpcodeI64LoadName = "i64.load"
OpcodeF32LoadName = "f32.load"
OpcodeF64LoadName = "f64.load"
OpcodeI32Load8SName = "i32.load8_s"
OpcodeI32Load8UName = "i32.load8_u"
OpcodeI32Load16SName = "i32.load16_s"
OpcodeI32Load16UName = "i32.load16_u"
OpcodeI64Load8SName = "i64.load8_s"
OpcodeI64Load8UName = "i64.load8_u"
OpcodeI64Load16SName = "i64.load16_s"
OpcodeI64Load16UName = "i64.load16_u"
OpcodeI64Load32SName = "i64.load32_s"
OpcodeI64Load32UName = "i64.load32_u"
OpcodeI32StoreName = "i32.store"
OpcodeI64StoreName = "i64.store"
OpcodeF32StoreName = "f32.store"
OpcodeF64StoreName = "f64.store"
OpcodeI32Store8Name = "i32.store8"
OpcodeI32Store16Name = "i32.store16"
OpcodeI64Store8Name = "i64.store8"
OpcodeI64Store16Name = "i64.store16"
OpcodeI64Store32Name = "i64.store32"
OpcodeMemorySizeName = "memory.size"
OpcodeMemoryGrowName = "memory.grow"
OpcodeI32ConstName = "i32.const"
OpcodeI64ConstName = "i64.const"
OpcodeF32ConstName = "f32.const"
OpcodeF64ConstName = "f64.const"
OpcodeI32EqzName = "i32.eqz"
OpcodeI32EqName = "i32.eq"
OpcodeI32NeName = "i32.ne"
OpcodeI32LtSName = "i32.lt_s"
OpcodeI32LtUName = "i32.lt_u"
OpcodeI32GtSName = "i32.gt_s"
OpcodeI32GtUName = "i32.gt_u"
OpcodeI32LeSName = "i32.le_s"
OpcodeI32LeUName = "i32.le_u"
OpcodeI32GeSName = "i32.ge_s"
OpcodeI32GeUName = "i32.ge_u"
OpcodeI64EqzName = "i64.eqz"
OpcodeI64EqName = "i64.eq"
OpcodeI64NeName = "i64.ne"
OpcodeI64LtSName = "i64.lt_s"
OpcodeI64LtUName = "i64.lt_u"
OpcodeI64GtSName = "i64.gt_s"
OpcodeI64GtUName = "i64.gt_u"
OpcodeI64LeSName = "i64.le_s"
OpcodeI64LeUName = "i64.le_u"
OpcodeI64GeSName = "i64.ge_s"
OpcodeI64GeUName = "i64.ge_u"
OpcodeF32EqName = "f32.eq"
OpcodeF32NeName = "f32.ne"
OpcodeF32LtName = "f32.lt"
OpcodeF32GtName = "f32.gt"
OpcodeF32LeName = "f32.le"
OpcodeF32GeName = "f32.ge"
OpcodeF64EqName = "f64.eq"
OpcodeF64NeName = "f64.ne"
OpcodeF64LtName = "f64.lt"
OpcodeF64GtName = "f64.gt"
OpcodeF64LeName = "f64.le"
OpcodeF64GeName = "f64.ge"
OpcodeI32ClzName = "i32.clz"
OpcodeI32CtzName = "i32.ctz"
OpcodeI32PopcntName = "i32.popcnt"
OpcodeI32AddName = "i32.add"
OpcodeI32SubName = "i32.sub"
OpcodeI32MulName = "i32.mul"
OpcodeI32DivSName = "i32.div_s"
OpcodeI32DivUName = "i32.div_u"
OpcodeI32RemSName = "i32.rem_s"
OpcodeI32RemUName = "i32.rem_u"
OpcodeI32AndName = "i32.and"
OpcodeI32OrName = "i32.or"
OpcodeI32XorName = "i32.xor"
OpcodeI32ShlName = "i32.shl"
OpcodeI32ShrSName = "i32.shr_s"
OpcodeI32ShrUName = "i32.shr_u"
OpcodeI32RotlName = "i32.rotl"
OpcodeI32RotrName = "i32.rotr"
OpcodeI64ClzName = "i64.clz"
OpcodeI64CtzName = "i64.ctz"
OpcodeI64PopcntName = "i64.popcnt"
OpcodeI64AddName = "i64.add"
OpcodeI64SubName = "i64.sub"
OpcodeI64MulName = "i64.mul"
OpcodeI64DivSName = "i64.div_s"
OpcodeI64DivUName = "i64.div_u"
OpcodeI64RemSName = "i64.rem_s"
OpcodeI64RemUName = "i64.rem_u"
OpcodeI64AndName = "i64.and"
OpcodeI64OrName = "i64.or"
OpcodeI64XorName = "i64.xor"
OpcodeI64ShlName = "i64.shl"
OpcodeI64ShrSName = "i64.shr_s"
OpcodeI64ShrUName = "i64.shr_u"
OpcodeI64RotlName = "i64.rotl"
OpcodeI64RotrName = "i64.rotr"
OpcodeF32AbsName = "f32.abs"
OpcodeF32NegName = "f32.neg"
OpcodeF32CeilName = "f32.ceil"
OpcodeF32FloorName = "f32.floor"
OpcodeF32TruncName = "f32.trunc"
OpcodeF32NearestName = "f32.nearest"
OpcodeF32SqrtName = "f32.sqrt"
OpcodeF32AddName = "f32.add"
OpcodeF32SubName = "f32.sub"
OpcodeF32MulName = "f32.mul"
OpcodeF32DivName = "f32.div"
OpcodeF32MinName = "f32.min"
OpcodeF32MaxName = "f32.max"
OpcodeF32CopysignName = "f32.copysign"
OpcodeF64AbsName = "f64.abs"
OpcodeF64NegName = "f64.neg"
OpcodeF64CeilName = "f64.ceil"
OpcodeF64FloorName = "f64.floor"
OpcodeF64TruncName = "f64.trunc"
OpcodeF64NearestName = "f64.nearest"
OpcodeF64SqrtName = "f64.sqrt"
OpcodeF64AddName = "f64.add"
OpcodeF64SubName = "f64.sub"
OpcodeF64MulName = "f64.mul"
OpcodeF64DivName = "f64.div"
OpcodeF64MinName = "f64.min"
OpcodeF64MaxName = "f64.max"
OpcodeF64CopysignName = "f64.copysign"
OpcodeI32WrapI64Name = "i32.wrap_i64"
OpcodeI32TruncF32SName = "i32.trunc_f32_s"
OpcodeI32TruncF32UName = "i32.trunc_f32_u"
OpcodeI32TruncF64SName = "i32.trunc_f64_s"
OpcodeI32TruncF64UName = "i32.trunc_f64_u"
OpcodeI64ExtendI32SName = "i64.extend_i32_s"
OpcodeI64ExtendI32UName = "i64.extend_i32_u"
OpcodeI64TruncF32SName = "i64.trunc_f32_s"
OpcodeI64TruncF32UName = "i64.trunc_f32_u"
OpcodeI64TruncF64SName = "i64.trunc_f64_s"
OpcodeI64TruncF64UName = "i64.trunc_f64_u"
OpcodeF32ConvertI32SName = "f32.convert_i32_s"
OpcodeF32ConvertI32UName = "f32.convert_i32_u"
OpcodeF32ConvertI64SName = "f32.convert_i64_s"
OpcodeF32ConvertI64UName = "f32.convert_i64u"
OpcodeF32DemoteF64Name = "f32.demote_f64"
OpcodeF64ConvertI32SName = "f64.convert_i32_s"
OpcodeF64ConvertI32UName = "f64.convert_i32_u"
OpcodeF64ConvertI64SName = "f64.convert_i64_s"
OpcodeF64ConvertI64UName = "f64.convert_i64_u"
OpcodeF64PromoteF32Name = "f64.promote_f32"
OpcodeI32ReinterpretF32Name = "i32.reinterpret_f32"
OpcodeI64ReinterpretF64Name = "i64.reinterpret_f64"
OpcodeF32ReinterpretI32Name = "f32.reinterpret_i32"
OpcodeF64ReinterpretI64Name = "f64.reinterpret_i64"
OpcodeRefNullName = "ref.null"
OpcodeRefIsNullName = "ref.is_null"
OpcodeRefFuncName = "ref.func"
OpcodeTableGetName = "table.get"
OpcodeTableSetName = "table.set"
// Below are toggled with CoreFeatureSignExtensionOps
OpcodeI32Extend8SName = "i32.extend8_s"
OpcodeI32Extend16SName = "i32.extend16_s"
OpcodeI64Extend8SName = "i64.extend8_s"
OpcodeI64Extend16SName = "i64.extend16_s"
OpcodeI64Extend32SName = "i64.extend32_s"
OpcodeMiscPrefixName = "misc_prefix"
OpcodeVecPrefixName = "vector_prefix"
OpcodeAtomicPrefixName = "atomic_prefix"
)
var instructionNames = [256]string{
OpcodeUnreachable: OpcodeUnreachableName,
OpcodeNop: OpcodeNopName,
OpcodeBlock: OpcodeBlockName,
OpcodeLoop: OpcodeLoopName,
OpcodeIf: OpcodeIfName,
OpcodeElse: OpcodeElseName,
OpcodeEnd: OpcodeEndName,
OpcodeBr: OpcodeBrName,
OpcodeBrIf: OpcodeBrIfName,
OpcodeBrTable: OpcodeBrTableName,
OpcodeReturn: OpcodeReturnName,
OpcodeCall: OpcodeCallName,
OpcodeCallIndirect: OpcodeCallIndirectName,
OpcodeDrop: OpcodeDropName,
OpcodeSelect: OpcodeSelectName,
OpcodeTypedSelect: OpcodeTypedSelectName,
OpcodeLocalGet: OpcodeLocalGetName,
OpcodeLocalSet: OpcodeLocalSetName,
OpcodeLocalTee: OpcodeLocalTeeName,
OpcodeGlobalGet: OpcodeGlobalGetName,
OpcodeGlobalSet: OpcodeGlobalSetName,
OpcodeI32Load: OpcodeI32LoadName,
OpcodeI64Load: OpcodeI64LoadName,
OpcodeF32Load: OpcodeF32LoadName,
OpcodeF64Load: OpcodeF64LoadName,
OpcodeI32Load8S: OpcodeI32Load8SName,
OpcodeI32Load8U: OpcodeI32Load8UName,
OpcodeI32Load16S: OpcodeI32Load16SName,
OpcodeI32Load16U: OpcodeI32Load16UName,
OpcodeI64Load8S: OpcodeI64Load8SName,
OpcodeI64Load8U: OpcodeI64Load8UName,
OpcodeI64Load16S: OpcodeI64Load16SName,
OpcodeI64Load16U: OpcodeI64Load16UName,
OpcodeI64Load32S: OpcodeI64Load32SName,
OpcodeI64Load32U: OpcodeI64Load32UName,
OpcodeI32Store: OpcodeI32StoreName,
OpcodeI64Store: OpcodeI64StoreName,
OpcodeF32Store: OpcodeF32StoreName,
OpcodeF64Store: OpcodeF64StoreName,
OpcodeI32Store8: OpcodeI32Store8Name,
OpcodeI32Store16: OpcodeI32Store16Name,
OpcodeI64Store8: OpcodeI64Store8Name,
OpcodeI64Store16: OpcodeI64Store16Name,
OpcodeI64Store32: OpcodeI64Store32Name,
OpcodeMemorySize: OpcodeMemorySizeName,
OpcodeMemoryGrow: OpcodeMemoryGrowName,
OpcodeI32Const: OpcodeI32ConstName,
OpcodeI64Const: OpcodeI64ConstName,
OpcodeF32Const: OpcodeF32ConstName,
OpcodeF64Const: OpcodeF64ConstName,
OpcodeI32Eqz: OpcodeI32EqzName,
OpcodeI32Eq: OpcodeI32EqName,
OpcodeI32Ne: OpcodeI32NeName,
OpcodeI32LtS: OpcodeI32LtSName,
OpcodeI32LtU: OpcodeI32LtUName,
OpcodeI32GtS: OpcodeI32GtSName,
OpcodeI32GtU: OpcodeI32GtUName,
OpcodeI32LeS: OpcodeI32LeSName,
OpcodeI32LeU: OpcodeI32LeUName,
OpcodeI32GeS: OpcodeI32GeSName,
OpcodeI32GeU: OpcodeI32GeUName,
OpcodeI64Eqz: OpcodeI64EqzName,
OpcodeI64Eq: OpcodeI64EqName,
OpcodeI64Ne: OpcodeI64NeName,
OpcodeI64LtS: OpcodeI64LtSName,
OpcodeI64LtU: OpcodeI64LtUName,
OpcodeI64GtS: OpcodeI64GtSName,
OpcodeI64GtU: OpcodeI64GtUName,
OpcodeI64LeS: OpcodeI64LeSName,
OpcodeI64LeU: OpcodeI64LeUName,
OpcodeI64GeS: OpcodeI64GeSName,
OpcodeI64GeU: OpcodeI64GeUName,
OpcodeF32Eq: OpcodeF32EqName,
OpcodeF32Ne: OpcodeF32NeName,
OpcodeF32Lt: OpcodeF32LtName,
OpcodeF32Gt: OpcodeF32GtName,
OpcodeF32Le: OpcodeF32LeName,
OpcodeF32Ge: OpcodeF32GeName,
OpcodeF64Eq: OpcodeF64EqName,
OpcodeF64Ne: OpcodeF64NeName,
OpcodeF64Lt: OpcodeF64LtName,
OpcodeF64Gt: OpcodeF64GtName,
OpcodeF64Le: OpcodeF64LeName,
OpcodeF64Ge: OpcodeF64GeName,
OpcodeI32Clz: OpcodeI32ClzName,
OpcodeI32Ctz: OpcodeI32CtzName,
OpcodeI32Popcnt: OpcodeI32PopcntName,
OpcodeI32Add: OpcodeI32AddName,
OpcodeI32Sub: OpcodeI32SubName,
OpcodeI32Mul: OpcodeI32MulName,
OpcodeI32DivS: OpcodeI32DivSName,
OpcodeI32DivU: OpcodeI32DivUName,
OpcodeI32RemS: OpcodeI32RemSName,
OpcodeI32RemU: OpcodeI32RemUName,
OpcodeI32And: OpcodeI32AndName,
OpcodeI32Or: OpcodeI32OrName,
OpcodeI32Xor: OpcodeI32XorName,
OpcodeI32Shl: OpcodeI32ShlName,
OpcodeI32ShrS: OpcodeI32ShrSName,
OpcodeI32ShrU: OpcodeI32ShrUName,
OpcodeI32Rotl: OpcodeI32RotlName,
OpcodeI32Rotr: OpcodeI32RotrName,
OpcodeI64Clz: OpcodeI64ClzName,
OpcodeI64Ctz: OpcodeI64CtzName,
OpcodeI64Popcnt: OpcodeI64PopcntName,
OpcodeI64Add: OpcodeI64AddName,
OpcodeI64Sub: OpcodeI64SubName,
OpcodeI64Mul: OpcodeI64MulName,
OpcodeI64DivS: OpcodeI64DivSName,
OpcodeI64DivU: OpcodeI64DivUName,
OpcodeI64RemS: OpcodeI64RemSName,
OpcodeI64RemU: OpcodeI64RemUName,
OpcodeI64And: OpcodeI64AndName,
OpcodeI64Or: OpcodeI64OrName,
OpcodeI64Xor: OpcodeI64XorName,
OpcodeI64Shl: OpcodeI64ShlName,
OpcodeI64ShrS: OpcodeI64ShrSName,
OpcodeI64ShrU: OpcodeI64ShrUName,
OpcodeI64Rotl: OpcodeI64RotlName,
OpcodeI64Rotr: OpcodeI64RotrName,
OpcodeF32Abs: OpcodeF32AbsName,
OpcodeF32Neg: OpcodeF32NegName,
OpcodeF32Ceil: OpcodeF32CeilName,
OpcodeF32Floor: OpcodeF32FloorName,
OpcodeF32Trunc: OpcodeF32TruncName,
OpcodeF32Nearest: OpcodeF32NearestName,
OpcodeF32Sqrt: OpcodeF32SqrtName,
OpcodeF32Add: OpcodeF32AddName,
OpcodeF32Sub: OpcodeF32SubName,
OpcodeF32Mul: OpcodeF32MulName,
OpcodeF32Div: OpcodeF32DivName,
OpcodeF32Min: OpcodeF32MinName,
OpcodeF32Max: OpcodeF32MaxName,
OpcodeF32Copysign: OpcodeF32CopysignName,
OpcodeF64Abs: OpcodeF64AbsName,
OpcodeF64Neg: OpcodeF64NegName,
OpcodeF64Ceil: OpcodeF64CeilName,
OpcodeF64Floor: OpcodeF64FloorName,
OpcodeF64Trunc: OpcodeF64TruncName,
OpcodeF64Nearest: OpcodeF64NearestName,
OpcodeF64Sqrt: OpcodeF64SqrtName,
OpcodeF64Add: OpcodeF64AddName,
OpcodeF64Sub: OpcodeF64SubName,
OpcodeF64Mul: OpcodeF64MulName,
OpcodeF64Div: OpcodeF64DivName,
OpcodeF64Min: OpcodeF64MinName,
OpcodeF64Max: OpcodeF64MaxName,
OpcodeF64Copysign: OpcodeF64CopysignName,
OpcodeI32WrapI64: OpcodeI32WrapI64Name,
OpcodeI32TruncF32S: OpcodeI32TruncF32SName,
OpcodeI32TruncF32U: OpcodeI32TruncF32UName,
OpcodeI32TruncF64S: OpcodeI32TruncF64SName,
OpcodeI32TruncF64U: OpcodeI32TruncF64UName,
OpcodeI64ExtendI32S: OpcodeI64ExtendI32SName,
OpcodeI64ExtendI32U: OpcodeI64ExtendI32UName,
OpcodeI64TruncF32S: OpcodeI64TruncF32SName,
OpcodeI64TruncF32U: OpcodeI64TruncF32UName,
OpcodeI64TruncF64S: OpcodeI64TruncF64SName,
OpcodeI64TruncF64U: OpcodeI64TruncF64UName,
OpcodeF32ConvertI32S: OpcodeF32ConvertI32SName,
OpcodeF32ConvertI32U: OpcodeF32ConvertI32UName,
OpcodeF32ConvertI64S: OpcodeF32ConvertI64SName,
OpcodeF32ConvertI64U: OpcodeF32ConvertI64UName,
OpcodeF32DemoteF64: OpcodeF32DemoteF64Name,
OpcodeF64ConvertI32S: OpcodeF64ConvertI32SName,
OpcodeF64ConvertI32U: OpcodeF64ConvertI32UName,
OpcodeF64ConvertI64S: OpcodeF64ConvertI64SName,
OpcodeF64ConvertI64U: OpcodeF64ConvertI64UName,
OpcodeF64PromoteF32: OpcodeF64PromoteF32Name,
OpcodeI32ReinterpretF32: OpcodeI32ReinterpretF32Name,
OpcodeI64ReinterpretF64: OpcodeI64ReinterpretF64Name,
OpcodeF32ReinterpretI32: OpcodeF32ReinterpretI32Name,
OpcodeF64ReinterpretI64: OpcodeF64ReinterpretI64Name,
OpcodeRefNull: OpcodeRefNullName,
OpcodeRefIsNull: OpcodeRefIsNullName,
OpcodeRefFunc: OpcodeRefFuncName,
OpcodeTableGet: OpcodeTableGetName,
OpcodeTableSet: OpcodeTableSetName,
// Below are toggled with CoreFeatureSignExtensionOps
OpcodeI32Extend8S: OpcodeI32Extend8SName,
OpcodeI32Extend16S: OpcodeI32Extend16SName,
OpcodeI64Extend8S: OpcodeI64Extend8SName,
OpcodeI64Extend16S: OpcodeI64Extend16SName,
OpcodeI64Extend32S: OpcodeI64Extend32SName,
OpcodeMiscPrefix: OpcodeMiscPrefixName,
OpcodeVecPrefix: OpcodeVecPrefixName,
}
// InstructionName returns the instruction corresponding to this binary Opcode.
// See https://www.w3.org/TR/2019/REC-wasm-core-1-20191205/#a7-index-of-instructions
func InstructionName(oc Opcode) string {
return instructionNames[oc]
}
const (
OpcodeI32TruncSatF32SName = "i32.trunc_sat_f32_s"
OpcodeI32TruncSatF32UName = "i32.trunc_sat_f32_u"
OpcodeI32TruncSatF64SName = "i32.trunc_sat_f64_s"
OpcodeI32TruncSatF64UName = "i32.trunc_sat_f64_u"
OpcodeI64TruncSatF32SName = "i64.trunc_sat_f32_s"
OpcodeI64TruncSatF32UName = "i64.trunc_sat_f32_u"
OpcodeI64TruncSatF64SName = "i64.trunc_sat_f64_s"
OpcodeI64TruncSatF64UName = "i64.trunc_sat_f64_u"
OpcodeMemoryInitName = "memory.init"
OpcodeDataDropName = "data.drop"
OpcodeMemoryCopyName = "memory.copy"
OpcodeMemoryFillName = "memory.fill"
OpcodeTableInitName = "table.init"
OpcodeElemDropName = "elem.drop"
OpcodeTableCopyName = "table.copy"
OpcodeTableGrowName = "table.grow"
OpcodeTableSizeName = "table.size"
OpcodeTableFillName = "table.fill"
)
var miscInstructionNames = [256]string{
OpcodeMiscI32TruncSatF32S: OpcodeI32TruncSatF32SName,
OpcodeMiscI32TruncSatF32U: OpcodeI32TruncSatF32UName,
OpcodeMiscI32TruncSatF64S: OpcodeI32TruncSatF64SName,
OpcodeMiscI32TruncSatF64U: OpcodeI32TruncSatF64UName,
OpcodeMiscI64TruncSatF32S: OpcodeI64TruncSatF32SName,
OpcodeMiscI64TruncSatF32U: OpcodeI64TruncSatF32UName,
OpcodeMiscI64TruncSatF64S: OpcodeI64TruncSatF64SName,
OpcodeMiscI64TruncSatF64U: OpcodeI64TruncSatF64UName,
OpcodeMiscMemoryInit: OpcodeMemoryInitName,
OpcodeMiscDataDrop: OpcodeDataDropName,
OpcodeMiscMemoryCopy: OpcodeMemoryCopyName,
OpcodeMiscMemoryFill: OpcodeMemoryFillName,
OpcodeMiscTableInit: OpcodeTableInitName,
OpcodeMiscElemDrop: OpcodeElemDropName,
OpcodeMiscTableCopy: OpcodeTableCopyName,
OpcodeMiscTableGrow: OpcodeTableGrowName,
OpcodeMiscTableSize: OpcodeTableSizeName,
OpcodeMiscTableFill: OpcodeTableFillName,
}
// MiscInstructionName returns the instruction corresponding to this miscellaneous Opcode.
func MiscInstructionName(oc OpcodeMisc) string {
return miscInstructionNames[oc]
}
const (
OpcodeVecV128LoadName = "v128.load"
OpcodeVecV128Load8x8SName = "v128.load8x8_s"
OpcodeVecV128Load8x8UName = "v128.load8x8_u"
OpcodeVecV128Load16x4SName = "v128.load16x4_s"
OpcodeVecV128Load16x4UName = "v128.load16x4_u"
OpcodeVecV128Load32x2SName = "v128.load32x2_s"
OpcodeVecV128Load32x2UName = "v128.load32x2_u"
OpcodeVecV128Load8SplatName = "v128.load8_splat"
OpcodeVecV128Load16SplatName = "v128.load16_splat"
OpcodeVecV128Load32SplatName = "v128.load32_splat"
OpcodeVecV128Load64SplatName = "v128.load64_splat"
OpcodeVecV128Load32zeroName = "v128.load32_zero"
OpcodeVecV128Load64zeroName = "v128.load64_zero"
OpcodeVecV128StoreName = "v128.store"
OpcodeVecV128Load8LaneName = "v128.load8_lane"
OpcodeVecV128Load16LaneName = "v128.load16_lane"
OpcodeVecV128Load32LaneName = "v128.load32_lane"
OpcodeVecV128Load64LaneName = "v128.load64_lane"
OpcodeVecV128Store8LaneName = "v128.store8_lane"
OpcodeVecV128Store16LaneName = "v128.store16_lane"
OpcodeVecV128Store32LaneName = "v128.store32_lane"
OpcodeVecV128Store64LaneName = "v128.store64_lane"
OpcodeVecV128ConstName = "v128.const"
OpcodeVecV128i8x16ShuffleName = "v128.shuffle"
OpcodeVecI8x16ExtractLaneSName = "i8x16.extract_lane_s"
OpcodeVecI8x16ExtractLaneUName = "i8x16.extract_lane_u"
OpcodeVecI8x16ReplaceLaneName = "i8x16.replace_lane"
OpcodeVecI16x8ExtractLaneSName = "i16x8.extract_lane_s"
OpcodeVecI16x8ExtractLaneUName = "i16x8.extract_lane_u"
OpcodeVecI16x8ReplaceLaneName = "i16x8.replace_lane"
OpcodeVecI32x4ExtractLaneName = "i32x4.extract_lane"
OpcodeVecI32x4ReplaceLaneName = "i32x4.replace_lane"
OpcodeVecI64x2ExtractLaneName = "i64x2.extract_lane"
OpcodeVecI64x2ReplaceLaneName = "i64x2.replace_lane"
OpcodeVecF32x4ExtractLaneName = "f32x4.extract_lane"
OpcodeVecF32x4ReplaceLaneName = "f32x4.replace_lane"
OpcodeVecF64x2ExtractLaneName = "f64x2.extract_lane"
OpcodeVecF64x2ReplaceLaneName = "f64x2.replace_lane"
OpcodeVecI8x16SwizzleName = "i8x16.swizzle"
OpcodeVecI8x16SplatName = "i8x16.splat"
OpcodeVecI16x8SplatName = "i16x8.splat"
OpcodeVecI32x4SplatName = "i32x4.splat"
OpcodeVecI64x2SplatName = "i64x2.splat"
OpcodeVecF32x4SplatName = "f32x4.splat"
OpcodeVecF64x2SplatName = "f64x2.splat"
OpcodeVecI8x16EqName = "i8x16.eq"
OpcodeVecI8x16NeName = "i8x16.ne"
OpcodeVecI8x16LtSName = "i8x16.lt_s"
OpcodeVecI8x16LtUName = "i8x16.lt_u"
OpcodeVecI8x16GtSName = "i8x16.gt_s"
OpcodeVecI8x16GtUName = "i8x16.gt_u"
OpcodeVecI8x16LeSName = "i8x16.le_s"
OpcodeVecI8x16LeUName = "i8x16.le_u"
OpcodeVecI8x16GeSName = "i8x16.ge_s"
OpcodeVecI8x16GeUName = "i8x16.ge_u"
OpcodeVecI16x8EqName = "i16x8.eq"
OpcodeVecI16x8NeName = "i16x8.ne"
OpcodeVecI16x8LtSName = "i16x8.lt_s"
OpcodeVecI16x8LtUName = "i16x8.lt_u"
OpcodeVecI16x8GtSName = "i16x8.gt_s"
OpcodeVecI16x8GtUName = "i16x8.gt_u"
OpcodeVecI16x8LeSName = "i16x8.le_s"
OpcodeVecI16x8LeUName = "i16x8.le_u"
OpcodeVecI16x8GeSName = "i16x8.ge_s"
OpcodeVecI16x8GeUName = "i16x8.ge_u"
OpcodeVecI32x4EqName = "i32x4.eq"
OpcodeVecI32x4NeName = "i32x4.ne"
OpcodeVecI32x4LtSName = "i32x4.lt_s"
OpcodeVecI32x4LtUName = "i32x4.lt_u"
OpcodeVecI32x4GtSName = "i32x4.gt_s"
OpcodeVecI32x4GtUName = "i32x4.gt_u"
OpcodeVecI32x4LeSName = "i32x4.le_s"
OpcodeVecI32x4LeUName = "i32x4.le_u"
OpcodeVecI32x4GeSName = "i32x4.ge_s"
OpcodeVecI32x4GeUName = "i32x4.ge_u"
OpcodeVecI64x2EqName = "i64x2.eq"
OpcodeVecI64x2NeName = "i64x2.ne"
OpcodeVecI64x2LtSName = "i64x2.lt"
OpcodeVecI64x2GtSName = "i64x2.gt"
OpcodeVecI64x2LeSName = "i64x2.le"
OpcodeVecI64x2GeSName = "i64x2.ge"
OpcodeVecF32x4EqName = "f32x4.eq"
OpcodeVecF32x4NeName = "f32x4.ne"
OpcodeVecF32x4LtName = "f32x4.lt"
OpcodeVecF32x4GtName = "f32x4.gt"
OpcodeVecF32x4LeName = "f32x4.le"
OpcodeVecF32x4GeName = "f32x4.ge"
OpcodeVecF64x2EqName = "f64x2.eq"
OpcodeVecF64x2NeName = "f64x2.ne"
OpcodeVecF64x2LtName = "f64x2.lt"
OpcodeVecF64x2GtName = "f64x2.gt"
OpcodeVecF64x2LeName = "f64x2.le"
OpcodeVecF64x2GeName = "f64x2.ge"
OpcodeVecV128NotName = "v128.not"
OpcodeVecV128AndName = "v128.and"
OpcodeVecV128AndNotName = "v128.andnot"
OpcodeVecV128OrName = "v128.or"
OpcodeVecV128XorName = "v128.xor"
OpcodeVecV128BitselectName = "v128.bitselect"
OpcodeVecV128AnyTrueName = "v128.any_true"
OpcodeVecI8x16AbsName = "i8x16.abs"
OpcodeVecI8x16NegName = "i8x16.neg"
OpcodeVecI8x16PopcntName = "i8x16.popcnt"
OpcodeVecI8x16AllTrueName = "i8x16.all_true"
OpcodeVecI8x16BitMaskName = "i8x16.bitmask"
OpcodeVecI8x16NarrowI16x8SName = "i8x16.narrow_i16x8_s"
OpcodeVecI8x16NarrowI16x8UName = "i8x16.narrow_i16x8_u"
OpcodeVecI8x16ShlName = "i8x16.shl"
OpcodeVecI8x16ShrSName = "i8x16.shr_s"
OpcodeVecI8x16ShrUName = "i8x16.shr_u"
OpcodeVecI8x16AddName = "i8x16.add"
OpcodeVecI8x16AddSatSName = "i8x16.add_sat_s"
OpcodeVecI8x16AddSatUName = "i8x16.add_sat_u"
OpcodeVecI8x16SubName = "i8x16.sub"
OpcodeVecI8x16SubSatSName = "i8x16.sub_s"
OpcodeVecI8x16SubSatUName = "i8x16.sub_u"
OpcodeVecI8x16MinSName = "i8x16.min_s"
OpcodeVecI8x16MinUName = "i8x16.min_u"
OpcodeVecI8x16MaxSName = "i8x16.max_s"
OpcodeVecI8x16MaxUName = "i8x16.max_u"
OpcodeVecI8x16AvgrUName = "i8x16.avgr_u"
OpcodeVecI16x8ExtaddPairwiseI8x16SName = "i16x8.extadd_pairwise_i8x16_s"
OpcodeVecI16x8ExtaddPairwiseI8x16UName = "i16x8.extadd_pairwise_i8x16_u"
OpcodeVecI16x8AbsName = "i16x8.abs"
OpcodeVecI16x8NegName = "i16x8.neg"
OpcodeVecI16x8Q15mulrSatSName = "i16x8.q15mulr_sat_s"
OpcodeVecI16x8AllTrueName = "i16x8.all_true"
OpcodeVecI16x8BitMaskName = "i16x8.bitmask"
OpcodeVecI16x8NarrowI32x4SName = "i16x8.narrow_i32x4_s"
OpcodeVecI16x8NarrowI32x4UName = "i16x8.narrow_i32x4_u"
OpcodeVecI16x8ExtendLowI8x16SName = "i16x8.extend_low_i8x16_s"
OpcodeVecI16x8ExtendHighI8x16SName = "i16x8.extend_high_i8x16_s"
OpcodeVecI16x8ExtendLowI8x16UName = "i16x8.extend_low_i8x16_u"
OpcodeVecI16x8ExtendHighI8x16UName = "i16x8.extend_high_i8x16_u"
OpcodeVecI16x8ShlName = "i16x8.shl"
OpcodeVecI16x8ShrSName = "i16x8.shr_s"
OpcodeVecI16x8ShrUName = "i16x8.shr_u"
OpcodeVecI16x8AddName = "i16x8.add"
OpcodeVecI16x8AddSatSName = "i16x8.add_sat_s"
OpcodeVecI16x8AddSatUName = "i16x8.add_sat_u"
OpcodeVecI16x8SubName = "i16x8.sub"
OpcodeVecI16x8SubSatSName = "i16x8.sub_sat_s"
OpcodeVecI16x8SubSatUName = "i16x8.sub_sat_u"
OpcodeVecI16x8MulName = "i16x8.mul"
OpcodeVecI16x8MinSName = "i16x8.min_s"
OpcodeVecI16x8MinUName = "i16x8.min_u"
OpcodeVecI16x8MaxSName = "i16x8.max_s"
OpcodeVecI16x8MaxUName = "i16x8.max_u"
OpcodeVecI16x8AvgrUName = "i16x8.avgr_u"
OpcodeVecI16x8ExtMulLowI8x16SName = "i16x8.extmul_low_i8x16_s"
OpcodeVecI16x8ExtMulHighI8x16SName = "i16x8.extmul_high_i8x16_s"
OpcodeVecI16x8ExtMulLowI8x16UName = "i16x8.extmul_low_i8x16_u"
OpcodeVecI16x8ExtMulHighI8x16UName = "i16x8.extmul_high_i8x16_u"
OpcodeVecI32x4ExtaddPairwiseI16x8SName = "i32x4.extadd_pairwise_i16x8_s"
OpcodeVecI32x4ExtaddPairwiseI16x8UName = "i32x4.extadd_pairwise_i16x8_u"
OpcodeVecI32x4AbsName = "i32x4.abs"
OpcodeVecI32x4NegName = "i32x4.neg"
OpcodeVecI32x4AllTrueName = "i32x4.all_true"
OpcodeVecI32x4BitMaskName = "i32x4.bitmask"
OpcodeVecI32x4ExtendLowI16x8SName = "i32x4.extend_low_i16x8_s"
OpcodeVecI32x4ExtendHighI16x8SName = "i32x4.extend_high_i16x8_s"
OpcodeVecI32x4ExtendLowI16x8UName = "i32x4.extend_low_i16x8_u"
OpcodeVecI32x4ExtendHighI16x8UName = "i32x4.extend_high_i16x8_u"
OpcodeVecI32x4ShlName = "i32x4.shl"
OpcodeVecI32x4ShrSName = "i32x4.shr_s"
OpcodeVecI32x4ShrUName = "i32x4.shr_u"
OpcodeVecI32x4AddName = "i32x4.add"
OpcodeVecI32x4SubName = "i32x4.sub"
OpcodeVecI32x4MulName = "i32x4.mul"
OpcodeVecI32x4MinSName = "i32x4.min_s"
OpcodeVecI32x4MinUName = "i32x4.min_u"
OpcodeVecI32x4MaxSName = "i32x4.max_s"
OpcodeVecI32x4MaxUName = "i32x4.max_u"
OpcodeVecI32x4DotI16x8SName = "i32x4.dot_i16x8_s"
OpcodeVecI32x4ExtMulLowI16x8SName = "i32x4.extmul_low_i16x8_s"
OpcodeVecI32x4ExtMulHighI16x8SName = "i32x4.extmul_high_i16x8_s"
OpcodeVecI32x4ExtMulLowI16x8UName = "i32x4.extmul_low_i16x8_u"
OpcodeVecI32x4ExtMulHighI16x8UName = "i32x4.extmul_high_i16x8_u"
OpcodeVecI64x2AbsName = "i64x2.abs"
OpcodeVecI64x2NegName = "i64x2.neg"
OpcodeVecI64x2AllTrueName = "i64x2.all_true"
OpcodeVecI64x2BitMaskName = "i64x2.bitmask"
OpcodeVecI64x2ExtendLowI32x4SName = "i64x2.extend_low_i32x4_s"
OpcodeVecI64x2ExtendHighI32x4SName = "i64x2.extend_high_i32x4_s"
OpcodeVecI64x2ExtendLowI32x4UName = "i64x2.extend_low_i32x4_u"
OpcodeVecI64x2ExtendHighI32x4UName = "i64x2.extend_high_i32x4_u"
OpcodeVecI64x2ShlName = "i64x2.shl"
OpcodeVecI64x2ShrSName = "i64x2.shr_s"
OpcodeVecI64x2ShrUName = "i64x2.shr_u"
OpcodeVecI64x2AddName = "i64x2.add"
OpcodeVecI64x2SubName = "i64x2.sub"
OpcodeVecI64x2MulName = "i64x2.mul"
OpcodeVecI64x2ExtMulLowI32x4SName = "i64x2.extmul_low_i32x4_s"
OpcodeVecI64x2ExtMulHighI32x4SName = "i64x2.extmul_high_i32x4_s"
OpcodeVecI64x2ExtMulLowI32x4UName = "i64x2.extmul_low_i32x4_u"
OpcodeVecI64x2ExtMulHighI32x4UName = "i64x2.extmul_high_i32x4_u"
OpcodeVecF32x4CeilName = "f32x4.ceil"
OpcodeVecF32x4FloorName = "f32x4.floor"
OpcodeVecF32x4TruncName = "f32x4.trunc"
OpcodeVecF32x4NearestName = "f32x4.nearest"
OpcodeVecF32x4AbsName = "f32x4.abs"
OpcodeVecF32x4NegName = "f32x4.neg"
OpcodeVecF32x4SqrtName = "f32x4.sqrt"
OpcodeVecF32x4AddName = "f32x4.add"
OpcodeVecF32x4SubName = "f32x4.sub"
OpcodeVecF32x4MulName = "f32x4.mul"
OpcodeVecF32x4DivName = "f32x4.div"
OpcodeVecF32x4MinName = "f32x4.min"
OpcodeVecF32x4MaxName = "f32x4.max"
OpcodeVecF32x4PminName = "f32x4.pmin"
OpcodeVecF32x4PmaxName = "f32x4.pmax"
OpcodeVecF64x2CeilName = "f64x2.ceil"
OpcodeVecF64x2FloorName = "f64x2.floor"
OpcodeVecF64x2TruncName = "f64x2.trunc"
OpcodeVecF64x2NearestName = "f64x2.nearest"
OpcodeVecF64x2AbsName = "f64x2.abs"
OpcodeVecF64x2NegName = "f64x2.neg"
OpcodeVecF64x2SqrtName = "f64x2.sqrt"
OpcodeVecF64x2AddName = "f64x2.add"
OpcodeVecF64x2SubName = "f64x2.sub"
OpcodeVecF64x2MulName = "f64x2.mul"
OpcodeVecF64x2DivName = "f64x2.div"
OpcodeVecF64x2MinName = "f64x2.min"
OpcodeVecF64x2MaxName = "f64x2.max"
OpcodeVecF64x2PminName = "f64x2.pmin"
OpcodeVecF64x2PmaxName = "f64x2.pmax"
OpcodeVecI32x4TruncSatF32x4SName = "i32x4.trunc_sat_f32x4_s"
OpcodeVecI32x4TruncSatF32x4UName = "i32x4.trunc_sat_f32x4_u"
OpcodeVecF32x4ConvertI32x4SName = "f32x4.convert_i32x4_s"
OpcodeVecF32x4ConvertI32x4UName = "f32x4.convert_i32x4_u"
OpcodeVecI32x4TruncSatF64x2SZeroName = "i32x4.trunc_sat_f64x2_s_zero"
OpcodeVecI32x4TruncSatF64x2UZeroName = "i32x4.trunc_sat_f64x2_u_zero"
OpcodeVecF64x2ConvertLowI32x4SName = "f64x2.convert_low_i32x4_s"
OpcodeVecF64x2ConvertLowI32x4UName = "f64x2.convert_low_i32x4_u"
OpcodeVecF32x4DemoteF64x2ZeroName = "f32x4.demote_f64x2_zero"
OpcodeVecF64x2PromoteLowF32x4ZeroName = "f64x2.promote_low_f32x4"
)
var vectorInstructionName = map[OpcodeVec]string{
OpcodeVecV128Load: OpcodeVecV128LoadName,
OpcodeVecV128Load8x8s: OpcodeVecV128Load8x8SName,
OpcodeVecV128Load8x8u: OpcodeVecV128Load8x8UName,
OpcodeVecV128Load16x4s: OpcodeVecV128Load16x4SName,
OpcodeVecV128Load16x4u: OpcodeVecV128Load16x4UName,
OpcodeVecV128Load32x2s: OpcodeVecV128Load32x2SName,
OpcodeVecV128Load32x2u: OpcodeVecV128Load32x2UName,
OpcodeVecV128Load8Splat: OpcodeVecV128Load8SplatName,
OpcodeVecV128Load16Splat: OpcodeVecV128Load16SplatName,
OpcodeVecV128Load32Splat: OpcodeVecV128Load32SplatName,
OpcodeVecV128Load64Splat: OpcodeVecV128Load64SplatName,
OpcodeVecV128Load32zero: OpcodeVecV128Load32zeroName,
OpcodeVecV128Load64zero: OpcodeVecV128Load64zeroName,
OpcodeVecV128Store: OpcodeVecV128StoreName,
OpcodeVecV128Load8Lane: OpcodeVecV128Load8LaneName,
OpcodeVecV128Load16Lane: OpcodeVecV128Load16LaneName,
OpcodeVecV128Load32Lane: OpcodeVecV128Load32LaneName,
OpcodeVecV128Load64Lane: OpcodeVecV128Load64LaneName,
OpcodeVecV128Store8Lane: OpcodeVecV128Store8LaneName,
OpcodeVecV128Store16Lane: OpcodeVecV128Store16LaneName,
OpcodeVecV128Store32Lane: OpcodeVecV128Store32LaneName,
OpcodeVecV128Store64Lane: OpcodeVecV128Store64LaneName,
OpcodeVecV128Const: OpcodeVecV128ConstName,
OpcodeVecV128i8x16Shuffle: OpcodeVecV128i8x16ShuffleName,
OpcodeVecI8x16ExtractLaneS: OpcodeVecI8x16ExtractLaneSName,
OpcodeVecI8x16ExtractLaneU: OpcodeVecI8x16ExtractLaneUName,
OpcodeVecI8x16ReplaceLane: OpcodeVecI8x16ReplaceLaneName,
OpcodeVecI16x8ExtractLaneS: OpcodeVecI16x8ExtractLaneSName,
OpcodeVecI16x8ExtractLaneU: OpcodeVecI16x8ExtractLaneUName,
OpcodeVecI16x8ReplaceLane: OpcodeVecI16x8ReplaceLaneName,
OpcodeVecI32x4ExtractLane: OpcodeVecI32x4ExtractLaneName,
OpcodeVecI32x4ReplaceLane: OpcodeVecI32x4ReplaceLaneName,
OpcodeVecI64x2ExtractLane: OpcodeVecI64x2ExtractLaneName,
OpcodeVecI64x2ReplaceLane: OpcodeVecI64x2ReplaceLaneName,
OpcodeVecF32x4ExtractLane: OpcodeVecF32x4ExtractLaneName,
OpcodeVecF32x4ReplaceLane: OpcodeVecF32x4ReplaceLaneName,
OpcodeVecF64x2ExtractLane: OpcodeVecF64x2ExtractLaneName,
OpcodeVecF64x2ReplaceLane: OpcodeVecF64x2ReplaceLaneName,
OpcodeVecI8x16Swizzle: OpcodeVecI8x16SwizzleName,
OpcodeVecI8x16Splat: OpcodeVecI8x16SplatName,
OpcodeVecI16x8Splat: OpcodeVecI16x8SplatName,
OpcodeVecI32x4Splat: OpcodeVecI32x4SplatName,
OpcodeVecI64x2Splat: OpcodeVecI64x2SplatName,
OpcodeVecF32x4Splat: OpcodeVecF32x4SplatName,
OpcodeVecF64x2Splat: OpcodeVecF64x2SplatName,
OpcodeVecI8x16Eq: OpcodeVecI8x16EqName,
OpcodeVecI8x16Ne: OpcodeVecI8x16NeName,
OpcodeVecI8x16LtS: OpcodeVecI8x16LtSName,
OpcodeVecI8x16LtU: OpcodeVecI8x16LtUName,
OpcodeVecI8x16GtS: OpcodeVecI8x16GtSName,
OpcodeVecI8x16GtU: OpcodeVecI8x16GtUName,
OpcodeVecI8x16LeS: OpcodeVecI8x16LeSName,
OpcodeVecI8x16LeU: OpcodeVecI8x16LeUName,
OpcodeVecI8x16GeS: OpcodeVecI8x16GeSName,
OpcodeVecI8x16GeU: OpcodeVecI8x16GeUName,
OpcodeVecI16x8Eq: OpcodeVecI16x8EqName,
OpcodeVecI16x8Ne: OpcodeVecI16x8NeName,
OpcodeVecI16x8LtS: OpcodeVecI16x8LtSName,
OpcodeVecI16x8LtU: OpcodeVecI16x8LtUName,
OpcodeVecI16x8GtS: OpcodeVecI16x8GtSName,
OpcodeVecI16x8GtU: OpcodeVecI16x8GtUName,
OpcodeVecI16x8LeS: OpcodeVecI16x8LeSName,
OpcodeVecI16x8LeU: OpcodeVecI16x8LeUName,
OpcodeVecI16x8GeS: OpcodeVecI16x8GeSName,
OpcodeVecI16x8GeU: OpcodeVecI16x8GeUName,
OpcodeVecI32x4Eq: OpcodeVecI32x4EqName,
OpcodeVecI32x4Ne: OpcodeVecI32x4NeName,
OpcodeVecI32x4LtS: OpcodeVecI32x4LtSName,
OpcodeVecI32x4LtU: OpcodeVecI32x4LtUName,
OpcodeVecI32x4GtS: OpcodeVecI32x4GtSName,
OpcodeVecI32x4GtU: OpcodeVecI32x4GtUName,
OpcodeVecI32x4LeS: OpcodeVecI32x4LeSName,
OpcodeVecI32x4LeU: OpcodeVecI32x4LeUName,
OpcodeVecI32x4GeS: OpcodeVecI32x4GeSName,
OpcodeVecI32x4GeU: OpcodeVecI32x4GeUName,
OpcodeVecI64x2Eq: OpcodeVecI64x2EqName,
OpcodeVecI64x2Ne: OpcodeVecI64x2NeName,
OpcodeVecI64x2LtS: OpcodeVecI64x2LtSName,
OpcodeVecI64x2GtS: OpcodeVecI64x2GtSName,
OpcodeVecI64x2LeS: OpcodeVecI64x2LeSName,
OpcodeVecI64x2GeS: OpcodeVecI64x2GeSName,
OpcodeVecF32x4Eq: OpcodeVecF32x4EqName,
OpcodeVecF32x4Ne: OpcodeVecF32x4NeName,
OpcodeVecF32x4Lt: OpcodeVecF32x4LtName,
OpcodeVecF32x4Gt: OpcodeVecF32x4GtName,
OpcodeVecF32x4Le: OpcodeVecF32x4LeName,
OpcodeVecF32x4Ge: OpcodeVecF32x4GeName,
OpcodeVecF64x2Eq: OpcodeVecF64x2EqName,
OpcodeVecF64x2Ne: OpcodeVecF64x2NeName,
OpcodeVecF64x2Lt: OpcodeVecF64x2LtName,
OpcodeVecF64x2Gt: OpcodeVecF64x2GtName,
OpcodeVecF64x2Le: OpcodeVecF64x2LeName,
OpcodeVecF64x2Ge: OpcodeVecF64x2GeName,
OpcodeVecV128Not: OpcodeVecV128NotName,
OpcodeVecV128And: OpcodeVecV128AndName,
OpcodeVecV128AndNot: OpcodeVecV128AndNotName,
OpcodeVecV128Or: OpcodeVecV128OrName,
OpcodeVecV128Xor: OpcodeVecV128XorName,
OpcodeVecV128Bitselect: OpcodeVecV128BitselectName,
OpcodeVecV128AnyTrue: OpcodeVecV128AnyTrueName,
OpcodeVecI8x16Abs: OpcodeVecI8x16AbsName,
OpcodeVecI8x16Neg: OpcodeVecI8x16NegName,
OpcodeVecI8x16Popcnt: OpcodeVecI8x16PopcntName,
OpcodeVecI8x16AllTrue: OpcodeVecI8x16AllTrueName,
OpcodeVecI8x16BitMask: OpcodeVecI8x16BitMaskName,
OpcodeVecI8x16NarrowI16x8S: OpcodeVecI8x16NarrowI16x8SName,
OpcodeVecI8x16NarrowI16x8U: OpcodeVecI8x16NarrowI16x8UName,
OpcodeVecI8x16Shl: OpcodeVecI8x16ShlName,
OpcodeVecI8x16ShrS: OpcodeVecI8x16ShrSName,
OpcodeVecI8x16ShrU: OpcodeVecI8x16ShrUName,
OpcodeVecI8x16Add: OpcodeVecI8x16AddName,
OpcodeVecI8x16AddSatS: OpcodeVecI8x16AddSatSName,
OpcodeVecI8x16AddSatU: OpcodeVecI8x16AddSatUName,
OpcodeVecI8x16Sub: OpcodeVecI8x16SubName,
OpcodeVecI8x16SubSatS: OpcodeVecI8x16SubSatSName,
OpcodeVecI8x16SubSatU: OpcodeVecI8x16SubSatUName,
OpcodeVecI8x16MinS: OpcodeVecI8x16MinSName,
OpcodeVecI8x16MinU: OpcodeVecI8x16MinUName,
OpcodeVecI8x16MaxS: OpcodeVecI8x16MaxSName,
OpcodeVecI8x16MaxU: OpcodeVecI8x16MaxUName,
OpcodeVecI8x16AvgrU: OpcodeVecI8x16AvgrUName,
OpcodeVecI16x8ExtaddPairwiseI8x16S: OpcodeVecI16x8ExtaddPairwiseI8x16SName,
OpcodeVecI16x8ExtaddPairwiseI8x16U: OpcodeVecI16x8ExtaddPairwiseI8x16UName,
OpcodeVecI16x8Abs: OpcodeVecI16x8AbsName,
OpcodeVecI16x8Neg: OpcodeVecI16x8NegName,
OpcodeVecI16x8Q15mulrSatS: OpcodeVecI16x8Q15mulrSatSName,
OpcodeVecI16x8AllTrue: OpcodeVecI16x8AllTrueName,
OpcodeVecI16x8BitMask: OpcodeVecI16x8BitMaskName,
OpcodeVecI16x8NarrowI32x4S: OpcodeVecI16x8NarrowI32x4SName,
OpcodeVecI16x8NarrowI32x4U: OpcodeVecI16x8NarrowI32x4UName,
OpcodeVecI16x8ExtendLowI8x16S: OpcodeVecI16x8ExtendLowI8x16SName,
OpcodeVecI16x8ExtendHighI8x16S: OpcodeVecI16x8ExtendHighI8x16SName,
OpcodeVecI16x8ExtendLowI8x16U: OpcodeVecI16x8ExtendLowI8x16UName,
OpcodeVecI16x8ExtendHighI8x16U: OpcodeVecI16x8ExtendHighI8x16UName,
OpcodeVecI16x8Shl: OpcodeVecI16x8ShlName,
OpcodeVecI16x8ShrS: OpcodeVecI16x8ShrSName,
OpcodeVecI16x8ShrU: OpcodeVecI16x8ShrUName,
OpcodeVecI16x8Add: OpcodeVecI16x8AddName,
OpcodeVecI16x8AddSatS: OpcodeVecI16x8AddSatSName,
OpcodeVecI16x8AddSatU: OpcodeVecI16x8AddSatUName,
OpcodeVecI16x8Sub: OpcodeVecI16x8SubName,
OpcodeVecI16x8SubSatS: OpcodeVecI16x8SubSatSName,
OpcodeVecI16x8SubSatU: OpcodeVecI16x8SubSatUName,
OpcodeVecI16x8Mul: OpcodeVecI16x8MulName,
OpcodeVecI16x8MinS: OpcodeVecI16x8MinSName,
OpcodeVecI16x8MinU: OpcodeVecI16x8MinUName,
OpcodeVecI16x8MaxS: OpcodeVecI16x8MaxSName,
OpcodeVecI16x8MaxU: OpcodeVecI16x8MaxUName,
OpcodeVecI16x8AvgrU: OpcodeVecI16x8AvgrUName,
OpcodeVecI16x8ExtMulLowI8x16S: OpcodeVecI16x8ExtMulLowI8x16SName,
OpcodeVecI16x8ExtMulHighI8x16S: OpcodeVecI16x8ExtMulHighI8x16SName,
OpcodeVecI16x8ExtMulLowI8x16U: OpcodeVecI16x8ExtMulLowI8x16UName,
OpcodeVecI16x8ExtMulHighI8x16U: OpcodeVecI16x8ExtMulHighI8x16UName,
OpcodeVecI32x4ExtaddPairwiseI16x8S: OpcodeVecI32x4ExtaddPairwiseI16x8SName,
OpcodeVecI32x4ExtaddPairwiseI16x8U: OpcodeVecI32x4ExtaddPairwiseI16x8UName,
OpcodeVecI32x4Abs: OpcodeVecI32x4AbsName,
OpcodeVecI32x4Neg: OpcodeVecI32x4NegName,
OpcodeVecI32x4AllTrue: OpcodeVecI32x4AllTrueName,
OpcodeVecI32x4BitMask: OpcodeVecI32x4BitMaskName,
OpcodeVecI32x4ExtendLowI16x8S: OpcodeVecI32x4ExtendLowI16x8SName,
OpcodeVecI32x4ExtendHighI16x8S: OpcodeVecI32x4ExtendHighI16x8SName,
OpcodeVecI32x4ExtendLowI16x8U: OpcodeVecI32x4ExtendLowI16x8UName,
OpcodeVecI32x4ExtendHighI16x8U: OpcodeVecI32x4ExtendHighI16x8UName,
OpcodeVecI32x4Shl: OpcodeVecI32x4ShlName,
OpcodeVecI32x4ShrS: OpcodeVecI32x4ShrSName,
OpcodeVecI32x4ShrU: OpcodeVecI32x4ShrUName,
OpcodeVecI32x4Add: OpcodeVecI32x4AddName,
OpcodeVecI32x4Sub: OpcodeVecI32x4SubName,
OpcodeVecI32x4Mul: OpcodeVecI32x4MulName,
OpcodeVecI32x4MinS: OpcodeVecI32x4MinSName,
OpcodeVecI32x4MinU: OpcodeVecI32x4MinUName,
OpcodeVecI32x4MaxS: OpcodeVecI32x4MaxSName,
OpcodeVecI32x4MaxU: OpcodeVecI32x4MaxUName,
OpcodeVecI32x4DotI16x8S: OpcodeVecI32x4DotI16x8SName,
OpcodeVecI32x4ExtMulLowI16x8S: OpcodeVecI32x4ExtMulLowI16x8SName,
OpcodeVecI32x4ExtMulHighI16x8S: OpcodeVecI32x4ExtMulHighI16x8SName,
OpcodeVecI32x4ExtMulLowI16x8U: OpcodeVecI32x4ExtMulLowI16x8UName,
OpcodeVecI32x4ExtMulHighI16x8U: OpcodeVecI32x4ExtMulHighI16x8UName,
OpcodeVecI64x2Abs: OpcodeVecI64x2AbsName,
OpcodeVecI64x2Neg: OpcodeVecI64x2NegName,
OpcodeVecI64x2AllTrue: OpcodeVecI64x2AllTrueName,
OpcodeVecI64x2BitMask: OpcodeVecI64x2BitMaskName,
OpcodeVecI64x2ExtendLowI32x4S: OpcodeVecI64x2ExtendLowI32x4SName,
OpcodeVecI64x2ExtendHighI32x4S: OpcodeVecI64x2ExtendHighI32x4SName,
OpcodeVecI64x2ExtendLowI32x4U: OpcodeVecI64x2ExtendLowI32x4UName,
OpcodeVecI64x2ExtendHighI32x4U: OpcodeVecI64x2ExtendHighI32x4UName,
OpcodeVecI64x2Shl: OpcodeVecI64x2ShlName,
OpcodeVecI64x2ShrS: OpcodeVecI64x2ShrSName,
OpcodeVecI64x2ShrU: OpcodeVecI64x2ShrUName,
OpcodeVecI64x2Add: OpcodeVecI64x2AddName,
OpcodeVecI64x2Sub: OpcodeVecI64x2SubName,
OpcodeVecI64x2Mul: OpcodeVecI64x2MulName,
OpcodeVecI64x2ExtMulLowI32x4S: OpcodeVecI64x2ExtMulLowI32x4SName,
OpcodeVecI64x2ExtMulHighI32x4S: OpcodeVecI64x2ExtMulHighI32x4SName,
OpcodeVecI64x2ExtMulLowI32x4U: OpcodeVecI64x2ExtMulLowI32x4UName,
OpcodeVecI64x2ExtMulHighI32x4U: OpcodeVecI64x2ExtMulHighI32x4UName,
OpcodeVecF32x4Ceil: OpcodeVecF32x4CeilName,
OpcodeVecF32x4Floor: OpcodeVecF32x4FloorName,
OpcodeVecF32x4Trunc: OpcodeVecF32x4TruncName,
OpcodeVecF32x4Nearest: OpcodeVecF32x4NearestName,
OpcodeVecF32x4Abs: OpcodeVecF32x4AbsName,
OpcodeVecF32x4Neg: OpcodeVecF32x4NegName,
OpcodeVecF32x4Sqrt: OpcodeVecF32x4SqrtName,
OpcodeVecF32x4Add: OpcodeVecF32x4AddName,
OpcodeVecF32x4Sub: OpcodeVecF32x4SubName,
OpcodeVecF32x4Mul: OpcodeVecF32x4MulName,
OpcodeVecF32x4Div: OpcodeVecF32x4DivName,
OpcodeVecF32x4Min: OpcodeVecF32x4MinName,
OpcodeVecF32x4Max: OpcodeVecF32x4MaxName,
OpcodeVecF32x4Pmin: OpcodeVecF32x4PminName,
OpcodeVecF32x4Pmax: OpcodeVecF32x4PmaxName,
OpcodeVecF64x2Ceil: OpcodeVecF64x2CeilName,
OpcodeVecF64x2Floor: OpcodeVecF64x2FloorName,
OpcodeVecF64x2Trunc: OpcodeVecF64x2TruncName,
OpcodeVecF64x2Nearest: OpcodeVecF64x2NearestName,
OpcodeVecF64x2Abs: OpcodeVecF64x2AbsName,
OpcodeVecF64x2Neg: OpcodeVecF64x2NegName,
OpcodeVecF64x2Sqrt: OpcodeVecF64x2SqrtName,
OpcodeVecF64x2Add: OpcodeVecF64x2AddName,
OpcodeVecF64x2Sub: OpcodeVecF64x2SubName,
OpcodeVecF64x2Mul: OpcodeVecF64x2MulName,
OpcodeVecF64x2Div: OpcodeVecF64x2DivName,
OpcodeVecF64x2Min: OpcodeVecF64x2MinName,
OpcodeVecF64x2Max: OpcodeVecF64x2MaxName,
OpcodeVecF64x2Pmin: OpcodeVecF64x2PminName,
OpcodeVecF64x2Pmax: OpcodeVecF64x2PmaxName,
OpcodeVecI32x4TruncSatF32x4S: OpcodeVecI32x4TruncSatF32x4SName,
OpcodeVecI32x4TruncSatF32x4U: OpcodeVecI32x4TruncSatF32x4UName,
OpcodeVecF32x4ConvertI32x4S: OpcodeVecF32x4ConvertI32x4SName,
OpcodeVecF32x4ConvertI32x4U: OpcodeVecF32x4ConvertI32x4UName,
OpcodeVecI32x4TruncSatF64x2SZero: OpcodeVecI32x4TruncSatF64x2SZeroName,
OpcodeVecI32x4TruncSatF64x2UZero: OpcodeVecI32x4TruncSatF64x2UZeroName,
OpcodeVecF64x2ConvertLowI32x4S: OpcodeVecF64x2ConvertLowI32x4SName,
OpcodeVecF64x2ConvertLowI32x4U: OpcodeVecF64x2ConvertLowI32x4UName,
OpcodeVecF32x4DemoteF64x2Zero: OpcodeVecF32x4DemoteF64x2ZeroName,
OpcodeVecF64x2PromoteLowF32x4Zero: OpcodeVecF64x2PromoteLowF32x4ZeroName,
}
// VectorInstructionName returns the instruction name corresponding to the vector Opcode.
func VectorInstructionName(oc OpcodeVec) (ret string) {
return vectorInstructionName[oc]
}
const (
OpcodeAtomicMemoryNotifyName = "memory.atomic.notify"
OpcodeAtomicMemoryWait32Name = "memory.atomic.wait32"
OpcodeAtomicMemoryWait64Name = "memory.atomic.wait64"
OpcodeAtomicFenceName = "atomic.fence"
OpcodeAtomicI32LoadName = "i32.atomic.load"
OpcodeAtomicI64LoadName = "i64.atomic.load"
OpcodeAtomicI32Load8UName = "i32.atomic.load8_u"
OpcodeAtomicI32Load16UName = "i32.atomic.load16_u"
OpcodeAtomicI64Load8UName = "i64.atomic.load8_u"
OpcodeAtomicI64Load16UName = "i64.atomic.load16_u"
OpcodeAtomicI64Load32UName = "i64.atomic.load32_u"
OpcodeAtomicI32StoreName = "i32.atomic.store"
OpcodeAtomicI64StoreName = "i64.atomic.store"
OpcodeAtomicI32Store8Name = "i32.atomic.store8"
OpcodeAtomicI32Store16Name = "i32.atomic.store16"
OpcodeAtomicI64Store8Name = "i64.atomic.store8"
OpcodeAtomicI64Store16Name = "i64.atomic.store16"
OpcodeAtomicI64Store32Name = "i64.atomic.store32"
OpcodeAtomicI32RmwAddName = "i32.atomic.rmw.add"
OpcodeAtomicI64RmwAddName = "i64.atomic.rmw.add"
OpcodeAtomicI32Rmw8AddUName = "i32.atomic.rmw8.add_u"
OpcodeAtomicI32Rmw16AddUName = "i32.atomic.rmw16.add_u"
OpcodeAtomicI64Rmw8AddUName = "i64.atomic.rmw8.add_u"
OpcodeAtomicI64Rmw16AddUName = "i64.atomic.rmw16.add_u"
OpcodeAtomicI64Rmw32AddUName = "i64.atomic.rmw32.add_u"
OpcodeAtomicI32RmwSubName = "i32.atomic.rmw.sub"
OpcodeAtomicI64RmwSubName = "i64.atomic.rmw.sub"
OpcodeAtomicI32Rmw8SubUName = "i32.atomic.rmw8.sub_u"
OpcodeAtomicI32Rmw16SubUName = "i32.atomic.rmw16.sub_u"
OpcodeAtomicI64Rmw8SubUName = "i64.atomic.rmw8.sub_u"
OpcodeAtomicI64Rmw16SubUName = "i64.atomic.rmw16.sub_u"
OpcodeAtomicI64Rmw32SubUName = "i64.atomic.rmw32.sub_u"
OpcodeAtomicI32RmwAndName = "i32.atomic.rmw.and"
OpcodeAtomicI64RmwAndName = "i64.atomic.rmw.and"
OpcodeAtomicI32Rmw8AndUName = "i32.atomic.rmw8.and_u"
OpcodeAtomicI32Rmw16AndUName = "i32.atomic.rmw16.and_u"
OpcodeAtomicI64Rmw8AndUName = "i64.atomic.rmw8.and_u"
OpcodeAtomicI64Rmw16AndUName = "i64.atomic.rmw16.and_u"
OpcodeAtomicI64Rmw32AndUName = "i64.atomic.rmw32.and_u"
OpcodeAtomicI32RmwOrName = "i32.atomic.rmw.or"
OpcodeAtomicI64RmwOrName = "i64.atomic.rmw.or"
OpcodeAtomicI32Rmw8OrUName = "i32.atomic.rmw8.or_u"
OpcodeAtomicI32Rmw16OrUName = "i32.atomic.rmw16.or_u"
OpcodeAtomicI64Rmw8OrUName = "i64.atomic.rmw8.or_u"
OpcodeAtomicI64Rmw16OrUName = "i64.atomic.rmw16.or_u"
OpcodeAtomicI64Rmw32OrUName = "i64.atomic.rmw32.or_u"
OpcodeAtomicI32RmwXorName = "i32.atomic.rmw.xor"
OpcodeAtomicI64RmwXorName = "i64.atomic.rmw.xor"
OpcodeAtomicI32Rmw8XorUName = "i32.atomic.rmw8.xor_u"
OpcodeAtomicI32Rmw16XorUName = "i32.atomic.rmw16.xor_u"
OpcodeAtomicI64Rmw8XorUName = "i64.atomic.rmw8.xor_u"
OpcodeAtomicI64Rmw16XorUName = "i64.atomic.rmw16.xor_u"
OpcodeAtomicI64Rmw32XorUName = "i64.atomic.rmw32.xor_u"
OpcodeAtomicI32RmwXchgName = "i32.atomic.rmw.xchg"
OpcodeAtomicI64RmwXchgName = "i64.atomic.rmw.xchg"
OpcodeAtomicI32Rmw8XchgUName = "i32.atomic.rmw8.xchg_u"
OpcodeAtomicI32Rmw16XchgUName = "i32.atomic.rmw16.xchg_u"
OpcodeAtomicI64Rmw8XchgUName = "i64.atomic.rmw8.xchg_u"
OpcodeAtomicI64Rmw16XchgUName = "i64.atomic.rmw16.xchg_u"
OpcodeAtomicI64Rmw32XchgUName = "i64.atomic.rmw32.xchg_u"
OpcodeAtomicI32RmwCmpxchgName = "i32.atomic.rmw.cmpxchg"
OpcodeAtomicI64RmwCmpxchgName = "i64.atomic.rmw.cmpxchg"
OpcodeAtomicI32Rmw8CmpxchgUName = "i32.atomic.rmw8.cmpxchg_u"
OpcodeAtomicI32Rmw16CmpxchgUName = "i32.atomic.rmw16.cmpxchg_u"
OpcodeAtomicI64Rmw8CmpxchgUName = "i64.atomic.rmw8.cmpxchg_u"
OpcodeAtomicI64Rmw16CmpxchgUName = "i64.atomic.rmw16.cmpxchg_u"
OpcodeAtomicI64Rmw32CmpxchgUName = "i64.atomic.rmw32.cmpxchg_u"
)
var atomicInstructionName = map[OpcodeAtomic]string{
OpcodeAtomicMemoryNotify: OpcodeAtomicMemoryNotifyName,
OpcodeAtomicMemoryWait32: OpcodeAtomicMemoryWait32Name,
OpcodeAtomicMemoryWait64: OpcodeAtomicMemoryWait64Name,
OpcodeAtomicFence: OpcodeAtomicFenceName,
OpcodeAtomicI32Load: OpcodeAtomicI32LoadName,
OpcodeAtomicI64Load: OpcodeAtomicI64LoadName,
OpcodeAtomicI32Load8U: OpcodeAtomicI32Load8UName,
OpcodeAtomicI32Load16U: OpcodeAtomicI32Load16UName,
OpcodeAtomicI64Load8U: OpcodeAtomicI64Load8UName,
OpcodeAtomicI64Load16U: OpcodeAtomicI64Load16UName,
OpcodeAtomicI64Load32U: OpcodeAtomicI64Load32UName,
OpcodeAtomicI32Store: OpcodeAtomicI32StoreName,
OpcodeAtomicI64Store: OpcodeAtomicI64StoreName,
OpcodeAtomicI32Store8: OpcodeAtomicI32Store8Name,
OpcodeAtomicI32Store16: OpcodeAtomicI32Store16Name,
OpcodeAtomicI64Store8: OpcodeAtomicI64Store8Name,
OpcodeAtomicI64Store16: OpcodeAtomicI64Store16Name,
OpcodeAtomicI64Store32: OpcodeAtomicI64Store32Name,
OpcodeAtomicI32RmwAdd: OpcodeAtomicI32RmwAddName,
OpcodeAtomicI64RmwAdd: OpcodeAtomicI64RmwAddName,
OpcodeAtomicI32Rmw8AddU: OpcodeAtomicI32Rmw8AddUName,
OpcodeAtomicI32Rmw16AddU: OpcodeAtomicI32Rmw16AddUName,
OpcodeAtomicI64Rmw8AddU: OpcodeAtomicI64Rmw8AddUName,
OpcodeAtomicI64Rmw16AddU: OpcodeAtomicI64Rmw16AddUName,
OpcodeAtomicI64Rmw32AddU: OpcodeAtomicI64Rmw32AddUName,
OpcodeAtomicI32RmwSub: OpcodeAtomicI32RmwSubName,
OpcodeAtomicI64RmwSub: OpcodeAtomicI64RmwSubName,
OpcodeAtomicI32Rmw8SubU: OpcodeAtomicI32Rmw8SubUName,
OpcodeAtomicI32Rmw16SubU: OpcodeAtomicI32Rmw16SubUName,
OpcodeAtomicI64Rmw8SubU: OpcodeAtomicI64Rmw8SubUName,
OpcodeAtomicI64Rmw16SubU: OpcodeAtomicI64Rmw16SubUName,
OpcodeAtomicI64Rmw32SubU: OpcodeAtomicI64Rmw32SubUName,
OpcodeAtomicI32RmwAnd: OpcodeAtomicI32RmwAndName,
OpcodeAtomicI64RmwAnd: OpcodeAtomicI64RmwAndName,
OpcodeAtomicI32Rmw8AndU: OpcodeAtomicI32Rmw8AndUName,
OpcodeAtomicI32Rmw16AndU: OpcodeAtomicI32Rmw16AndUName,
OpcodeAtomicI64Rmw8AndU: OpcodeAtomicI64Rmw8AndUName,
OpcodeAtomicI64Rmw16AndU: OpcodeAtomicI64Rmw16AndUName,
OpcodeAtomicI64Rmw32AndU: OpcodeAtomicI64Rmw32AndUName,
OpcodeAtomicI32RmwOr: OpcodeAtomicI32RmwOrName,
OpcodeAtomicI64RmwOr: OpcodeAtomicI64RmwOrName,
OpcodeAtomicI32Rmw8OrU: OpcodeAtomicI32Rmw8OrUName,
OpcodeAtomicI32Rmw16OrU: OpcodeAtomicI32Rmw16OrUName,
OpcodeAtomicI64Rmw8OrU: OpcodeAtomicI64Rmw8OrUName,
OpcodeAtomicI64Rmw16OrU: OpcodeAtomicI64Rmw16OrUName,
OpcodeAtomicI64Rmw32OrU: OpcodeAtomicI64Rmw32OrUName,
OpcodeAtomicI32RmwXor: OpcodeAtomicI32RmwXorName,
OpcodeAtomicI64RmwXor: OpcodeAtomicI64RmwXorName,
OpcodeAtomicI32Rmw8XorU: OpcodeAtomicI32Rmw8XorUName,
OpcodeAtomicI32Rmw16XorU: OpcodeAtomicI32Rmw16XorUName,
OpcodeAtomicI64Rmw8XorU: OpcodeAtomicI64Rmw8XorUName,
OpcodeAtomicI64Rmw16XorU: OpcodeAtomicI64Rmw16XorUName,
OpcodeAtomicI64Rmw32XorU: OpcodeAtomicI64Rmw32XorUName,
OpcodeAtomicI32RmwXchg: OpcodeAtomicI32RmwXchgName,
OpcodeAtomicI64RmwXchg: OpcodeAtomicI64RmwXchgName,
OpcodeAtomicI32Rmw8XchgU: OpcodeAtomicI32Rmw8XchgUName,
OpcodeAtomicI32Rmw16XchgU: OpcodeAtomicI32Rmw16XchgUName,
OpcodeAtomicI64Rmw8XchgU: OpcodeAtomicI64Rmw8XchgUName,
OpcodeAtomicI64Rmw16XchgU: OpcodeAtomicI64Rmw16XchgUName,
OpcodeAtomicI64Rmw32XchgU: OpcodeAtomicI64Rmw32XchgUName,
OpcodeAtomicI32RmwCmpxchg: OpcodeAtomicI32RmwCmpxchgName,
OpcodeAtomicI64RmwCmpxchg: OpcodeAtomicI64RmwCmpxchgName,
OpcodeAtomicI32Rmw8CmpxchgU: OpcodeAtomicI32Rmw8CmpxchgUName,
OpcodeAtomicI32Rmw16CmpxchgU: OpcodeAtomicI32Rmw16CmpxchgUName,
OpcodeAtomicI64Rmw8CmpxchgU: OpcodeAtomicI64Rmw8CmpxchgUName,
OpcodeAtomicI64Rmw16CmpxchgU: OpcodeAtomicI64Rmw16CmpxchgUName,
OpcodeAtomicI64Rmw32CmpxchgU: OpcodeAtomicI64Rmw32CmpxchgUName,
}
// AtomicInstructionName returns the instruction name corresponding to the atomic Opcode.
func AtomicInstructionName(oc OpcodeAtomic) (ret string) {
return atomicInstructionName[oc]
}