|  | /* | 
|  | * 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_PROTO_TRACE_PARSER_H_ | 
|  | #define SRC_TRACE_PROCESSOR_PROTO_TRACE_PARSER_H_ | 
|  |  | 
|  | #include <stdint.h> | 
|  |  | 
|  | #include <array> | 
|  | #include <memory> | 
|  |  | 
|  | #include "perfetto/base/string_view.h" | 
|  | #include "perfetto/protozero/field.h" | 
|  | #include "src/trace_processor/ftrace_descriptors.h" | 
|  | #include "src/trace_processor/trace_blob_view.h" | 
|  | #include "src/trace_processor/trace_parser.h" | 
|  | #include "src/trace_processor/trace_storage.h" | 
|  |  | 
|  | namespace perfetto { | 
|  | namespace trace_processor { | 
|  |  | 
|  | class TraceProcessorContext; | 
|  |  | 
|  | struct SystraceTracePoint { | 
|  | char phase; | 
|  | uint32_t tgid; | 
|  |  | 
|  | // For phase = 'B' and phase = 'C' only. | 
|  | base::StringView name; | 
|  |  | 
|  | // For phase = 'C' only. | 
|  | double value; | 
|  | }; | 
|  |  | 
|  | inline bool operator==(const SystraceTracePoint& x, | 
|  | const SystraceTracePoint& y) { | 
|  | return std::tie(x.phase, x.tgid, x.name, x.value) == | 
|  | std::tie(y.phase, y.tgid, y.name, y.value); | 
|  | } | 
|  |  | 
|  | enum class SystraceParseResult { kFailure = 0, kUnsupported, kSuccess }; | 
|  |  | 
|  | SystraceParseResult ParseSystraceTracePoint(base::StringView, | 
|  | SystraceTracePoint* out); | 
|  |  | 
|  | class ProtoTraceParser : public TraceParser { | 
|  | public: | 
|  | using ConstBytes = protozero::ConstBytes; | 
|  | explicit ProtoTraceParser(TraceProcessorContext*); | 
|  | ~ProtoTraceParser() override; | 
|  |  | 
|  | // TraceParser implementation. | 
|  | void ParseTracePacket(int64_t timestamp, | 
|  | TraceSorter::TimestampedTracePiece) override; | 
|  | void ParseFtracePacket(uint32_t cpu, | 
|  | int64_t timestamp, | 
|  | TraceSorter::TimestampedTracePiece) override; | 
|  |  | 
|  | void ParseProcessTree(ConstBytes); | 
|  | void ParseProcessStats(int64_t timestamp, ConstBytes); | 
|  | void ParseSchedSwitch(uint32_t cpu, int64_t timestamp, ConstBytes); | 
|  | void ParseSchedWakeup(int64_t timestamp, ConstBytes); | 
|  | void ParseTaskNewTask(int64_t timestamp, uint32_t source_tid, ConstBytes); | 
|  | void ParseTaskRename(ConstBytes); | 
|  | void ParseCpuFreq(int64_t timestamp, ConstBytes); | 
|  | void ParseCpuIdle(int64_t timestamp, ConstBytes); | 
|  | void ParsePrint(uint32_t cpu, int64_t timestamp, uint32_t pid, ConstBytes); | 
|  | void ParseSysStats(int64_t ts, ConstBytes); | 
|  | void ParseRssStat(int64_t ts, uint32_t pid, ConstBytes); | 
|  | void ParseIonHeapGrowOrShrink(int64_t ts, | 
|  | uint32_t pid, | 
|  | ConstBytes, | 
|  | bool grow); | 
|  | void ParseSignalDeliver(int64_t ts, uint32_t pid, ConstBytes); | 
|  | void ParseSignalGenerate(int64_t ts, ConstBytes); | 
|  | void ParseLowmemoryKill(int64_t ts, ConstBytes); | 
|  | void ParseBatteryCounters(int64_t ts, ConstBytes); | 
|  | void ParsePowerRails(ConstBytes); | 
|  | void ParseOOMScoreAdjUpdate(int64_t ts, ConstBytes); | 
|  | void ParseMmEventRecord(int64_t ts, uint32_t pid, ConstBytes); | 
|  | void ParseSysEvent(int64_t ts, uint32_t pid, bool is_enter, ConstBytes); | 
|  | void ParseClockSnapshot(ConstBytes); | 
|  | void ParseAndroidLogPacket(ConstBytes); | 
|  | void ParseAndroidLogEvent(ConstBytes); | 
|  | void ParseAndroidLogStats(ConstBytes); | 
|  | void ParseGenericFtrace(int64_t timestamp, | 
|  | uint32_t cpu, | 
|  | uint32_t pid, | 
|  | ConstBytes view); | 
|  | void ParseTypedFtraceToRaw(uint32_t ftrace_id, | 
|  | int64_t timestamp, | 
|  | uint32_t cpu, | 
|  | uint32_t pid, | 
|  | ConstBytes view); | 
|  | void ParseTraceStats(ConstBytes); | 
|  | void ParseFtraceStats(ConstBytes); | 
|  | void ParseProfilePacket(ConstBytes); | 
|  | void ParseSystemInfo(ConstBytes); | 
|  |  | 
|  | private: | 
|  | TraceProcessorContext* context_; | 
|  | const StringId utid_name_id_; | 
|  | const StringId sched_wakeup_name_id_; | 
|  | const StringId cpu_freq_name_id_; | 
|  | const StringId cpu_idle_name_id_; | 
|  | const StringId comm_name_id_; | 
|  | const StringId num_forks_name_id_; | 
|  | const StringId num_irq_total_name_id_; | 
|  | const StringId num_softirq_total_name_id_; | 
|  | const StringId num_irq_name_id_; | 
|  | const StringId num_softirq_name_id_; | 
|  | const StringId cpu_times_user_ns_id_; | 
|  | const StringId cpu_times_user_nice_ns_id_; | 
|  | const StringId cpu_times_system_mode_ns_id_; | 
|  | const StringId cpu_times_idle_ns_id_; | 
|  | const StringId cpu_times_io_wait_ns_id_; | 
|  | const StringId cpu_times_irq_ns_id_; | 
|  | const StringId cpu_times_softirq_ns_id_; | 
|  | const StringId signal_deliver_id_; | 
|  | const StringId signal_generate_id_; | 
|  | const StringId batt_charge_id_; | 
|  | const StringId batt_capacity_id_; | 
|  | const StringId batt_current_id_; | 
|  | const StringId batt_current_avg_id_; | 
|  | const StringId lmk_id_; | 
|  | const StringId oom_score_adj_id_; | 
|  | const StringId ion_total_unknown_id_; | 
|  | const StringId ion_change_unknown_id_; | 
|  | std::vector<StringId> meminfo_strs_id_; | 
|  | std::vector<StringId> vmstat_strs_id_; | 
|  | std::vector<StringId> rss_members_; | 
|  | std::vector<StringId> power_rails_strs_id_; | 
|  |  | 
|  | struct FtraceMessageStrings { | 
|  | // The string id of name of the event field (e.g. sched_switch's id). | 
|  | StringId message_name_id = 0; | 
|  | std::array<StringId, kMaxFtraceEventFields> field_name_ids; | 
|  | }; | 
|  | std::vector<FtraceMessageStrings> ftrace_message_strings_; | 
|  |  | 
|  | // Maps a proto field number for memcounters in ProcessStats::Process to | 
|  | // their StringId. Keep kProcStatsProcessSize equal to 1 + max proto field | 
|  | // id of ProcessStats::Process. | 
|  | static constexpr size_t kProcStatsProcessSize = 11; | 
|  | std::array<StringId, kProcStatsProcessSize> proc_stats_process_names_{}; | 
|  |  | 
|  | struct MmEventCounterNames { | 
|  | MmEventCounterNames() = default; | 
|  | MmEventCounterNames(StringId _count, StringId _max_lat, StringId _avg_lat) | 
|  | : count(_count), max_lat(_max_lat), avg_lat(_avg_lat) {} | 
|  |  | 
|  | StringId count = 0; | 
|  | StringId max_lat = 0; | 
|  | StringId avg_lat = 0; | 
|  | }; | 
|  |  | 
|  | // Keep kMmEventCounterSize equal to mm_event_type::MM_TYPE_NUM in the kernel. | 
|  | static constexpr size_t kMmEventCounterSize = 7; | 
|  | std::array<MmEventCounterNames, kMmEventCounterSize> mm_event_counter_names_; | 
|  |  | 
|  | }; | 
|  |  | 
|  | }  // namespace trace_processor | 
|  | }  // namespace perfetto | 
|  |  | 
|  | #endif  // SRC_TRACE_PROCESSOR_PROTO_TRACE_PARSER_H_ |