]> git.saurik.com Git - apple/javascriptcore.git/blame - jit/ExecutableAllocator.h
JavaScriptCore-1097.13.tar.gz
[apple/javascriptcore.git] / jit / ExecutableAllocator.h
CommitLineData
9dae56ea
A
1/*
2 * Copyright (C) 2008 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#ifndef ExecutableAllocator_h
27#define ExecutableAllocator_h
6fe7ccc8 28#include "JITCompilationEffort.h"
f9bf01c6 29#include <stddef.h> // for ptrdiff_t
ba379fdc 30#include <limits>
9dae56ea 31#include <wtf/Assertions.h>
6fe7ccc8 32#include <wtf/MetaAllocatorHandle.h>
14957cd0 33#include <wtf/PageAllocation.h>
9dae56ea
A
34#include <wtf/PassRefPtr.h>
35#include <wtf/RefCounted.h>
ba379fdc 36#include <wtf/UnusedParam.h>
9dae56ea
A
37#include <wtf/Vector.h>
38
14957cd0 39#if OS(IOS)
ba379fdc 40#include <libkern/OSCacheControl.h>
f9bf01c6
A
41#endif
42
6fe7ccc8
A
43#if OS(IOS) || OS(QNX)
44#include <sys/mman.h>
f9bf01c6
A
45#endif
46
4e4e5a6f
A
47#if CPU(MIPS) && OS(LINUX)
48#include <sys/cachectl.h>
49#endif
50
14957cd0
A
51#if CPU(SH4) && OS(LINUX)
52#include <asm/cachectl.h>
53#include <asm/unistd.h>
54#include <sys/syscall.h>
55#include <unistd.h>
56#endif
57
f9bf01c6
A
58#if OS(WINCE)
59// From pkfuncs.h (private header file from the Platform Builder)
60#define CACHE_SYNC_ALL 0x07F
61extern "C" __declspec(dllimport) void CacheRangeFlush(LPVOID pAddr, DWORD dwLength, DWORD dwFlags);
62#endif
9dae56ea 63
6fe7ccc8 64#define JIT_ALLOCATOR_LARGE_ALLOC_SIZE (pageSize() * 4)
9dae56ea 65
ba379fdc
A
66#if ENABLE(ASSEMBLER_WX_EXCLUSIVE)
67#define PROTECTION_FLAGS_RW (PROT_READ | PROT_WRITE)
68#define PROTECTION_FLAGS_RX (PROT_READ | PROT_EXEC)
14957cd0 69#define EXECUTABLE_POOL_WRITABLE false
ba379fdc 70#else
14957cd0 71#define EXECUTABLE_POOL_WRITABLE true
ba379fdc
A
72#endif
73
74namespace JSC {
75
6fe7ccc8
A
76class JSGlobalData;
77void releaseExecutableMemory(JSGlobalData&);
78
ba379fdc
A
79inline size_t roundUpAllocationSize(size_t request, size_t granularity)
80{
81 if ((std::numeric_limits<size_t>::max() - granularity) <= request)
82 CRASH(); // Allocation is too large
83
84 // Round up to next page boundary
85 size_t size = request + (granularity - 1);
86 size = size & ~(granularity - 1);
87 ASSERT(size >= request);
88 return size;
89}
90
91}
92
9dae56ea
A
93namespace JSC {
94
6fe7ccc8
A
95typedef WTF::MetaAllocatorHandle ExecutableMemoryHandle;
96
97#if ENABLE(ASSEMBLER)
14957cd0 98
14957cd0 99#if ENABLE(EXECUTABLE_ALLOCATOR_DEMAND)
6fe7ccc8 100class DemandExecutableAllocator;
14957cd0 101#endif
9dae56ea
A
102
103class ExecutableAllocator {
14957cd0 104 enum ProtectionSetting { Writable, Executable };
ba379fdc 105
9dae56ea 106public:
6fe7ccc8
A
107 ExecutableAllocator(JSGlobalData&);
108 ~ExecutableAllocator();
109
110 static void initializeAllocator();
9dae56ea 111
4e4e5a6f 112 bool isValid() const;
14957cd0
A
113
114 static bool underMemoryPressure();
6fe7ccc8
A
115
116 static double memoryPressureMultiplier(size_t addedMemoryUsage);
117
118#if ENABLE(META_ALLOCATOR_PROFILE)
119 static void dumpProfile();
120#else
121 static void dumpProfile() { }
122#endif
14957cd0 123
6fe7ccc8 124 PassRefPtr<ExecutableMemoryHandle> allocate(JSGlobalData&, size_t sizeInBytes, void* ownerUID, JITCompilationEffort);
9dae56ea 125
ba379fdc
A
126#if ENABLE(ASSEMBLER_WX_EXCLUSIVE)
127 static void makeWritable(void* start, size_t size)
128 {
129 reprotectRegion(start, size, Writable);
130 }
131
132 static void makeExecutable(void* start, size_t size)
133 {
134 reprotectRegion(start, size, Executable);
135 }
136#else
137 static void makeWritable(void*, size_t) {}
138 static void makeExecutable(void*, size_t) {}
139#endif
140
14957cd0 141 static size_t committedByteCount();
ba379fdc 142
9dae56ea 143private:
ba379fdc
A
144
145#if ENABLE(ASSEMBLER_WX_EXCLUSIVE)
14957cd0 146 static void reprotectRegion(void*, size_t, ProtectionSetting);
6fe7ccc8
A
147#if ENABLE(EXECUTABLE_ALLOCATOR_DEMAND)
148 // We create a MetaAllocator for each JS global object.
149 OwnPtr<DemandExecutableAllocator> m_allocator;
150 DemandExecutableAllocator* allocator() { return m_allocator.get(); }
151#endif
ba379fdc
A
152#endif
153
9dae56ea
A
154};
155
f9bf01c6 156
14957cd0
A
157#else
158
14957cd0
A
159
160class ExecutableAllocator {
161public:
162 static size_t committedByteCount();
163};
164
14957cd0
A
165
166#endif // ENABLE(JIT) && ENABLE(ASSEMBLER)
9dae56ea 167
6fe7ccc8
A
168} // namespace JSC
169
9dae56ea 170#endif // !defined(ExecutableAllocator)