//===- FDRTraceExpander.cpp -----------------------------------------------===// // // Part of the LLVM Project, under the Apache License v2.0 with LLVM Exceptions. // See https://llvm.org/LICENSE.txt for license information. // SPDX-License-Identifier: Apache-2.0 WITH LLVM-exception // //===----------------------------------------------------------------------===// #include "llvm/XRay/FDRTraceExpander.h" namespace llvm { namespace xray { void TraceExpander::resetCurrentRecord() { if (BuildingRecord) C(CurrentRecord); BuildingRecord = false; CurrentRecord.CallArgs.clear(); CurrentRecord.Data.clear(); } Error TraceExpander::visit(BufferExtents &) { resetCurrentRecord(); return Error::success(); } Error TraceExpander::visit(WallclockRecord &) { return Error::success(); } Error TraceExpander::visit(NewCPUIDRecord &R) { CPUId = R.cpuid(); BaseTSC = R.tsc(); return Error::success(); } Error TraceExpander::visit(TSCWrapRecord &R) { BaseTSC = R.tsc(); return Error::success(); } Error TraceExpander::visit(CustomEventRecord &R) { resetCurrentRecord(); if (!IgnoringRecords) { CurrentRecord.TSC = R.tsc(); CurrentRecord.CPU = R.cpu(); CurrentRecord.PId = PID; CurrentRecord.TId = TID; CurrentRecord.Type = RecordTypes::CUSTOM_EVENT; CurrentRecord.Data = R.data(); BuildingRecord = true; } return Error::success(); } Error TraceExpander::visit(CustomEventRecordV5 &R) { resetCurrentRecord(); if (!IgnoringRecords) { BaseTSC += R.delta(); CurrentRecord.TSC = BaseTSC; CurrentRecord.CPU = CPUId; CurrentRecord.PId = PID; CurrentRecord.TId = TID; CurrentRecord.Type = RecordTypes::CUSTOM_EVENT; CurrentRecord.Data = R.data(); BuildingRecord = true; } return Error::success(); } Error TraceExpander::visit(TypedEventRecord &R) { resetCurrentRecord(); if (!IgnoringRecords) { BaseTSC += R.delta(); CurrentRecord.TSC = BaseTSC; CurrentRecord.CPU = CPUId; CurrentRecord.PId = PID; CurrentRecord.TId = TID; CurrentRecord.RecordType = R.eventType(); CurrentRecord.Type = RecordTypes::TYPED_EVENT; CurrentRecord.Data = R.data(); BuildingRecord = true; } return Error::success(); } Error TraceExpander::visit(CallArgRecord &R) { CurrentRecord.CallArgs.push_back(R.arg()); CurrentRecord.Type = RecordTypes::ENTER_ARG; return Error::success(); } Error TraceExpander::visit(PIDRecord &R) { PID = R.pid(); return Error::success(); } Error TraceExpander::visit(NewBufferRecord &R) { if (IgnoringRecords) IgnoringRecords = false; TID = R.tid(); if (LogVersion == 2) PID = R.tid(); return Error::success(); } Error TraceExpander::visit(EndBufferRecord &) { IgnoringRecords = true; resetCurrentRecord(); return Error::success(); } Error TraceExpander::visit(FunctionRecord &R) { resetCurrentRecord(); if (!IgnoringRecords) { BaseTSC += R.delta(); CurrentRecord.Type = R.recordType(); CurrentRecord.FuncId = R.functionId(); CurrentRecord.TSC = BaseTSC; CurrentRecord.PId = PID; CurrentRecord.TId = TID; CurrentRecord.CPU = CPUId; BuildingRecord = true; } return Error::success(); } Error TraceExpander::flush() { resetCurrentRecord(); return Error::success(); } } // namespace xray } // namespace llvm