blob: 36fe5ef5a2a9ee6061385a1e80dc06328bd4f7a6 [file] [log] [blame]
/*
* Copyright (C) 2018 The Android Open Source Project
*
* Licensed under the Apache License, Version 2.0 (the "License");
* you may not use this file except in compliance with the License.
* You may obtain a copy of the License at
*
* http://www.apache.org/licenses/LICENSE-2.0
*
* Unless required by applicable law or agreed to in writing, software
* distributed under the License is distributed on an "AS IS" BASIS,
* WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied.
* See the License for the specific language governing permissions and
* limitations under the License.
*/
#ifndef SRC_TRACE_PROCESSOR_SLICE_TRACKER_H_
#define SRC_TRACE_PROCESSOR_SLICE_TRACKER_H_
#include <stdint.h>
#include "src/trace_processor/args_tracker.h"
#include "src/trace_processor/trace_storage.h"
namespace perfetto {
namespace trace_processor {
class ArgsTracker;
class TraceProcessorContext;
class SliceTracker {
public:
using SetArgsCallback = std::function<void(ArgsTracker::BoundInserter*)>;
explicit SliceTracker(TraceProcessorContext*);
virtual ~SliceTracker();
// virtual for testing
virtual base::Optional<uint32_t> Begin(
int64_t timestamp,
TrackId track_id,
StringId category,
StringId name,
SetArgsCallback args_callback = SetArgsCallback());
void BeginGpu(tables::GpuSliceTable::Row row,
SetArgsCallback args_callback = SetArgsCallback());
// virtual for testing
virtual base::Optional<uint32_t> Scoped(
int64_t timestamp,
TrackId track_id,
StringId category,
StringId name,
int64_t duration,
SetArgsCallback args_callback = SetArgsCallback());
void ScopedGpu(const tables::GpuSliceTable::Row& row,
SetArgsCallback args_callback = SetArgsCallback());
// virtual for testing
virtual base::Optional<uint32_t> End(
int64_t timestamp,
TrackId track_id,
StringId opt_category = {},
StringId opt_name = {},
SetArgsCallback args_callback = SetArgsCallback());
// TODO(lalitm): eventually this method should become End and End should
// be renamed EndChrome.
base::Optional<SliceId> EndGpu(
int64_t ts,
TrackId track_id,
SetArgsCallback args_callback = SetArgsCallback());
void FlushPendingSlices();
private:
using SlicesStack = std::vector<std::pair<uint32_t /* row */, ArgsTracker>>;
using StackMap = std::unordered_map<TrackId, SlicesStack>;
base::Optional<uint32_t> StartSlice(int64_t timestamp,
TrackId track_id,
SetArgsCallback args_callback,
std::function<SliceId()> inserter);
base::Optional<SliceId> CompleteSlice(
int64_t timestamp,
TrackId track_id,
SetArgsCallback args_callback,
std::function<base::Optional<uint32_t>(const SlicesStack&)> finder);
void MaybeCloseStack(int64_t end_ts, SlicesStack*);
base::Optional<uint32_t> MatchingIncompleteSliceIndex(
const SlicesStack& stack,
StringId name,
StringId category);
int64_t GetStackHash(const SlicesStack&);
// Timestamp of the previous event. Used to discard events arriving out
// of order.
int64_t prev_timestamp_ = 0;
TraceProcessorContext* const context_;
StackMap stacks_;
};
} // namespace trace_processor
} // namespace perfetto
#endif // SRC_TRACE_PROCESSOR_SLICE_TRACKER_H_