2 * Copyright (C) 2012, 2013 Apple Inc. All rights reserved.
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions
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.
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.
26 #ifndef ProfilerDatabase_h
27 #define ProfilerDatabase_h
29 #include "JSCJSValue.h"
30 #include "ProfilerBytecodes.h"
31 #include "ProfilerCompilation.h"
32 #include "ProfilerCompilationKind.h"
33 #include <wtf/FastMalloc.h>
34 #include <wtf/HashMap.h>
35 #include <wtf/Noncopyable.h>
36 #include <wtf/PassRefPtr.h>
37 #include <wtf/SegmentedVector.h>
38 #include <wtf/ThreadingPrimitives.h>
39 #include <wtf/text/WTFString.h>
41 namespace JSC
{ namespace Profiler
{
44 WTF_MAKE_FAST_ALLOCATED
; WTF_MAKE_NONCOPYABLE(Database
);
46 JS_EXPORT_PRIVATE
Database(VM
&);
47 JS_EXPORT_PRIVATE
~Database();
49 int databaseID() const { return m_databaseID
; }
51 Bytecodes
* ensureBytecodesFor(CodeBlock
*);
52 void notifyDestruction(CodeBlock
*);
54 void addCompilation(PassRefPtr
<Compilation
>);
56 // Converts the database to a JavaScript object that is suitable for JSON stringification.
57 // Note that it's probably a good idea to use an ExecState* associated with a global
58 // object that is "clean" - i.e. array and object prototypes haven't had strange things
59 // done to them. And yes, it should be appropriate to just use a globalExec here.
60 JS_EXPORT_PRIVATE JSValue
toJS(ExecState
*) const;
62 // Converts the database to a JavaScript object using a private temporary global object,
63 // and then returns the JSON representation of that object.
64 JS_EXPORT_PRIVATE String
toJSON() const;
66 // Saves the JSON representation (from toJSON()) to the given file. Returns false if the
68 JS_EXPORT_PRIVATE
bool save(const char* filename
) const;
70 void registerToSaveAtExit(const char* filename
);
73 // Use a full-blown adaptive mutex because:
74 // - There is only one ProfilerDatabase per VM. The size overhead of the system's
75 // mutex is negligible if you only have one of them.
76 // - It's locked infrequently - once per bytecode generation, compilation, and
77 // code block collection - so the fact that the fast path still requires a
78 // function call is neglible.
79 // - It tends to be held for a while. Currently, we hold it while generating
80 // Profiler::Bytecodes for a CodeBlock. That's uncommon and shouldn't affect
81 // performance, but if we did have contention, we would want a sensible,
82 // power-aware backoff. An adaptive mutex will do this as a matter of course,
83 // but a spinlock won't.
85 typedef MutexLocker Locker
;
88 void addDatabaseToAtExit();
89 void removeDatabaseFromAtExit();
90 void performAtExitSave() const;
91 static Database
* removeFirstAtExitDatabase();
92 static void atExitCallback();
96 SegmentedVector
<Bytecodes
> m_bytecodes
;
97 HashMap
<CodeBlock
*, Bytecodes
*> m_bytecodesMap
;
98 Vector
<RefPtr
<Compilation
>> m_compilations
;
99 bool m_shouldSaveAtExit
;
100 CString m_atExitSaveFilename
;
101 Database
* m_nextRegisteredDatabase
;
105 } } // namespace JSC::Profiler
107 #endif // ProfilerDatabase_h