mirror of
https://github.com/intel/llvm.git
synced 2026-02-04 11:38:04 +08:00
[XRay][clang] Add flag to choose instrumentation bundles
Summary: This change addresses http://llvm.org/PR36926 by allowing users to pick which instrumentation bundles to use, when instrumenting with XRay. In particular, the flag `-fxray-instrumentation-bundle=` has four valid values: - `all`: the default, emits all instrumentation kinds - `none`: equivalent to -fnoxray-instrument - `function`: emits the entry/exit instrumentation - `custom`: emits the custom event instrumentation These can be combined either as comma-separated values, or as repeated flag values. Reviewers: echristo, kpw, eizan, pelikan Reviewed By: pelikan Subscribers: mgorny, cfe-commits Differential Revision: https://reviews.llvm.org/D44970 llvm-svn: 329985
This commit is contained in:
@@ -1846,9 +1846,10 @@ bool CodeGenModule::imbueXRayAttrs(llvm::Function *Fn, SourceLocation Loc,
|
||||
StringRef Category) const {
|
||||
if (!LangOpts.XRayInstrument)
|
||||
return false;
|
||||
|
||||
const auto &XRayFilter = getContext().getXRayFilter();
|
||||
using ImbueAttr = XRayFunctionFilter::ImbueAttribute;
|
||||
auto Attr = XRayFunctionFilter::ImbueAttribute::NONE;
|
||||
auto Attr = ImbueAttr::NONE;
|
||||
if (Loc.isValid())
|
||||
Attr = XRayFilter.shouldImbueLocation(Loc, Category);
|
||||
if (Attr == ImbueAttr::NONE)
|
||||
|
||||
Reference in New Issue
Block a user