diff options
Diffstat (limited to 'src/wasm/wasm-validator.cpp')
-rw-r--r-- | src/wasm/wasm-validator.cpp | 22 |
1 files changed, 22 insertions, 0 deletions
diff --git a/src/wasm/wasm-validator.cpp b/src/wasm/wasm-validator.cpp index c1df740df..d55f60009 100644 --- a/src/wasm/wasm-validator.cpp +++ b/src/wasm/wasm-validator.cpp @@ -337,6 +337,8 @@ public: void visitBrOnExn(BrOnExn* curr); void visitTupleMake(TupleMake* curr); void visitTupleExtract(TupleExtract* curr); + void visitI31New(I31New* curr); + void visitI31Get(I31Get* curr); void visitFunction(Function* curr); // helpers @@ -2109,6 +2111,26 @@ void FunctionValidator::visitTupleExtract(TupleExtract* curr) { } } +void FunctionValidator::visitI31New(I31New* curr) { + shouldBeTrue( + getModule()->features.hasGC(), curr, "i31.new requires gc to be enabled"); + shouldBeSubTypeOrFirstIsUnreachable(curr->value->type, + Type::i32, + curr->value, + "i31.new's argument should be i32"); +} + +void FunctionValidator::visitI31Get(I31Get* curr) { + shouldBeTrue(getModule()->features.hasGC(), + curr, + "i31.get_s/u requires gc to be enabled"); + shouldBeSubTypeOrFirstIsUnreachable( + curr->i31->type, + Type::i31ref, + curr->i31, + "i31.get_s/u's argument should be i31ref"); +} + void FunctionValidator::visitFunction(Function* curr) { if (curr->sig.results.isTuple()) { shouldBeTrue(getModule()->features.hasMultivalue(), |