Commit 6cee783c authored by Jakob Kummerow's avatar Jakob Kummerow Committed by Commit Bot

[wasm-c-api] Fix inefficiency in Global::get

Getting the type from the internal object avoids a costly allocation.
Not doing it this way all along was an oversight.

Change-Id: I22197cbb6ab2a68dd0faba78152e7cc2eb473e23
Reviewed-on: https://chromium-review.googlesource.com/c/v8/v8/+/1790102Reviewed-by: 's avatarAndreas Haas <ahaas@chromium.org>
Commit-Queue: Jakob Kummerow <jkummerow@chromium.org>
Cr-Commit-Position: refs/heads/master@{#63613}
parent 8703ac3a
......@@ -1692,17 +1692,17 @@ auto Global::type() const -> own<GlobalType> {
auto Global::get() const -> Val {
i::Handle<i::WasmGlobalObject> v8_global = impl(this)->v8_object();
switch (type()->content()->kind()) {
case I32:
switch (v8_global->type()) {
case i::wasm::kWasmI32:
return Val(v8_global->GetI32());
case I64:
case i::wasm::kWasmI64:
return Val(v8_global->GetI64());
case F32:
case i::wasm::kWasmF32:
return Val(v8_global->GetF32());
case F64:
case i::wasm::kWasmF64:
return Val(v8_global->GetF64());
case ANYREF:
case FUNCREF: {
case i::wasm::kWasmAnyRef:
case i::wasm::kWasmFuncRef: {
StoreImpl* store = impl(this)->store();
i::HandleScope scope(store->i_isolate());
return Val(V8RefValueToWasm(store, v8_global->GetRef()));
......
Markdown is supported
0% or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment