12345678910111213141516171819202122232425262728293031323334353637383940414243444546474849505152535455565758596061626364656667 |
- // Copyright 2019 The Chromium Authors. All rights reserved.
- // Use of this source code is governed by a BSD-style license that can be
- // found in the LICENSE file.
- #ifndef BASE_PROFILER_PROFILE_BUILDER_H_
- #define BASE_PROFILER_PROFILE_BUILDER_H_
- #include <memory>
- #include "base/base_export.h"
- #include "base/macros.h"
- #include "base/optional.h"
- #include "base/profiler/frame.h"
- #include "base/profiler/metadata_recorder.h"
- #include "base/profiler/module_cache.h"
- #include "base/time/time.h"
- namespace base {
- // The ProfileBuilder interface allows the user to record profile information on
- // the fly in whatever format is desired. Functions are invoked by the profiler
- // on its own thread so must not block or perform expensive operations.
- class BASE_EXPORT ProfileBuilder {
- public:
- ProfileBuilder() = default;
- virtual ~ProfileBuilder() = default;
- // Gets the ModuleCache to be used by the StackSamplingProfiler when looking
- // up modules from addresses.
- virtual ModuleCache* GetModuleCache() = 0;
- // Records metadata to be associated with the current sample. To avoid
- // deadlock on locks taken by the suspended profiled thread, implementations
- // of this method must not execute any code that could take a lock, including
- // heap allocation or use of CHECK/DCHECK/LOG statements. Generally
- // implementations should simply atomically copy metadata state to be
- // associated with the sample.
- virtual void RecordMetadata(
- const MetadataRecorder::MetadataProvider& metadata_provider) {}
- // Applies the specified metadata |item| to samples collected in the range
- // [period_start, period_end), iff the profile already captured execution that
- // covers that range entirely. This restriction avoids bias in the results
- // towards samples in the middle of the period, at the expense of excluding
- // periods overlapping the start or end of the profile. |period_end| must be
- // <= TimeTicks::Now().
- virtual void ApplyMetadataRetrospectively(
- TimeTicks period_start,
- TimeTicks period_end,
- const MetadataRecorder::Item& item) {}
- // Records a new set of frames. Invoked when sampling a sample completes.
- virtual void OnSampleCompleted(std::vector<Frame> frames,
- TimeTicks sample_timestamp) = 0;
- // Finishes the profile construction with |profile_duration| and
- // |sampling_period|. Invoked when sampling a profile completes.
- virtual void OnProfileCompleted(TimeDelta profile_duration,
- TimeDelta sampling_period) = 0;
- private:
- DISALLOW_COPY_AND_ASSIGN(ProfileBuilder);
- };
- } // namespace base
- #endif // BASE_PROFILER_PROFILE_BUILDER_H_
|