OLD | NEW |
1 // Copyright 2012 the V8 project authors. All rights reserved. | 1 // Copyright 2012 the V8 project authors. All rights reserved. |
2 // Redistribution and use in source and binary forms, with or without | 2 // Redistribution and use in source and binary forms, with or without |
3 // modification, are permitted provided that the following conditions are | 3 // modification, are permitted provided that the following conditions are |
4 // met: | 4 // met: |
5 // | 5 // |
6 // * Redistributions of source code must retain the above copyright | 6 // * Redistributions of source code must retain the above copyright |
7 // notice, this list of conditions and the following disclaimer. | 7 // notice, this list of conditions and the following disclaimer. |
8 // * Redistributions in binary form must reproduce the above | 8 // * Redistributions in binary form must reproduce the above |
9 // copyright notice, this list of conditions and the following | 9 // copyright notice, this list of conditions and the following |
10 // disclaimer in the documentation and/or other materials provided | 10 // disclaimer in the documentation and/or other materials provided |
(...skipping 14 matching lines...) Expand all Loading... |
25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE | 25 // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE |
26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. | 26 // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. |
27 | 27 |
28 #ifndef V8_OPTIMIZING_COMPILER_THREAD_H_ | 28 #ifndef V8_OPTIMIZING_COMPILER_THREAD_H_ |
29 #define V8_OPTIMIZING_COMPILER_THREAD_H_ | 29 #define V8_OPTIMIZING_COMPILER_THREAD_H_ |
30 | 30 |
31 #include "atomicops.h" | 31 #include "atomicops.h" |
32 #include "flags.h" | 32 #include "flags.h" |
33 #include "platform.h" | 33 #include "platform.h" |
34 #include "unbound-queue-inl.h" | 34 #include "unbound-queue-inl.h" |
| 35 #include "time/time.h" |
35 | 36 |
36 namespace v8 { | 37 namespace v8 { |
37 namespace internal { | 38 namespace internal { |
38 | 39 |
39 class HOptimizedGraphBuilder; | 40 class HOptimizedGraphBuilder; |
40 class OptimizingCompiler; | 41 class OptimizingCompiler; |
41 class SharedFunctionInfo; | 42 class SharedFunctionInfo; |
42 | 43 |
43 class OptimizingCompilerThread : public Thread { | 44 class OptimizingCompilerThread : public Thread { |
44 public: | 45 public: |
45 explicit OptimizingCompilerThread(Isolate *isolate) : | 46 explicit OptimizingCompilerThread(Isolate *isolate) : |
46 Thread("OptimizingCompilerThread"), | 47 Thread("OptimizingCompilerThread"), |
47 #ifdef DEBUG | 48 #ifdef DEBUG |
48 thread_id_(0), | 49 thread_id_(0), |
49 thread_id_mutex_(OS::CreateMutex()), | 50 thread_id_mutex_(OS::CreateMutex()), |
50 #endif | 51 #endif |
51 isolate_(isolate), | 52 isolate_(isolate), |
52 stop_semaphore_(OS::CreateSemaphore(0)), | 53 stop_semaphore_(OS::CreateSemaphore(0)), |
53 input_queue_semaphore_(OS::CreateSemaphore(0)), | 54 input_queue_semaphore_(OS::CreateSemaphore(0)), |
54 install_mutex_(OS::CreateMutex()), | 55 install_mutex_(OS::CreateMutex()) { |
55 time_spent_compiling_(0), | |
56 time_spent_total_(0) { | |
57 NoBarrier_Store(&stop_thread_, static_cast<AtomicWord>(CONTINUE)); | 56 NoBarrier_Store(&stop_thread_, static_cast<AtomicWord>(CONTINUE)); |
58 NoBarrier_Store(&queue_length_, static_cast<AtomicWord>(0)); | 57 NoBarrier_Store(&queue_length_, static_cast<AtomicWord>(0)); |
59 } | 58 } |
60 | 59 |
61 void Run(); | 60 void Run(); |
62 void Stop(); | 61 void Stop(); |
63 void Flush(); | 62 void Flush(); |
64 void QueueForOptimization(OptimizingCompiler* optimizing_compiler); | 63 void QueueForOptimization(OptimizingCompiler* optimizing_compiler); |
65 void InstallOptimizedFunctions(); | 64 void InstallOptimizedFunctions(); |
66 | 65 |
(...skipping 38 matching lines...) Expand 10 before | Expand all | Expand 10 after Loading... |
105 #endif | 104 #endif |
106 | 105 |
107 Isolate* isolate_; | 106 Isolate* isolate_; |
108 Semaphore* stop_semaphore_; | 107 Semaphore* stop_semaphore_; |
109 Semaphore* input_queue_semaphore_; | 108 Semaphore* input_queue_semaphore_; |
110 UnboundQueue<OptimizingCompiler*> input_queue_; | 109 UnboundQueue<OptimizingCompiler*> input_queue_; |
111 UnboundQueue<OptimizingCompiler*> output_queue_; | 110 UnboundQueue<OptimizingCompiler*> output_queue_; |
112 Mutex* install_mutex_; | 111 Mutex* install_mutex_; |
113 volatile AtomicWord stop_thread_; | 112 volatile AtomicWord stop_thread_; |
114 volatile Atomic32 queue_length_; | 113 volatile Atomic32 queue_length_; |
115 int64_t time_spent_compiling_; | 114 TimeDelta time_spent_compiling_; |
116 int64_t time_spent_total_; | 115 TimeDelta time_spent_total_; |
117 }; | 116 }; |
118 | 117 |
119 } } // namespace v8::internal | 118 } } // namespace v8::internal |
120 | 119 |
121 #endif // V8_OPTIMIZING_COMPILER_THREAD_H_ | 120 #endif // V8_OPTIMIZING_COMPILER_THREAD_H_ |
OLD | NEW |