blob: 8483d44300a6113fe83120ac1a9285f1ddc77f32 (
plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
|
/* -*- Mode: C++; tab-width: 8; indent-tabs-mode: nil; c-basic-offset: 2 -*-
* vim: set ts=8 sts=2 et sw=2 tw=80:
* This Source Code Form is subject to the terms of the Mozilla Public
* License, v. 2.0. If a copy of the MPL was not distributed with this
* file, You can obtain one at http://mozilla.org/MPL/2.0/. */
#include "vm/StencilCache.h"
#include "frontend/CompilationStencil.h"
#include "js/experimental/JSStencil.h"
#include "vm/MutexIDs.h"
js::StencilCache::StencilCache()
: cache(js::mutexid::StencilCache), enabled(false) {}
js::StencilCache::AccessKey js::StencilCache::isSourceCached(
ScriptSource* src) {
if (!enabled) {
return cache.noAccess();
}
AccessKey lock(cache.lock());
if (!enabled) {
// As we checked the flag before taking the lock, we have to check again to
// avoid races on the cache manipulation.
return cache.noAccess();
}
if (!lock->watched.has(src)) {
// If the source does not have any cached function, and we do not expect to
// cache any delazification in the future, then skip any cache handling.
return cache.noAccess();
}
return lock;
}
bool js::StencilCache::startCaching(RefPtr<ScriptSource>&& src) {
auto guard = cache.lock();
if (!guard->watched.putNew(std::move(src))) {
return false;
}
enabled = true;
return true;
}
js::frontend::CompilationStencil* js::StencilCache::lookup(
AccessKey& guard, const StencilContext& key) {
auto ptr = guard->functions.lookup(key);
if (!ptr) {
return nullptr;
}
return ptr->value().get();
}
bool js::StencilCache::putNew(AccessKey& guard, const StencilContext& key,
js::frontend::CompilationStencil* value) {
return guard->functions.putNew(key, value);
}
// Important: This function should not be called within a scope checking for
// isSourceCached, as this would cause a dead-lock.
void js::StencilCache::clearAndDisable() {
auto guard = cache.lock();
guard->functions.clearAndCompact();
guard->watched.clearAndCompact();
enabled = false;
}
|