diff options
-rw-r--r-- | src/wasm/wasm-ir-builder.cpp | 12 | ||||
-rw-r--r-- | test/lit/wat-kitchen-sink.wast | 12 |
2 files changed, 13 insertions, 11 deletions
diff --git a/src/wasm/wasm-ir-builder.cpp b/src/wasm/wasm-ir-builder.cpp index ffd0b8674..a7c743970 100644 --- a/src/wasm/wasm-ir-builder.cpp +++ b/src/wasm/wasm-ir-builder.cpp @@ -378,18 +378,10 @@ Result<> IRBuilder::visitReturn(Return* curr) { size_t n = func->getResults().size(); if (n == 0) { curr->value = nullptr; - } else if (n == 1) { - auto val = pop(); + } else { + auto val = pop(n); CHECK_ERR(val); curr->value = *val; - } else { - std::vector<Expression*> vals(n); - for (size_t i = 0; i < n; ++i) { - auto val = pop(); - CHECK_ERR(val); - vals[n - i - 1] = *val; - } - curr->value = builder.makeTupleMake(vals); } return Ok{}; } diff --git a/test/lit/wat-kitchen-sink.wast b/test/lit/wat-kitchen-sink.wast index 33f570702..af9ce7ff0 100644 --- a/test/lit/wat-kitchen-sink.wast +++ b/test/lit/wat-kitchen-sink.wast @@ -3662,6 +3662,16 @@ return ) + ;; CHECK: (func $return-multivalue (type $4) (result i32 i64) + ;; CHECK-NEXT: (return + ;; CHECK-NEXT: (call $return-multivalue) + ;; CHECK-NEXT: ) + ;; CHECK-NEXT: ) + (func $return-multivalue (result i32 i64) + call $return-multivalue + return + ) + ;; CHECK: (func $ref-is-null (type $45) (param $0 anyref) (result i32) ;; CHECK-NEXT: (ref.is_null ;; CHECK-NEXT: (local.get $0) @@ -3683,7 +3693,7 @@ (func $ref-func ref.func $ref-func drop - ref.func 156 + ref.func 157 drop ) |