/* * 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. */ #include "src/trace_processor/types/trace_processor_context.h" #include #include "src/trace_processor/forwarding_trace_parser.h" #include "src/trace_processor/importers/common/args_tracker.h" #include "src/trace_processor/importers/common/args_translation_table.h" #include "src/trace_processor/importers/common/async_track_set_tracker.h" #include "src/trace_processor/importers/common/chunked_trace_reader.h" #include "src/trace_processor/importers/common/clock_converter.h" #include "src/trace_processor/importers/common/clock_tracker.h" #include "src/trace_processor/importers/common/cpu_tracker.h" #include "src/trace_processor/importers/common/deobfuscation_mapping_table.h" #include "src/trace_processor/importers/common/event_tracker.h" #include "src/trace_processor/importers/common/flow_tracker.h" #include "src/trace_processor/importers/common/global_args_tracker.h" #include "src/trace_processor/importers/common/machine_tracker.h" #include "src/trace_processor/importers/common/mapping_tracker.h" #include "src/trace_processor/importers/common/metadata_tracker.h" #include "src/trace_processor/importers/common/process_track_translation_table.h" #include "src/trace_processor/importers/common/process_tracker.h" #include "src/trace_processor/importers/common/sched_event_tracker.h" #include "src/trace_processor/importers/common/slice_tracker.h" #include "src/trace_processor/importers/common/slice_translation_table.h" #include "src/trace_processor/importers/common/stack_profile_tracker.h" #include "src/trace_processor/importers/common/track_tracker.h" #include "src/trace_processor/importers/ftrace/ftrace_module.h" #include "src/trace_processor/importers/proto/chrome_track_event.descriptor.h" #include "src/trace_processor/importers/proto/multi_machine_trace_manager.h" #include "src/trace_processor/importers/proto/perf_sample_tracker.h" #include "src/trace_processor/importers/proto/proto_importer_module.h" #include "src/trace_processor/importers/proto/track_event.descriptor.h" #include "src/trace_processor/importers/proto/track_event_module.h" #include "src/trace_processor/sorter/trace_sorter.h" #include "src/trace_processor/trace_reader_registry.h" #include "src/trace_processor/types/destructible.h" namespace perfetto { namespace trace_processor { TraceProcessorContext::TraceProcessorContext(const InitArgs& args) : config(args.config), storage(args.storage) { reader_registry = std::make_unique(this); // Init the trackers. machine_tracker.reset(new MachineTracker(this, args.raw_machine_id)); if (!machine_id()) { multi_machine_trace_manager.reset(new MultiMachineTraceManager(this)); } track_tracker.reset(new TrackTracker(this)); async_track_set_tracker.reset(new AsyncTrackSetTracker(this)); args_tracker.reset(new ArgsTracker(this)); args_translation_table.reset(new ArgsTranslationTable(storage.get())); slice_tracker.reset(new SliceTracker(this)); slice_translation_table.reset(new SliceTranslationTable(storage.get())); flow_tracker.reset(new FlowTracker(this)); event_tracker.reset(new EventTracker(this)); sched_event_tracker.reset(new SchedEventTracker(this)); process_tracker.reset(new ProcessTracker(this)); process_track_translation_table.reset( new ProcessTrackTranslationTable(storage.get())); clock_tracker.reset(new ClockTracker(this)); clock_converter.reset(new ClockConverter(this)); mapping_tracker.reset(new MappingTracker(this)); perf_sample_tracker.reset(new PerfSampleTracker(this)); stack_profile_tracker.reset(new StackProfileTracker(this)); metadata_tracker.reset(new MetadataTracker(storage.get())); cpu_tracker.reset(new CpuTracker(this)); global_args_tracker.reset(new GlobalArgsTracker(storage.get())); { descriptor_pool_.reset(new DescriptorPool()); auto status = descriptor_pool_->AddFromFileDescriptorSet( kTrackEventDescriptor.data(), kTrackEventDescriptor.size()); PERFETTO_DCHECK(status.ok()); status = descriptor_pool_->AddFromFileDescriptorSet( kChromeTrackEventDescriptor.data(), kChromeTrackEventDescriptor.size()); PERFETTO_DCHECK(status.ok()); } slice_tracker->SetOnSliceBeginCallback( [this](TrackId track_id, SliceId slice_id) { flow_tracker->ClosePendingEventsOnTrack(track_id, slice_id); }); } TraceProcessorContext::TraceProcessorContext() = default; TraceProcessorContext::~TraceProcessorContext() = default; std::optional TraceProcessorContext::machine_id() const { if (!machine_tracker) { // Doesn't require that |machine_tracker| is initialzed, e.g. in unit tests. return std::nullopt; } return machine_tracker->machine_id(); } } // namespace trace_processor } // namespace perfetto