//===-- driver/cl_options_instrumentation.cpp ------------------*- C++ -*-===// // // LDC – the LLVM D compiler // // This file is distributed under the BSD-style LDC license. See the LICENSE // file for details. // //===----------------------------------------------------------------------===// // // Defines the LDC command line options related to instrumentation, such as PGO // -finstrument-functions, etc. // Options for the instrumentation for the sanitizers is not part of this. // //===----------------------------------------------------------------------===// #include "driver/cl_options_instrumentation.h" #include "errors.h" #include "globals.h" #include "gen/to_string.h" #include "llvm/ADT/Triple.h" namespace { namespace cl = llvm::cl; /// Option for generating IR-based PGO instrumentation (LLVM pass) cl::opt IRPGOInstrGenFile( "fprofile-generate", cl::value_desc("filename"), cl::desc("Generate instrumented code to collect a runtime " "profile into default.profraw (overriden by " "'=' or LLVM_PROFILE_FILE env var)"), cl::ZeroOrMore, cl::ValueOptional); /// Option for generating IR-based PGO instrumentation (LLVM pass) cl::opt IRPGOInstrUseFile( "fprofile-use", cl::ZeroOrMore, cl::value_desc("filename"), cl::desc("Use instrumentation data for profile-guided optimization"), cl::ValueRequired); /// Option for generating frontend-based PGO instrumentation cl::opt ASTPGOInstrGenFile( "fprofile-instr-generate", cl::value_desc("filename"), cl::desc("Generate instrumented code to collect a runtime " "profile into default.profraw (overriden by " "'=' or LLVM_PROFILE_FILE env var)"), cl::ZeroOrMore, cl::ValueOptional); /// Option for generating frontend-based PGO instrumentation cl::opt ASTPGOInstrUseFile( "fprofile-instr-use", cl::ZeroOrMore, cl::value_desc("filename"), cl::desc("Use instrumentation data for profile-guided optimization"), cl::ValueRequired); #if LDC_LLVM_VER >= 500 cl::opt fXRayInstructionThreshold( "fxray-instruction-threshold", cl::value_desc("value"), cl::desc("Sets the minimum function size to instrument with XRay"), cl::init(200), cl::ZeroOrMore, cl::ValueRequired); #else constexpr int fXRayInstructionThreshold = 200; #endif } // anonymous namespace namespace opts { PGOKind pgoMode = PGO_None; cl::opt instrumentFunctions("finstrument-functions", cl::ZeroOrMore, cl::desc("Instrument function entry and exit with " "GCC-compatible profiling calls")); // DMD-style profiling (`dmd -profile`) static cl::opt dmdFunctionTrace( "fdmd-trace-functions", cl::ZeroOrMore, cl::desc("DMD-style runtime performance profiling of generated code")); #if LDC_LLVM_VER >= 500 cl::opt fXRayInstrument( "fxray-instrument", cl::ZeroOrMore, cl::desc("Generate XRay instrumentation sleds on function entry and exit")); #endif llvm::StringRef getXRayInstructionThresholdString() { // The instruction threshold is constant during one compiler invoke, so we // can cache the int->string conversion result. static std::string thresholdString = ldc::to_string(fXRayInstructionThreshold); return thresholdString; } void initializeInstrumentationOptionsFromCmdline(const llvm::Triple &triple) { if (ASTPGOInstrGenFile.getNumOccurrences() > 0) { pgoMode = PGO_ASTBasedInstr; if (ASTPGOInstrGenFile.empty()) { // profile-rt provides a default filename by itself global.params.datafileInstrProf = nullptr; } else { initFromPathString(global.params.datafileInstrProf, ASTPGOInstrGenFile); } } else if (!ASTPGOInstrUseFile.empty()) { pgoMode = PGO_ASTBasedUse; initFromPathString(global.params.datafileInstrProf, ASTPGOInstrUseFile); } else if (IRPGOInstrGenFile.getNumOccurrences() > 0) { pgoMode = PGO_IRBasedInstr; if (IRPGOInstrGenFile.empty()) { global.params.datafileInstrProf = "default_%m.profraw"; } else { initFromPathString(global.params.datafileInstrProf, IRPGOInstrGenFile); } } else if (!IRPGOInstrUseFile.empty()) { pgoMode = PGO_IRBasedUse; initFromPathString(global.params.datafileInstrProf, IRPGOInstrUseFile); } if (dmdFunctionTrace) global.params.trace = true; } } // namespace opts