WebAssembly: poison JS object's secrets
[WebKit-https.git] / Source / JavaScriptCore / wasm / js / JSWebAssemblyCodeBlock.h
1 /*
2  * Copyright (C) 2017-2018 Apple Inc. All rights reserved.
3  *
4  * Redistribution and use in source and binary forms, with or without
5  * modification, are permitted provided that the following conditions
6  * are met:
7  * 1. Redistributions of source code must retain the above copyright
8  *    notice, this list of conditions and the following disclaimer.
9  * 2. Redistributions in binary form must reproduce the above copyright
10  *    notice, this list of conditions and the following disclaimer in the
11  *    documentation and/or other materials provided with the distribution.
12  *
13  * THIS SOFTWARE IS PROVIDED BY APPLE INC. ``AS IS'' AND ANY
14  * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
15  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
16  * PURPOSE ARE DISCLAIMED.  IN NO EVENT SHALL APPLE INC. OR
17  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
18  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
19  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR
20  * PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY
21  * OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
22  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE
23  * OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
24  */
25
26 #pragma once
27
28 #if ENABLE(WEBASSEMBLY)
29
30 #include "CallLinkInfo.h"
31 #include "JSCPoison.h"
32 #include "JSCell.h"
33 #include "PromiseDeferredTimer.h"
34 #include "Structure.h"
35 #include "UnconditionalFinalizer.h"
36 #include "WasmCallee.h"
37 #include "WasmFormat.h"
38 #include "WasmModule.h"
39 #include <wtf/Bag.h>
40 #include <wtf/Ref.h>
41 #include <wtf/Vector.h>
42
43 namespace JSC {
44
45 class JSWebAssemblyMemory;
46
47 namespace Wasm {
48 class Plan;
49 }
50
51 class JSWebAssemblyCodeBlock final : public JSCell {
52 public:
53     typedef JSCell Base;
54     static const unsigned StructureFlags = Base::StructureFlags | StructureIsImmortal;
55
56     static JSWebAssemblyCodeBlock* create(VM&, Ref<Wasm::CodeBlock>, const Wasm::ModuleInformation&);
57     static Structure* createStructure(VM& vm, JSGlobalObject* globalObject, JSValue prototype)
58     {
59         return Structure::create(vm, globalObject, prototype, TypeInfo(CellType, StructureFlags), info());
60     }
61
62     template<typename CellType>
63     static CompleteSubspace* subspaceFor(VM& vm)
64     {
65         return &vm.webAssemblyCodeBlockSpace;
66     }
67
68     Wasm::CodeBlock& codeBlock() { return m_codeBlock.get(); }
69     
70     void* wasmToEmbedderStubExecutableAddress(size_t importFunctionNum) { return m_wasmToJSExitStubs[importFunctionNum].code().executableAddress(); }
71
72     void finishCreation(VM&);
73
74     void clearJSCallICs(VM&);
75
76     bool runnable() const { return !m_errorMessage; }
77
78     String errorMessage()
79     {
80         ASSERT(!runnable());
81         return m_errorMessage;
82     }
83
84 private:
85     JSWebAssemblyCodeBlock(VM&, Ref<Wasm::CodeBlock>&&, const Wasm::ModuleInformation&);
86     DECLARE_EXPORT_INFO;
87     static const bool needsDestruction = true;
88     static void destroy(JSCell*);
89     static void visitChildren(JSCell*, SlotVisitor&);
90
91     class UnconditionalFinalizer : public JSC::UnconditionalFinalizer {
92         void finalizeUnconditionally() override;
93     };
94
95     PoisonedRef<JSWebAssemblyCodeBlockPoison, Wasm::CodeBlock> m_codeBlock;
96     Vector<MacroAssemblerCodeRef> m_wasmToJSExitStubs;
97     UnconditionalFinalizer m_unconditionalFinalizer;
98     Bag<CallLinkInfo> m_callLinkInfos;
99     String m_errorMessage;
100 };
101
102 } // namespace JSC
103
104 #endif // ENABLE(WEBASSEMBLY)