1 /* 2 * Copyright (c) 2021 Huawei Device Co., Ltd. 3 * Licensed under the Apache License, Version 2.0 (the "License"); 4 * you may not use this file except in compliance with the License. 5 * You may obtain a copy of the License at 6 * 7 * http://www.apache.org/licenses/LICENSE-2.0 8 * 9 * Unless required by applicable law or agreed to in writing, software 10 * distributed under the License is distributed on an "AS IS" BASIS, 11 * WITHOUT WARRANTIES OR CONDITIONS OF ANY KIND, either express or implied. 12 * See the License for the specific language governing permissions and 13 * limitations under the License. 14 */ 15 #ifndef SRC_PRINT_EVENT_PARSER_H 16 #define SRC_PRINT_EVENT_PARSER_H 17 #include <regex> 18 #include <string_view> 19 #include "common_types.h" 20 #include "event_parser_base.h" 21 #include "filter/measure_filter.h" 22 #include "filter/process_filter.h" 23 #include "filter/slice_filter.h" 24 #include "filter/task_pool_filter.h" 25 #include "string_to_numerical.h" 26 #include "trace_streamer_config.h" 27 namespace SysTuning { 28 namespace TraceStreamer { 29 class PrintEventParser : private EventParserBase { 30 public: 31 PrintEventParser(TraceDataCache* dataCache, const TraceStreamerFilters* filter); 32 bool ParsePrintEvent(const std::string& comm, 33 uint64_t ts, 34 uint32_t pid, 35 std::string_view event, 36 const BytraceLine& line); 37 void 38 ParseBeginEvent(const std::string& comm, uint64_t ts, uint32_t pid, TracePoint& point, const BytraceLine& line); 39 void ParseEndEvent(uint64_t ts, uint32_t pid, const TracePoint& point); 40 void ParseStartEvent(const std::string& comm, 41 uint64_t ts, 42 uint32_t pid, 43 const TracePoint& point, 44 const BytraceLine& line); 45 void ParseFinishEvent(uint64_t ts, uint32_t pid, const TracePoint& point, const BytraceLine& line); 46 void ParseCreateEvent(uint64_t ts, const TracePoint& point); 47 void Finish(); 48 void SetTraceType(TraceFileType traceType); 49 void SetTraceClockId(BuiltinClocks clock); 50 51 private: 52 using FrameFuncCall = std::function<bool(const size_t callStackRow, std::string& args, const BytraceLine& line)>; 53 ParseResult GetTracePoint(std::string_view pointStr, TracePoint& outPoint) const; 54 ParseResult CheckTracePoint(std::string_view pointStr) const; 55 uint32_t GetThreadGroupId(std::string_view pointStr, size_t& length) const; 56 std::string_view GetPointNameForBegin(std::string_view pointStr, size_t tGidlength) const; 57 ParseResult HandlerB(std::string_view pointStr, TracePoint& outPoint, size_t tGidlength) const; 58 bool HandleFrameSliceBeginEvent(DataIndex eventName, 59 size_t callStackRow, 60 std::string& args, 61 const BytraceLine& line); 62 void HandleFrameSliceEndEvent(uint64_t ts, uint64_t pid, uint64_t tid, size_t callStackRow); 63 void HandleFrameQueueEndEvent(uint64_t ts, uint64_t pid, uint64_t tid, size_t callStackRow); 64 bool HandleAnimationBeginEvent(const TracePoint& point, size_t callStackRow, const BytraceLine& line); 65 static ParseResult HandlerE(void); 66 ParseResult HandlerCSF(std::string_view pointStr, TracePoint& outPoint, size_t tGidlength) const; 67 static size_t GetNameLength(std::string_view pointStr, size_t nameIndex); 68 size_t GetValueLength(std::string_view pointStr, size_t valueIndex) const; 69 bool ReciveVsync(size_t callStackRow, std::string& args, const BytraceLine& line); 70 bool RSReciveOnVsync(size_t callStackRow, std::string& args, const BytraceLine& line); 71 bool OnRwTransaction(size_t callStackRow, std::string& args, const BytraceLine& line); 72 bool OnMainThreadProcessCmd(size_t callStackRow, std::string& args, const BytraceLine& line); 73 bool OnFrameQueueStart(uint64_t ts, size_t callStackRow, uint64_t pid); 74 75 private: 76 std::map<DataIndex, FrameFuncCall> eventToFrameFunctionMap_ = {}; 77 const uint32_t pointLength_; 78 const uint32_t maxPointLength_; 79 TraceStreamerConfig config_{}; 80 const DataIndex recvievVsync_ = traceDataCache_->GetDataIndex("H:ReceiveVsync"); 81 const DataIndex rsOnVsyncEvent_ = traceDataCache_->GetDataIndex("H:RSMainThread::OnVsync"); 82 const std::string onFrameQueeuStartEvent_ = "H:M: Frame queued"; 83 const std::string onLauncherVsyncEvent_ = "launcher"; 84 const DataIndex marshRwTransactionData_ = traceDataCache_->GetDataIndex("H:MarshRSTransactionData"); 85 const DataIndex rsMainThreadProcessCmd_ = traceDataCache_->GetDataIndex("H:RSMainThread::ProcessCommandUni"); 86 const DataIndex onAnimationStartEvent_ = traceDataCache_->GetDataIndex("H:L:TracestartAppAnimation"); 87 const std::regex recvVsyncPattern_ = std::regex("(\\w+):(\\w+)"); 88 const std::regex transFlagPattern_ = std::regex("transactionFlag:\\[(\\d+),(\\d+)\\]"); 89 const std::regex mainProcessCmdPattern = std::regex("\\[(\\d+),(\\d+)\\]"); 90 std::vector<uint64_t> frameCallIds_ = {}; 91 std::vector<uint64_t> vsyncSliceIds_ = {}; 92 TraceFileType traceType_ = TRACE_FILETYPE_H_TRACE; 93 BuiltinClocks clock_ = TS_CLOCK_BOOTTIME; 94 // if convert vsync's now and expectEnd 95 bool convertVsyncTs_ = true; 96 }; 97 } // namespace TraceStreamer 98 } // namespace SysTuning 99 100 #endif // SRC_PRINT_EVENT_PARSER_H 101