diff options
| author | Dean Michael Berris <dberris@google.com> | 2018-11-06 08:51:37 +0000 |
|---|---|---|
| committer | Dean Michael Berris <dberris@google.com> | 2018-11-06 08:51:37 +0000 |
| commit | 25f8d204b828c534dabd90700e4efa6764508094 (patch) | |
| tree | aa8c192fbad0f862530482b829ec5caf51f0d47a /llvm/lib/XRay | |
| parent | c1e530ee92ce8e0e6aa67677c4d0843f94b3ee05 (diff) | |
| download | bcm5719-llvm-25f8d204b828c534dabd90700e4efa6764508094.tar.gz bcm5719-llvm-25f8d204b828c534dabd90700e4efa6764508094.zip | |
[XRay] Update XRayRecord to support Custom/Typed Events
Summary:
This change cuts across LLVM and compiler-rt to add support for
rendering custom events in the XRayRecord type, to allow for including
user-provided annotations in the output YAML (as raw bytes).
This work enables us to add custom event and typed event records into
the `llvm::xray::Trace` type for user-provided events. This can then be
programmatically handled through the C++ API and can be included in some
of the tooling as well. For now we support printing the raw data we
encounter in the custom events in the converted output.
Future work will allow us to start interpreting these custom and typed
events through a yet-to-be-defined API for extending the trace analysis
library.
Reviewers: mboerger
Subscribers: hiraditya, llvm-commits
Differential Revision: https://reviews.llvm.org/D54139
llvm-svn: 346214
Diffstat (limited to 'llvm/lib/XRay')
| -rw-r--r-- | llvm/lib/XRay/FDRTraceExpander.cpp | 20 | ||||
| -rw-r--r-- | llvm/lib/XRay/Profile.cpp | 6 | ||||
| -rw-r--r-- | llvm/lib/XRay/RecordPrinter.cpp | 4 | ||||
| -rw-r--r-- | llvm/lib/XRay/Trace.cpp | 5 |
4 files changed, 28 insertions, 7 deletions
diff --git a/llvm/lib/XRay/FDRTraceExpander.cpp b/llvm/lib/XRay/FDRTraceExpander.cpp index 8e15db52ce6..adddb550ecd 100644 --- a/llvm/lib/XRay/FDRTraceExpander.cpp +++ b/llvm/lib/XRay/FDRTraceExpander.cpp @@ -12,10 +12,11 @@ namespace llvm { namespace xray { void TraceExpander::resetCurrentRecord() { - if (BuildingFunction) + if (BuildingRecord) C(CurrentRecord); - BuildingFunction = false; + BuildingRecord = false; CurrentRecord.CallArgs.clear(); + CurrentRecord.Data.clear(); } Error TraceExpander::visit(BufferExtents &) { @@ -36,9 +37,18 @@ Error TraceExpander::visit(TSCWrapRecord &R) { return Error::success(); } -Error TraceExpander::visit(CustomEventRecord &) { - // TODO: Support custom event records in the future. +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; + std::copy(R.data().begin(), R.data().end(), + std::back_inserter(CurrentRecord.Data)); + BuildingRecord = true; + } return Error::success(); } @@ -78,7 +88,7 @@ Error TraceExpander::visit(FunctionRecord &R) { CurrentRecord.PId = PID; CurrentRecord.TId = TID; CurrentRecord.CPU = CPUId; - BuildingFunction = true; + BuildingRecord = true; } return Error::success(); } diff --git a/llvm/lib/XRay/Profile.cpp b/llvm/lib/XRay/Profile.cpp index fdd1953ab0f..e8a082884d6 100644 --- a/llvm/lib/XRay/Profile.cpp +++ b/llvm/lib/XRay/Profile.cpp @@ -374,6 +374,12 @@ Expected<Profile> profileFromTrace(const Trace &T) { } break; + + case RecordTypes::CUSTOM_EVENT: + case RecordTypes::TYPED_EVENT: + // TODO: Support an extension point to allow handling of custom and typed + // events in profiles. + break; } } diff --git a/llvm/lib/XRay/RecordPrinter.cpp b/llvm/lib/XRay/RecordPrinter.cpp index 0d5ee2de83d..61a292cef85 100644 --- a/llvm/lib/XRay/RecordPrinter.cpp +++ b/llvm/lib/XRay/RecordPrinter.cpp @@ -81,6 +81,10 @@ Error RecordPrinter::visit(FunctionRecord &R) { OS << formatv("<Function Tail Exit: #{0} delta = +{1}>", R.functionId(), R.delta()); break; + case RecordTypes::CUSTOM_EVENT: + case RecordTypes::TYPED_EVENT: + // TODO: Flag as a bug? + break; } OS << Delim; return Error::success(); diff --git a/llvm/lib/XRay/Trace.cpp b/llvm/lib/XRay/Trace.cpp index e7b878cb83f..37cd147078e 100644 --- a/llvm/lib/XRay/Trace.cpp +++ b/llvm/lib/XRay/Trace.cpp @@ -352,8 +352,9 @@ Error loadYAMLLog(StringRef Data, XRayFileHeader &FileHeader, Records.clear(); std::transform(Trace.Records.begin(), Trace.Records.end(), std::back_inserter(Records), [&](const YAMLXRayRecord &R) { - return XRayRecord{R.RecordType, R.CPU, R.Type, R.FuncId, - R.TSC, R.TId, R.PId, R.CallArgs}; + return XRayRecord{R.RecordType, R.CPU, R.Type, + R.FuncId, R.TSC, R.TId, + R.PId, R.CallArgs, R.Data}; }); return Error::success(); } |

