Instructions¶
Instructions are classified by instruction types that describe how they manipulate the operand stack and initialize locals:
A type
Note
For example, the instruction
Typing extends to instruction sequences
For some instructions, the typing rules do not fully constrain the type, and therefore allow for multiple types. Such instructions are called polymorphic. Two degrees of polymorphism can be distinguished:
value-polymorphic: the value type
of one or several individual operands is unconstrained. That is the case for all parametric instructions like and .stack-polymorphic: the entire (or most of the) instruction type
of the instruction is unconstrained. That is the case for all control instructions that perform an unconditional control transfer, such as , , , and .
In both cases, the unconstrained types or type sequences can be chosen arbitrarily, as long as they meet the constraints imposed for the surrounding parts of the program.
Note
For example, the
and
are valid, with
The
is valid by assuming type
is invalid, because there is no possible type to pick for the
The Appendix describes a type checking algorithm that efficiently implements validation of instruction sequences as prescribed by the rules given here.
Numeric Instructions¶
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
Reference Instructions¶
¶
¶
The function
must be defined in the context.Let
be the defined type .The function index
must be contained in .The instruction is valid with type
.
¶
¶
¶
The instruction is valid with type
.
¶
The reference type
must be valid.Then the instruction is valid with type
for any valid reference type for which matches .
Note
The liberty to pick a supertype
¶
The reference type
must be valid.Then the instruction is valid with type
for any valid reference type for which matches .
Note
The liberty to pick a supertype
Aggregate Reference Instructions¶
¶
The defined type
must exist.The expansion of
must be a structure type .For each field type
in :Let
be .Let
be the value type .
Let
be the concatenation of all .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be a structure type .For each field type
in :Let
be .Let
be the value type .The type
must be defaultable.
Let
be the concatenation of all .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be a structure type .Let the field type
be .Let
be the value type .The extension
must be present if and only if is a packed type.Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be a structure type .Let the field type
be .The prefix
must be .Let
be the value type .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let
be .Let
be the value type .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let
be .Let
be the value type .The type
must be defaultable.Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let
be .Let
be the value type .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let
be .The storage type
must be a reference type .The element segment
must exist.Let
be the reference type .The reference type
must match .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let
be .Let
be the value type .The type
must be a numeric type or a vector type.The data segment
must exist.Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .Let
be the value type .The extension
must be present if and only if is a packed type.Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The prefix
must be .Let
be the value type .Then the instruction is valid with type
.
¶
The the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The prefix
must be .Let
be the value type .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The prefix
must be .The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The storage type
must match .Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The prefix
must be .Let
be the value type .The value type
must be a numeric type or a vector type.The data segment
must exist.Then the instruction is valid with type
.
¶
The defined type
must exist.The expansion of
must be an array type .Let the field type
be .The prefix
must be .The storage type
must be a reference type .The element segment
must exist.Let
be the reference type .The reference type
must match .Then the instruction is valid with type
.
Scalar Reference Instructions¶
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
External Reference Instructions¶
¶
The instruction is valid with type
for any that equals .
¶
The instruction is valid with type
for any that equals .
Vector Instructions¶
Vector instructions can have a prefix to describe the shape of the operand. Packed numeric types,
The following auxiliary function denotes the number of lanes in a vector shape, i.e., its dimension:
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
For all
, in , must be smaller than .The instruction is valid with type
.
¶
Let
be .The instruction is valid with type
.
¶
The lane index
must be smaller than .The instruction is valid with type
.
¶
The lane index
must be smaller than .Let
be .The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
¶
The instruction is valid with type
.
Parametric Instructions¶
¶
The instruction is valid with type
, for any valid value type .
Note
Both
¶
If
is present, then:The result type
must be valid.The length of
must be .Then the instruction is valid with type
.
Else:
The instruction is valid with type
, for any valid value type that matches some number type or vector type.
Note
In future versions of WebAssembly,
Variable Instructions¶
¶
The local
must be defined in the context.Let
be the local type .The initialization status
must be .Then the instruction is valid with type
.
¶
The local
must be defined in the context.Let
be the local type .Then the instruction is valid with type
.
¶
The local
must be defined in the context.Let
be the local type .Then the instruction is valid with type
.
¶
The global
must be defined in the context.Let
be the global type .Then the instruction is valid with type
.
¶
The global
must be defined in the context.Let
be the global type .The mutability
must be .Then the instruction is valid with type
.
Table Instructions¶
¶
The table
must be defined in the context.Let
be the table type .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .The table
must be defined in the context.Let
be the table type .The reference type
must match .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .The element segment
must be defined in the context.Let
be the reference type .The reference type
must match .Then the instruction is valid with type
.
¶
The element segment
must be defined in the context.Then the instruction is valid with type
.
Memory Instructions¶
¶
The memory
must be defined in the context.The alignment
must not be larger than the bit width of divided by .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than the bit width of divided by .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The lane index
must be smaller than .The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The lane index
must be smaller than .The memory
must be defined in the context.The alignment
must not be larger than .Then the instruction is valid with type
.
¶
The memory
must be defined in the context.Then the instruction is valid with type
.
¶
The memory
must be defined in the context.Then the instruction is valid with type
.
¶
The memory
must be defined in the context.Then the instruction is valid with type
.
¶
The memory
must be defined in the context.Then the instruction is valid with type
.
¶
The memory
must be defined in the context.The data segment
must be defined in the context.Then the instruction is valid with type
.
¶
The data segment
must be defined in the context.Then the instruction is valid with type
.
Control Instructions¶
¶
The instruction is valid with type
.
¶
The instruction is valid with any valid type of the form
.
Note
The
¶
The block type must be valid as some instruction type
.Let
be the same context as , but with the result type prepended to the vector.Under context
, the instruction sequence must be valid with type .Then the compound instruction is valid with type
.
Note
The notation
¶
The block type must be valid as some instruction type
.Let
be the same context as , but with the result type prepended to the vector.Under context
, the instruction sequence must be valid with type .Then the compound instruction is valid with type
.
Note
The notation
¶
The block type must be valid as some instruction type
.Let
be the same context as , but with the result type prepended to the vector.Under context
, the instruction sequence must be valid with type .Under context
, the instruction sequence must be valid with type .Then the compound instruction is valid with type
.
Note
The notation
¶
The label
must be defined in the context.Let
be the result type .Then the instruction is valid with any valid type of the form
.
Note
The label index space in the context
The
¶
The label
must be defined in the context.Let
be the result type .Then the instruction is valid with type
.
Note
The label index space in the context
¶
The label
must be defined in the context.For each label
in , the label must be defined in the context.There must be a sequence
of value types, such that:Then the instruction is valid with any valid type of the form
.
Note
The label index space in the context
The
Furthermore, the result type
¶
The label
must be defined in the context.Let
be the result type .Then the instruction is valid with type
for any valid heap type .
¶
The label
must be defined in the context.Let
be the result type .The result type
must contain at least one type.Let the value type
be the last element in the sequence , and the remainder of the sequence preceding it.The value type
must be a reference type of the form .Then the instruction is valid with type
.
¶
The label
must be defined in the context.Let
be the result type .The type sequence
must be of the form .The reference type
must be valid.The reference type
must be valid.The reference type
must match .The reference type
must match .Let
be the type difference between and .Then the instruction is valid with type
.
¶
The label
must be defined in the context.Let
be the result type .The type sequence
must be of the form .The reference type
must be valid.The reference type
must be valid.The reference type
must match .Let
be the type difference between and .The reference type
must match .Then the instruction is valid with type
.
¶
The return type
must not be absent in the context.Let
be the result type of .Then the instruction is valid with any valid type of the form
.
Note
The
¶
The function
must be defined in the context.The expansion of
must be a function type .Then the instruction is valid with type
.
¶
The type
must be defined in the context.The expansion of
must be a function type .Then the instruction is valid with type
.
¶
The table
must be defined in the context.Let
be the table type .The reference type
must match type .The type
must be defined in the context.The expansion of
must be a function type .Then the instruction is valid with type
.
¶
The return type
must not be absent in the context.The function
must be defined in the context.The expansion of
must be a function type .The result type
must match .Then the instruction is valid with any valid type
.
Note
The
¶
The type
must be defined in the context.The expansion of
must be a function type .The result type
must match .Then the instruction is valid with any valid type
.
Note
The
¶
The return type
must not be empty in the context.The table
must be defined in the context.Let
be the table type .The reference type
must match type .The type
must be defined in the context.The expansion of
must be a function type .The result type
must match .Then the instruction is valid with type
, for any sequences of value types and .
Note
The
Instruction Sequences¶
Typing of instruction sequences is defined recursively.
Empty Instruction Sequence: ¶
The empty instruction sequence is valid with type
.
Non-empty Instruction Sequence: ¶
The instruction
must be valid with some type .Let
be the same context as , but with: the same as in C, except that for every local index in , the local type has been updated to initialization status .
Under the context
, the instruction sequence must be valid with some type .Then the combined instruction sequence is valid with type
.
Subsumption for ¶
The instruction sequence
must be valid with some type .The instruction type
: must be a validThe instruction type
must match the type .Then the instruction sequence
is also valid with type .
Note
In combination with the previous rule, subsumption allows to compose instructions whose types would not directly fit otherwise. For example, consider the instruction sequence
To type this sequence, its subsequence
Furthermore, subsumption allows to drop init variables
Expressions¶
Expressions
¶
Then the expression is valid with result type
.
Constant Expressions¶
In a constant expression
all instructions in must be constant.A constant instruction
must be:either of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
,or of the form
, in which case must be a global type of the form .
Note
Currently, constant expressions occurring in globals are further constrained in that contained
The definition of constant expression may be extended in future versions of WebAssembly.