| Index: src/wasm/wasm-objects.h
|
| diff --git a/src/wasm/wasm-objects.h b/src/wasm/wasm-objects.h
|
| new file mode 100644
|
| index 0000000000000000000000000000000000000000..d91bcc4fa075f68f23c1a37108b80f68f24165c5
|
| --- /dev/null
|
| +++ b/src/wasm/wasm-objects.h
|
| @@ -0,0 +1,300 @@
|
| +// Copyright 2016 the V8 project authors. All rights reserved.
|
| +// Use of this source code is governed by a BSD-style license that can be
|
| +// found in the LICENSE file.
|
| +
|
| +#ifndef V8_WASM_OBJECTS_H_
|
| +#define V8_WASM_OBJECTS_H_
|
| +
|
| +#include "src/objects-inl.h"
|
| +#include "src/wasm/managed.h"
|
| +
|
| +namespace v8 {
|
| +namespace internal {
|
| +namespace wasm {
|
| +struct WasmModule;
|
| +}
|
| +
|
| +class WasmCompiledModule;
|
| +class WasmDebugInfo;
|
| +class WasmInstanceObject;
|
| +
|
| +#define DECLARE_CASTS(name) \
|
| + static bool Is##name(Object* object); \
|
| + static name* cast(Object* object)
|
| +
|
| +#define DECLARE_ACCESSORS(name, type) \
|
| + type* get_##name(); \
|
| + void set_##name(type* value)
|
| +
|
| +#define DECLARE_OPTIONAL_ACCESSORS(name, type) \
|
| + bool has_##name(); \
|
| + type* get_##name(); \
|
| + void set_##name(type* value)
|
| +
|
| +// Representation of a WebAssembly.Module JavaScript-level object.
|
| +class WasmModuleObject : public JSObject {
|
| + public:
|
| + // TODO(titzer): add the brand as an internal field instead of a property.
|
| + enum Fields { kCompiledModule, kFieldCount };
|
| +
|
| + DECLARE_CASTS(WasmModuleObject);
|
| +
|
| + WasmCompiledModule* compiled_module();
|
| + wasm::WasmModule* module();
|
| + int num_functions();
|
| + bool is_asm_js();
|
| + int GetAsmWasmSourcePosition(int func_index, int byte_offset);
|
| + WasmDebugInfo* debug_info();
|
| + void set_debug_info(WasmDebugInfo* debug_info);
|
| + MaybeHandle<String> GetFunctionName(Isolate* isolate, int func_index);
|
| +
|
| + static Handle<WasmModuleObject> New(
|
| + Isolate* isolate, Handle<WasmCompiledModule> compiled_module);
|
| +};
|
| +
|
| +// Representation of a WebAssembly.Table JavaScript-level object.
|
| +class WasmTableObject : public JSObject {
|
| + public:
|
| + // TODO(titzer): add the brand as an internal field instead of a property.
|
| + enum Fields { kFunctions, kMaximum, kDispatchTables, kFieldCount };
|
| +
|
| + DECLARE_CASTS(WasmTableObject);
|
| + DECLARE_ACCESSORS(functions, FixedArray);
|
| +
|
| + FixedArray* get_dispatch_tables();
|
| + uint32_t current_length();
|
| + uint32_t maximum_length();
|
| +
|
| + static Handle<WasmTableObject> New(Isolate* isolate, uint32_t initial,
|
| + uint32_t maximum,
|
| + Handle<FixedArray>* js_functions);
|
| + static bool Grow(Handle<WasmTableObject> table, uint32_t count);
|
| + static Handle<FixedArray> AddDispatchTable(
|
| + Isolate* isolate, Handle<WasmTableObject> table,
|
| + Handle<WasmInstanceObject> instance, int table_index,
|
| + Handle<FixedArray> dispatch_table);
|
| +};
|
| +
|
| +// Representation of a WebAssembly.Memory JavaScript-level object.
|
| +class WasmMemoryObject : public JSObject {
|
| + public:
|
| + // TODO(titzer): add the brand as an internal field instead of a property.
|
| + enum Fields : uint8_t { kArrayBuffer, kMaximum, kInstance, kFieldCount };
|
| +
|
| + DECLARE_CASTS(WasmMemoryObject);
|
| + DECLARE_ACCESSORS(buffer, JSArrayBuffer);
|
| +
|
| + void AddInstance(WasmInstanceObject* object);
|
| + uint32_t current_pages();
|
| + int32_t maximum_pages(); // returns < 0 if there is no maximum
|
| +
|
| + static Handle<WasmMemoryObject> New(Isolate* isolate,
|
| + Handle<JSArrayBuffer> buffer,
|
| + int maximum);
|
| +
|
| + static bool Grow(Handle<WasmMemoryObject> memory, uint32_t count);
|
| +};
|
| +
|
| +// Representation of a WebAssembly.Instance JavaScript-level object.
|
| +class WasmInstanceObject : public JSObject {
|
| + public:
|
| + // TODO(titzer): add the brand as an internal field instead of a property.
|
| + enum Fields {
|
| + kCompiledModule,
|
| + kMemoryObject,
|
| + kMemoryArrayBuffer,
|
| + kGlobalsArrayBuffer,
|
| + kDebugInfo,
|
| + kFieldCount
|
| + };
|
| +
|
| + DECLARE_CASTS(WasmInstanceObject);
|
| +
|
| + DECLARE_ACCESSORS(compiled_module, WasmCompiledModule);
|
| + DECLARE_OPTIONAL_ACCESSORS(globals_buffer, JSArrayBuffer);
|
| + DECLARE_OPTIONAL_ACCESSORS(memory_buffer, JSArrayBuffer);
|
| + DECLARE_OPTIONAL_ACCESSORS(memory_object, WasmMemoryObject);
|
| + DECLARE_OPTIONAL_ACCESSORS(debug_info, WasmDebugInfo);
|
| +
|
| + WasmModuleObject* module_object();
|
| + wasm::WasmModule* module();
|
| +
|
| + static Handle<WasmInstanceObject> New(
|
| + Isolate* isolate, Handle<WasmCompiledModule> compiled_module);
|
| +};
|
| +
|
| +// Representation of an exported WASM function.
|
| +class WasmExportedFunction : public JSFunction {
|
| + public:
|
| + enum Fields { kInstance, kIndex, kFieldCount };
|
| +
|
| + DECLARE_CASTS(WasmExportedFunction);
|
| +
|
| + WasmInstanceObject* instance();
|
| + int function_index();
|
| +
|
| + static Handle<WasmExportedFunction> New(Isolate* isolate,
|
| + Handle<WasmInstanceObject> instance,
|
| + Handle<String> name,
|
| + Handle<Code> export_wrapper,
|
| + int arity, int func_index);
|
| +};
|
| +
|
| +class WasmCompiledModule : public FixedArray {
|
| + public:
|
| + enum Fields { kFieldCount };
|
| +
|
| + static WasmCompiledModule* cast(Object* fixed_array) {
|
| + SLOW_DCHECK(IsWasmCompiledModule(fixed_array));
|
| + return reinterpret_cast<WasmCompiledModule*>(fixed_array);
|
| + }
|
| +
|
| +#define WCM_OBJECT_OR_WEAK(TYPE, NAME, ID) \
|
| + Handle<TYPE> NAME() const { return handle(ptr_to_##NAME()); } \
|
| + \
|
| + MaybeHandle<TYPE> maybe_##NAME() const { \
|
| + if (has_##NAME()) return NAME(); \
|
| + return MaybeHandle<TYPE>(); \
|
| + } \
|
| + \
|
| + TYPE* ptr_to_##NAME() const { \
|
| + Object* obj = get(ID); \
|
| + if (!obj->Is##TYPE()) return nullptr; \
|
| + return TYPE::cast(obj); \
|
| + } \
|
| + \
|
| + void set_##NAME(Handle<TYPE> value) { set_ptr_to_##NAME(*value); } \
|
| + \
|
| + void set_ptr_to_##NAME(TYPE* value) { set(ID, value); } \
|
| + \
|
| + bool has_##NAME() const { return get(ID)->Is##TYPE(); } \
|
| + \
|
| + void reset_##NAME() { set_undefined(ID); }
|
| +
|
| +#define WCM_OBJECT(TYPE, NAME) WCM_OBJECT_OR_WEAK(TYPE, NAME, kID_##NAME)
|
| +
|
| +#define WCM_SMALL_NUMBER(TYPE, NAME) \
|
| + TYPE NAME() const { \
|
| + return static_cast<TYPE>(Smi::cast(get(kID_##NAME))->value()); \
|
| + } \
|
| + void set_##NAME(TYPE value) { set(kID_##NAME, Smi::FromInt(value)); }
|
| +
|
| +#define WCM_WEAK_LINK(TYPE, NAME) \
|
| + WCM_OBJECT_OR_WEAK(WeakCell, weak_##NAME, kID_##NAME); \
|
| + \
|
| + Handle<TYPE> NAME() const { \
|
| + return handle(TYPE::cast(weak_##NAME()->value())); \
|
| + }
|
| +
|
| +#define CORE_WCM_PROPERTY_TABLE(MACRO) \
|
| + MACRO(OBJECT, FixedArray, code_table) \
|
| + MACRO(OBJECT, Foreign, module_wrapper) \
|
| + MACRO(OBJECT, SeqOneByteString, module_bytes) \
|
| + MACRO(OBJECT, Script, asm_js_script) \
|
| + MACRO(OBJECT, FixedArray, function_tables) \
|
| + MACRO(OBJECT, FixedArray, empty_function_tables) \
|
| + MACRO(OBJECT, ByteArray, asm_js_offset_tables) \
|
| + MACRO(OBJECT, JSArrayBuffer, memory) \
|
| + MACRO(SMALL_NUMBER, uint32_t, min_mem_pages) \
|
| + MACRO(SMALL_NUMBER, uint32_t, max_mem_pages) \
|
| + MACRO(WEAK_LINK, WasmCompiledModule, next_instance) \
|
| + MACRO(WEAK_LINK, WasmCompiledModule, prev_instance) \
|
| + MACRO(WEAK_LINK, JSObject, owning_instance) \
|
| + MACRO(WEAK_LINK, JSObject, wasm_module)
|
| +
|
| +#if DEBUG
|
| +#define DEBUG_ONLY_TABLE(MACRO) MACRO(SMALL_NUMBER, uint32_t, instance_id)
|
| +#else
|
| +#define DEBUG_ONLY_TABLE(IGNORE)
|
| + uint32_t instance_id() const { return -1; }
|
| +#endif
|
| +
|
| +#define WCM_PROPERTY_TABLE(MACRO) \
|
| + CORE_WCM_PROPERTY_TABLE(MACRO) \
|
| + DEBUG_ONLY_TABLE(MACRO)
|
| +
|
| + private:
|
| + enum PropertyIndices {
|
| +#define INDICES(IGNORE1, IGNORE2, NAME) kID_##NAME,
|
| + WCM_PROPERTY_TABLE(INDICES) Count
|
| +#undef INDICES
|
| + };
|
| +
|
| + public:
|
| + static Handle<WasmCompiledModule> New(
|
| + Isolate* isolate, Handle<Managed<wasm::WasmModule>> module_wrapper);
|
| +
|
| + static Handle<WasmCompiledModule> Clone(Isolate* isolate,
|
| + Handle<WasmCompiledModule> module) {
|
| + Handle<WasmCompiledModule> ret = Handle<WasmCompiledModule>::cast(
|
| + isolate->factory()->CopyFixedArray(module));
|
| + ret->InitId();
|
| + ret->reset_weak_owning_instance();
|
| + ret->reset_weak_next_instance();
|
| + ret->reset_weak_prev_instance();
|
| + return ret;
|
| + }
|
| +
|
| + uint32_t mem_size() const;
|
| + uint32_t default_mem_size() const;
|
| +
|
| + wasm::WasmModule* module() const;
|
| +
|
| +#define DECLARATION(KIND, TYPE, NAME) WCM_##KIND(TYPE, NAME)
|
| + WCM_PROPERTY_TABLE(DECLARATION)
|
| +#undef DECLARATION
|
| +
|
| + static bool IsWasmCompiledModule(Object* obj);
|
| +
|
| + void PrintInstancesChain();
|
| +
|
| + static void RecreateModuleWrapper(Isolate* isolate,
|
| + Handle<FixedArray> compiled_module);
|
| +
|
| + private:
|
| + void InitId();
|
| +
|
| + DISALLOW_IMPLICIT_CONSTRUCTORS(WasmCompiledModule);
|
| +};
|
| +
|
| +class WasmDebugInfo : public FixedArray {
|
| + public:
|
| + enum class Fields { kFieldCount };
|
| +
|
| + static Handle<WasmDebugInfo> New(Handle<JSObject> wasm);
|
| +
|
| + static bool IsDebugInfo(Object* object);
|
| + static WasmDebugInfo* cast(Object* object);
|
| +
|
| + JSObject* wasm_instance();
|
| +
|
| + bool SetBreakPoint(int byte_offset);
|
| +
|
| + // Get the Script for the specified function.
|
| + static Script* GetFunctionScript(Handle<WasmDebugInfo> debug_info,
|
| + int func_index);
|
| +
|
| + // Disassemble the specified function from this module.
|
| + static Handle<String> DisassembleFunction(Handle<WasmDebugInfo> debug_info,
|
| + int func_index);
|
| +
|
| + // Get the offset table for the specified function, mapping from byte offsets
|
| + // to position in the disassembly.
|
| + // Returns an array with three entries per instruction: byte offset, line and
|
| + // column.
|
| + static Handle<FixedArray> GetFunctionOffsetTable(
|
| + Handle<WasmDebugInfo> debug_info, int func_index);
|
| +
|
| + // Get the asm.js source position from a byte offset.
|
| + // Must only be called if the associated wasm object was created from asm.js.
|
| + static int GetAsmJsSourcePosition(Handle<WasmDebugInfo> debug_info,
|
| + int func_index, int byte_offset);
|
| +};
|
| +
|
| +#undef DECLARE_ACCESSORS
|
| +#undef DECLARE_OPTIONAL_ACCESSORS
|
| +
|
| +} // namespace internal
|
| +} // namespace v8
|
| +
|
| +#endif // V8_WASM_OBJECTS_H_
|
|
|