darling-JavaScriptCore/wasm/WasmModule.h

83 lines
3.0 KiB
C++

/*
* Copyright (C) 2017 Apple Inc. All rights reserved.
*
* Redistribution and use in source and binary forms, with or without
* modification, are permitted provided that the following conditions
* are met:
* 1. Redistributions of source code must retain the above copyright
* notice, this list of conditions and the following disclaimer.
* 2. Redistributions in binary form must reproduce the above copyright
* notice, this list of conditions and the following disclaimer in the
* documentation and/or other materials provided with the distribution.
*
* THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
* EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
* IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
* PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL APPLE INC. OR
* CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
* EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
* PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
* PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
* OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
* (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
* OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
*/
#pragma once
#if ENABLE(WEBASSEMBLY)
#include "WasmCodeBlock.h"
#include "WasmEmbedder.h"
#include "WasmMemory.h"
#include <wtf/Expected.h>
#include <wtf/Lock.h>
#include <wtf/SharedTask.h>
#include <wtf/ThreadSafeRefCounted.h>
namespace JSC { namespace Wasm {
class LLIntPlan;
struct Context;
struct ModuleInformation;
using SignatureIndex = uint64_t;
class Module : public ThreadSafeRefCounted<Module> {
public:
using ValidationResult = Expected<RefPtr<Module>, String>;
typedef void CallbackType(ValidationResult&&);
using AsyncValidationCallback = RefPtr<SharedTask<CallbackType>>;
static ValidationResult validateSync(Context*, Vector<uint8_t>&& source);
static void validateAsync(Context*, Vector<uint8_t>&& source, Module::AsyncValidationCallback&&);
static Ref<Module> create(LLIntPlan& plan)
{
return adoptRef(*new Module(plan));
}
Wasm::SignatureIndex signatureIndexFromFunctionIndexSpace(unsigned functionIndexSpace) const;
const Wasm::ModuleInformation& moduleInformation() const { return m_moduleInformation.get(); }
Ref<CodeBlock> compileSync(Context*, MemoryMode);
void compileAsync(Context*, MemoryMode, CodeBlock::AsyncCompilationCallback&&);
JS_EXPORT_PRIVATE ~Module();
CodeBlock* codeBlockFor(MemoryMode mode) { return m_codeBlocks[static_cast<uint8_t>(mode)].get(); }
private:
Ref<CodeBlock> getOrCreateCodeBlock(Context*, MemoryMode);
Module(LLIntPlan&);
Ref<ModuleInformation> m_moduleInformation;
RefPtr<CodeBlock> m_codeBlocks[Wasm::NumberOfMemoryModes];
RefPtr<LLIntCallees> m_llintCallees;
MacroAssemblerCodeRef<B3CompilationPtrTag> m_llintEntryThunks;
Lock m_lock;
};
} } // namespace JSC::Wasm
#endif // ENABLE(WEBASSEMBLY)