mirror of
https://codeberg.org/superseriousbusiness/gotosocial.git
synced 2024-12-22 17:10:20 +03:00
1e7b32490d
This allows for building GoToSocial with [SQLite transpiled to WASM](https://github.com/ncruces/go-sqlite3) and accessed through [Wazero](https://wazero.io/).
1866 lines
84 KiB
Go
1866 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]
|
|
}
|