mirror of
				https://github.com/superseriousbusiness/gotosocial.git
				synced 2025-10-31 12:22:24 -05:00 
			
		
		
		
	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]
 | |
| }
 |