Index: src/profiler/tick-sample.h |
diff --git a/src/profiler/sampler.h b/src/profiler/tick-sample.h |
similarity index 47% |
copy from src/profiler/sampler.h |
copy to src/profiler/tick-sample.h |
index 04c8f0446cb940d1397e33e4247e87ad77759139..fa2cf212782c743a950392ea1d8b4a671d1199eb 100644 |
--- a/src/profiler/sampler.h |
+++ b/src/profiler/tick-sample.h |
@@ -2,12 +2,11 @@ |
// Use of this source code is governed by a BSD-style license that can be |
// found in the LICENSE file. |
-#ifndef V8_PROFILER_SAMPLER_H_ |
-#define V8_PROFILER_SAMPLER_H_ |
+#ifndef V8_PROFILER_TICK_SAMPLE_H_ |
+#define V8_PROFILER_TICK_SAMPLE_H_ |
#include "include/v8.h" |
-#include "src/base/atomicops.h" |
#include "src/base/platform/time.h" |
#include "src/frames.h" |
#include "src/globals.h" |
@@ -61,88 +60,9 @@ struct TickSample { |
StackFrame::Type top_frame_type : 5; |
}; |
-class Sampler { |
- public: |
- // Initializes the Sampler support. Called once at VM startup. |
- static void SetUp(); |
- static void TearDown(); |
- |
- // Initialize sampler. |
- Sampler(Isolate* isolate, int interval); |
- virtual ~Sampler(); |
- |
- Isolate* isolate() const { return isolate_; } |
- int interval() const { return interval_; } |
- |
- // Performs stack sampling. |
- void SampleStack(const v8::RegisterState& regs); |
- |
- // Start and stop sampler. |
- void Start(); |
- void Stop(); |
- |
- // Whether the sampling thread should use this Sampler for CPU profiling? |
- bool IsProfiling() const { |
- return base::NoBarrier_Load(&profiling_) > 0 && |
- !base::NoBarrier_Load(&has_processing_thread_); |
- } |
- void IncreaseProfilingDepth(); |
- void DecreaseProfilingDepth(); |
- |
- // Whether the sampler is running (that is, consumes resources). |
- bool IsActive() const { return base::NoBarrier_Load(&active_); } |
- |
- // CpuProfiler collects samples by calling DoSample directly |
- // without calling Start. To keep it working, we register the sampler |
- // with the CpuProfiler. |
- bool IsRegistered() const { return base::NoBarrier_Load(®istered_); } |
- |
- void DoSample(); |
- // If true next sample must be initiated on the profiler event processor |
- // thread right after latest sample is processed. |
- void SetHasProcessingThread(bool value) { |
- base::NoBarrier_Store(&has_processing_thread_, value); |
- } |
- |
- // Used in tests to make sure that stack sampling is performed. |
- unsigned js_sample_count() const { return js_sample_count_; } |
- unsigned external_sample_count() const { return external_sample_count_; } |
- void StartCountingSamples() { |
- js_sample_count_ = 0; |
- external_sample_count_ = 0; |
- is_counting_samples_ = true; |
- } |
- |
- class PlatformData; |
- PlatformData* platform_data() const { return data_; } |
- |
- protected: |
- // This method is called for each sampling period with the current |
- // program counter. |
- virtual void Tick(TickSample* sample) = 0; |
- |
- private: |
- void SetActive(bool value) { base::NoBarrier_Store(&active_, value); } |
- |
- void SetRegistered(bool value) { base::NoBarrier_Store(®istered_, value); } |
- |
- Isolate* isolate_; |
- const int interval_; |
- base::Atomic32 profiling_; |
- base::Atomic32 has_processing_thread_; |
- base::Atomic32 active_; |
- base::Atomic32 registered_; |
- PlatformData* data_; // Platform specific data. |
- // Counts stack samples taken in various VM states. |
- bool is_counting_samples_; |
- unsigned js_sample_count_; |
- unsigned external_sample_count_; |
- DISALLOW_IMPLICIT_CONSTRUCTORS(Sampler); |
-}; |
- |
#if defined(USE_SIMULATOR) |
-class SimulatorHelper : AllStatic { |
+class SimulatorHelper { |
public: |
// Returns true if register values were successfully retrieved |
// from the simulator, otherwise returns false. |
@@ -150,8 +70,7 @@ class SimulatorHelper : AllStatic { |
}; |
#endif // USE_SIMULATOR |
- |
} // namespace internal |
} // namespace v8 |
-#endif // V8_PROFILER_SAMPLER_H_ |
+#endif // V8_PROFILER_TICK_SAMPLE_H_ |