OLD | NEW |
1 // Copyright 2015 the V8 project authors. All rights reserved. | 1 // Copyright 2015 the V8 project authors. All rights reserved. |
2 // Use of this source code is governed by a BSD-style license that can be | 2 // Use of this source code is governed by a BSD-style license that can be |
3 // found in the LICENSE file. | 3 // found in the LICENSE file. |
4 | 4 |
5 #include "src/api-natives.h" | 5 #include "src/api-natives.h" |
6 #include "src/api.h" | 6 #include "src/api.h" |
7 #include "src/asmjs/asm-js.h" | 7 #include "src/asmjs/asm-js.h" |
8 #include "src/asmjs/asm-typer.h" | 8 #include "src/asmjs/asm-typer.h" |
9 #include "src/asmjs/asm-wasm-builder.h" | 9 #include "src/asmjs/asm-wasm-builder.h" |
10 #include "src/assert-scope.h" | 10 #include "src/assert-scope.h" |
(...skipping 10 matching lines...) Expand all Loading... |
21 #include "src/wasm/wasm-module.h" | 21 #include "src/wasm/wasm-module.h" |
22 #include "src/wasm/wasm-objects.h" | 22 #include "src/wasm/wasm-objects.h" |
23 #include "src/wasm/wasm-result.h" | 23 #include "src/wasm/wasm-result.h" |
24 | 24 |
25 typedef uint8_t byte; | 25 typedef uint8_t byte; |
26 | 26 |
27 using v8::internal::wasm::ErrorThrower; | 27 using v8::internal::wasm::ErrorThrower; |
28 | 28 |
29 namespace v8 { | 29 namespace v8 { |
30 | 30 |
| 31 enum WasmMemoryObjectData { |
| 32 kWasmMemoryBuffer, |
| 33 kWasmMemoryMaximum, |
| 34 kWasmMemoryInstanceObject |
| 35 }; |
| 36 |
31 namespace { | 37 namespace { |
32 i::Handle<i::String> v8_str(i::Isolate* isolate, const char* str) { | 38 i::Handle<i::String> v8_str(i::Isolate* isolate, const char* str) { |
33 return isolate->factory()->NewStringFromAsciiChecked(str); | 39 return isolate->factory()->NewStringFromAsciiChecked(str); |
34 } | 40 } |
35 Local<String> v8_str(Isolate* isolate, const char* str) { | 41 Local<String> v8_str(Isolate* isolate, const char* str) { |
36 return Utils::ToLocal(v8_str(reinterpret_cast<i::Isolate*>(isolate), str)); | 42 return Utils::ToLocal(v8_str(reinterpret_cast<i::Isolate*>(isolate), str)); |
37 } | 43 } |
38 | 44 |
39 struct RawBuffer { | 45 struct RawBuffer { |
40 const byte* start; | 46 const byte* start; |
(...skipping 176 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
217 i::Handle<i::JSArrayBuffer> memory = i::Handle<i::JSArrayBuffer>::null(); | 223 i::Handle<i::JSArrayBuffer> memory = i::Handle<i::JSArrayBuffer>::null(); |
218 if (args.Length() > 2 && args[2]->IsObject()) { | 224 if (args.Length() > 2 && args[2]->IsObject()) { |
219 Local<Object> obj = Local<Object>::Cast(args[2]); | 225 Local<Object> obj = Local<Object>::Cast(args[2]); |
220 i::Handle<i::Object> mem_obj = v8::Utils::OpenHandle(*obj); | 226 i::Handle<i::Object> mem_obj = v8::Utils::OpenHandle(*obj); |
221 if (i::WasmJs::IsWasmMemoryObject(i_isolate, mem_obj)) { | 227 if (i::WasmJs::IsWasmMemoryObject(i_isolate, mem_obj)) { |
222 memory = i::Handle<i::JSArrayBuffer>( | 228 memory = i::Handle<i::JSArrayBuffer>( |
223 i::Handle<i::WasmMemoryObject>::cast(mem_obj)->get_buffer(), | 229 i::Handle<i::WasmMemoryObject>::cast(mem_obj)->get_buffer(), |
224 i_isolate); | 230 i_isolate); |
225 } else { | 231 } else { |
226 thrower.TypeError("Argument 2 must be a WebAssembly.Memory"); | 232 thrower.TypeError("Argument 2 must be a WebAssembly.Memory"); |
227 return; | |
228 } | 233 } |
229 } | 234 } |
230 i::MaybeHandle<i::JSObject> instance = | 235 i::MaybeHandle<i::JSObject> instance = |
231 i::wasm::WasmModule::Instantiate(i_isolate, &thrower, i_obj, ffi, memory); | 236 i::wasm::WasmModule::Instantiate(i_isolate, &thrower, i_obj, ffi, memory); |
232 if (instance.is_null()) { | 237 if (instance.is_null()) { |
233 if (!thrower.error()) thrower.RuntimeError("Could not instantiate module"); | 238 if (!thrower.error()) thrower.RuntimeError("Could not instantiate module"); |
234 return; | 239 return; |
235 } | 240 } |
236 DCHECK(!i_isolate->has_pending_exception()); | 241 DCHECK(!i_isolate->has_pending_exception()); |
237 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); | 242 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); |
(...skipping 280 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
518 } | 523 } |
519 if (args.Length() < 1) { | 524 if (args.Length() < 1) { |
520 v8::Local<v8::Value> e = v8::Exception::TypeError( | 525 v8::Local<v8::Value> e = v8::Exception::TypeError( |
521 v8_str(isolate, "Argument 0 required, must be numeric value of pages")); | 526 v8_str(isolate, "Argument 0 required, must be numeric value of pages")); |
522 isolate->ThrowException(e); | 527 isolate->ThrowException(e); |
523 return; | 528 return; |
524 } | 529 } |
525 | 530 |
526 uint32_t delta = args[0]->Uint32Value(context).FromJust(); | 531 uint32_t delta = args[0]->Uint32Value(context).FromJust(); |
527 i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate); | 532 i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate); |
528 i::Handle<i::Object> receiver = | 533 i::Handle<i::JSObject> receiver = |
529 i::Handle<i::Object>::cast(Utils::OpenHandle(*args.This())); | 534 i::Handle<i::JSObject>::cast(Utils::OpenHandle(*args.This())); |
530 int32_t ret = i::wasm::GrowWebAssemblyMemory(i_isolate, receiver, delta); | 535 i::Handle<i::Object> instance_object( |
| 536 receiver->GetInternalField(kWasmMemoryInstanceObject), i_isolate); |
| 537 i::Handle<i::WasmInstanceObject> instance( |
| 538 i::Handle<i::WasmInstanceObject>::cast(instance_object)); |
| 539 |
| 540 // TODO(gdeepti) Implement growing memory when shared by different |
| 541 // instances. |
| 542 int32_t ret = internal::wasm::GrowInstanceMemory(i_isolate, instance, delta); |
531 if (ret == -1) { | 543 if (ret == -1) { |
532 v8::Local<v8::Value> e = v8::Exception::Error( | 544 v8::Local<v8::Value> e = v8::Exception::Error( |
533 v8_str(isolate, "Unable to grow instance memory.")); | 545 v8_str(isolate, "Unable to grow instance memory.")); |
534 isolate->ThrowException(e); | 546 isolate->ThrowException(e); |
535 return; | 547 return; |
536 } | 548 } |
| 549 i::MaybeHandle<i::JSArrayBuffer> buffer = |
| 550 internal::wasm::GetInstanceMemory(i_isolate, instance); |
| 551 if (buffer.is_null()) { |
| 552 v8::Local<v8::Value> e = v8::Exception::Error( |
| 553 v8_str(isolate, "WebAssembly.Memory buffer object not set.")); |
| 554 isolate->ThrowException(e); |
| 555 return; |
| 556 } |
| 557 receiver->SetInternalField(kWasmMemoryBuffer, *buffer.ToHandleChecked()); |
537 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); | 558 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); |
538 return_value.Set(ret); | 559 return_value.Set(ret); |
539 } | 560 } |
540 | 561 |
541 void WebAssemblyMemoryGetBuffer( | 562 void WebAssemblyMemoryGetBuffer( |
542 const v8::FunctionCallbackInfo<v8::Value>& args) { | 563 const v8::FunctionCallbackInfo<v8::Value>& args) { |
543 v8::Isolate* isolate = args.GetIsolate(); | 564 v8::Isolate* isolate = args.GetIsolate(); |
544 Local<Context> context = isolate->GetCurrentContext(); | 565 Local<Context> context = isolate->GetCurrentContext(); |
545 i::Handle<i::Context> i_context = Utils::OpenHandle(*context); | 566 i::Handle<i::Context> i_context = Utils::OpenHandle(*context); |
546 if (!BrandCheck(isolate, Utils::OpenHandle(*args.This()), | 567 if (!BrandCheck(isolate, Utils::OpenHandle(*args.This()), |
547 i::Handle<i::Symbol>(i_context->wasm_memory_sym()), | 568 i::Handle<i::Symbol>(i_context->wasm_memory_sym()), |
548 "Receiver is not a WebAssembly.Memory")) { | 569 "Receiver is not a WebAssembly.Memory")) { |
549 return; | 570 return; |
550 } | 571 } |
551 i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate); | 572 i::Isolate* i_isolate = reinterpret_cast<i::Isolate*>(isolate); |
552 i::Handle<i::WasmMemoryObject> receiver = | 573 i::Handle<i::JSObject> receiver = |
553 i::Handle<i::WasmMemoryObject>::cast(Utils::OpenHandle(*args.This())); | 574 i::Handle<i::JSObject>::cast(Utils::OpenHandle(*args.This())); |
554 i::Handle<i::Object> buffer(receiver->get_buffer(), i_isolate); | 575 i::Handle<i::Object> buffer(receiver->GetInternalField(kWasmMemoryBuffer), |
| 576 i_isolate); |
555 DCHECK(buffer->IsJSArrayBuffer()); | 577 DCHECK(buffer->IsJSArrayBuffer()); |
556 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); | 578 v8::ReturnValue<v8::Value> return_value = args.GetReturnValue(); |
557 return_value.Set(Utils::ToLocal(buffer)); | 579 return_value.Set(Utils::ToLocal(buffer)); |
558 } | 580 } |
559 } // namespace | 581 } // namespace |
560 | 582 |
561 // TODO(titzer): we use the API to create the function template because the | 583 // TODO(titzer): we use the API to create the function template because the |
562 // internal guts are too ugly to replicate here. | 584 // internal guts are too ugly to replicate here. |
563 static i::Handle<i::FunctionTemplateInfo> NewTemplate(i::Isolate* i_isolate, | 585 static i::Handle<i::FunctionTemplateInfo> NewTemplate(i::Isolate* i_isolate, |
564 FunctionCallback func) { | 586 FunctionCallback func) { |
(...skipping 193 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
758 i::Handle<i::Symbol> symbol(isolate->context()->wasm_memory_sym(), isolate); | 780 i::Handle<i::Symbol> symbol(isolate->context()->wasm_memory_sym(), isolate); |
759 return HasBrand(value, symbol); | 781 return HasBrand(value, symbol); |
760 } | 782 } |
761 | 783 |
762 bool WasmJs::IsWasmTableObject(Isolate* isolate, Handle<Object> value) { | 784 bool WasmJs::IsWasmTableObject(Isolate* isolate, Handle<Object> value) { |
763 i::Handle<i::Symbol> symbol(isolate->context()->wasm_table_sym(), isolate); | 785 i::Handle<i::Symbol> symbol(isolate->context()->wasm_table_sym(), isolate); |
764 return HasBrand(value, symbol); | 786 return HasBrand(value, symbol); |
765 } | 787 } |
766 } // namespace internal | 788 } // namespace internal |
767 } // namespace v8 | 789 } // namespace v8 |
OLD | NEW |