| /* |
| * 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/trace_storage.h" |
| |
| namespace perfetto { |
| namespace trace_processor { |
| |
| class ArgsTracker; |
| class TraceProcessorContext; |
| |
| class SliceTracker { |
| public: |
| using SetArgsCallback = std::function<void(ArgsTracker*, RowId row_id)>; |
| |
| explicit SliceTracker(TraceProcessorContext*); |
| virtual ~SliceTracker(); |
| |
| base::Optional<uint32_t> BeginAndroid(int64_t timestamp, |
| uint32_t ftrace_tid, |
| uint32_t atrace_tgid, |
| StringId category, |
| StringId name); |
| |
| // virtual for testing |
| virtual base::Optional<uint32_t> Begin( |
| int64_t timestamp, |
| TrackId track_id, |
| int64_t ref, |
| RefType ref_type, |
| StringId category, |
| StringId name, |
| SetArgsCallback args_callback = SetArgsCallback()); |
| |
| // virtual for testing |
| virtual base::Optional<uint32_t> Scoped( |
| int64_t timestamp, |
| TrackId track_id, |
| int64_t ref, |
| RefType ref_type, |
| StringId category, |
| StringId name, |
| int64_t duration, |
| SetArgsCallback args_callback = SetArgsCallback()); |
| |
| base::Optional<uint32_t> EndAndroid(int64_t timestamp, |
| uint32_t ftrace_tid, |
| uint32_t atrace_tgid); |
| |
| // 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()); |
| |
| 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, |
| int64_t duration, |
| TrackId track_id, |
| int64_t ref, |
| RefType ref_type, |
| StringId category, |
| StringId name, |
| SetArgsCallback args_callback); |
| base::Optional<uint32_t> CompleteSlice(TrackId track_id); |
| |
| void MaybeCloseStack(int64_t end_ts, SlicesStack*); |
| base::Optional<size_t> MatchingIncompleteSliceIndex(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_; |
| std::unordered_map<uint32_t, uint32_t> ftrace_to_atrace_tgid_; |
| }; |
| |
| } // namespace trace_processor |
| } // namespace perfetto |
| |
| #endif // SRC_TRACE_PROCESSOR_SLICE_TRACKER_H_ |