25 for (
auto E : Chunks) {
38 auto ConsumeInt = [&]() -> int64_t {
40 Remaining.
take_until([](
char c) {
return c <
'0' || c >
'9'; });
42 if (
Number.getAsInteger(10, Res)) {
43 errs() <<
"Failed to parse int at : " << Remaining <<
"\n";
51 int64_t Num = ConsumeInt();
54 if (!Chunks.
empty() && Num <= Chunks[Chunks.
size() - 1].End) {
55 errs() <<
"Expected Chunks to be in increasing order " << Num
56 <<
" <= " << Chunks[Chunks.
size() - 1].End <<
"\n";
61 int64_t Num2 = ConsumeInt();
65 errs() <<
"Expected " << Num <<
" < " << Num2 <<
" in " << Num <<
"-"
78 if (Remaining.
empty())
80 errs() <<
"Failed to parse at : " << Remaining;
92class DebugCounterList :
public cl::list<std::string, DebugCounter> {
97 template <
class... Mods>
98 explicit DebugCounterList(Mods &&... Ms) :
Base(
std::forward<Mods>(Ms)...) {}
101 void printOptionInfo(
size_t GlobalWidth)
const override {
109 outs() <<
" -" << ArgStr;
112 Option::printHelpStr(HelpStr, GlobalWidth, ArgStr.size() + 6);
114 for (
const auto &Entry : CounterInstance) {
115 const auto &[
Name,
Desc] = CounterInstance.getCounterDesc(
Entry.second);
116 size_t NumSpaces = GlobalWidth -
Name.size() - 8;
128 DebugCounterList DebugCounterOption{
130 cl::desc(
"Comma separated list of debug counter skip and count"),
132 cl::opt<bool, true> PrintDebugCounter{
133 "print-debug-counter",
138 cl::desc(
"Print out debug counter info after all counters accumulated"),
141 activateAllCounters();
143 cl::opt<bool, true> PrintDebugCounterQueries{
144 "print-debug-counter-queries",
149 cl::desc(
"Print out each query of an enabled debug counter")};
150 cl::opt<bool, true> BreakOnLastCount{
151 "debug-counter-break-on-last",
156 cl::desc(
"Insert a break point on the last enabled count of a "
159 DebugCounterOwner() {
166 ~DebugCounterOwner() {
167 if (ShouldPrintCounter)
191 if (CounterPair.second.empty()) {
192 errs() <<
"DebugCounter Error: " << Val <<
" does not have an = in it\n";
195 StringRef CounterName = CounterPair.first;
204 errs() <<
"DebugCounter Error: " << CounterName
205 <<
" is not a registered counter\n";
209 Counter->Active = Counter->IsSet =
true;
210 Counter->Chunks = std::move(Chunks);
217 OS <<
"Counters and values:\n";
218 for (
StringRef CounterName : CounterNames) {
227 int64_t CurrCount = Info.Count++;
228 uint64_t CurrIdx = Info.CurrChunkIdx;
230 if (Info.Chunks.empty())
232 if (CurrIdx >= Info.Chunks.size())
235 bool Res = Info.Chunks[CurrIdx].contains(CurrCount);
236 if (
BreakOnLast && CurrIdx == (Info.Chunks.size() - 1) &&
237 CurrCount == Info.Chunks[CurrIdx].End) {
240 if (CurrCount > Info.Chunks[CurrIdx].End) {
244 if (Info.CurrChunkIdx < Info.Chunks.size() &&
245 CurrCount == Info.Chunks[Info.CurrChunkIdx].Begin)
253 bool Res = Us.handleCounterIncrement(Counter);
254 if (Us.ShouldPrintCounterQueries && Counter.IsSet) {
255 dbgs() <<
"DebugCounter " << Counter.Name <<
"=" << (Counter.Count - 1)
256 << (Res ?
" execute" :
" skip") <<
"\n";
261#if !defined(NDEBUG) || defined(LLVM_ENABLE_DUMP)
static void print(raw_ostream &Out, object::Archive::Kind Kind, T Val)
#define LLVM_BUILTIN_DEBUGTRAP
LLVM_BUILTIN_DEBUGTRAP - On compilers which support it, expands to an expression which causes the pro...
#define LLVM_DUMP_METHOD
Mark debug helper function definitions like dump() that should not be stripped from debug builds.
static ManagedStatic< DebugCounterOwner > Owner
This file provides an implementation of debug counters.
ArrayRef - Represent a constant reference to an array (0 or more elements consecutively in memory),...
bool empty() const
empty - Check if the array is empty.
Struct to store counter info.
CounterInfo * getCounterInfo(StringRef Name) const
static LLVM_ABI void printChunks(raw_ostream &OS, ArrayRef< Chunk >)
bool handleCounterIncrement(CounterInfo &Info)
LLVM_ABI void push_back(const std::string &)
static LLVM_ABI bool parseChunks(StringRef Str, SmallVector< Chunk > &Res)
Return true on parsing error and print the error message on the llvm::errs()
static LLVM_ABI bool shouldExecuteImpl(CounterInfo &Counter)
static LLVM_ABI DebugCounter & instance()
Returns a reference to the singleton instance.
LLVM_ABI void print(raw_ostream &OS) const
LLVM_DUMP_METHOD void dump() const
MapVector< StringRef, CounterInfo * > Counters
ManagedStatic - This transparently changes the behavior of global statics to be lazily constructed on...
void push_back(const T &Elt)
This is a 'vector' (really, a variable-sized array), optimized for the case when the array is small.
StringRef - Represent a constant reference to a string, i.e.
std::pair< StringRef, StringRef > split(char Separator) const
Split into two substrings around the first occurrence of a separator character.
bool starts_with(StringRef Prefix) const
Check if this string starts with the given Prefix.
constexpr bool empty() const
empty - Check if the string is empty.
StringRef drop_front(size_t N=1) const
Return a StringRef equal to 'this' but with the first N elements dropped.
StringRef take_until(function_ref< bool(char)> F) const
Return the longest prefix of 'this' such that no character in the prefix satisfies the given predicat...
This class implements an extremely fast bulk output stream that can only output to a stream.
raw_ostream & indent(unsigned NumSpaces)
indent - Insert 'NumSpaces' spaces.
@ C
The default llvm calling convention, compatible with C.
initializer< Ty > init(const Ty &Val)
LocationClass< Ty > location(Ty &L)
cb< typename detail::callback_traits< F >::result_type, typename detail::callback_traits< F >::arg_type > callback(F CB)
This is an optimization pass for GlobalISel generic memory operations.
FunctionAddr VTableAddr Value
LLVM_ABI raw_fd_ostream & outs()
This returns a reference to a raw_fd_ostream for standard output.
void initDebugCounterOptions()
void sort(IteratorTy Start, IteratorTy End)
LLVM_ABI raw_ostream & dbgs()
dbgs() - This returns a reference to a raw_ostream for debugging messages.
LLVM_ABI raw_fd_ostream & errs()
This returns a reference to a raw_ostream for standard error.
FormattedString left_justify(StringRef Str, unsigned Width)
left_justify - append spaces after string so total output is Width characters.
Implement std::hash so that hash_code can be used in STL containers.
LLVM_ABI void print(llvm::raw_ostream &OS)