mirror of
https://github.com/RPCS3/llvm-mirror.git
synced 2024-11-25 12:12:47 +01:00
4dc78253e5
TypedDINodeRef<T> is a redundant wrapper of Metadata * that is actually a T *. Accordingly, change DI{Node,Scope,Type}Ref uses to DI{Node,Scope,Type} * or their const variants. This allows us to delete many resolve() calls that clutter the code. Reviewed By: rnk Differential Revision: https://reviews.llvm.org/D61369 llvm-svn: 360108
72 lines
2.1 KiB
C++
72 lines
2.1 KiB
C++
//===- BreakpointPrinter.cpp - Breakpoint location printer ----------------===//
|
|
//
|
|
// 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
|
|
//
|
|
//===----------------------------------------------------------------------===//
|
|
///
|
|
/// \file
|
|
/// Breakpoint location printer.
|
|
///
|
|
//===----------------------------------------------------------------------===//
|
|
#include "BreakpointPrinter.h"
|
|
#include "llvm/ADT/StringSet.h"
|
|
#include "llvm/IR/DebugInfo.h"
|
|
#include "llvm/IR/Module.h"
|
|
#include "llvm/Pass.h"
|
|
#include "llvm/Support/raw_ostream.h"
|
|
|
|
using namespace llvm;
|
|
|
|
namespace {
|
|
|
|
struct BreakpointPrinter : public ModulePass {
|
|
raw_ostream &Out;
|
|
static char ID;
|
|
|
|
BreakpointPrinter(raw_ostream &out) : ModulePass(ID), Out(out) {}
|
|
|
|
void getContextName(const DIScope *Context, std::string &N) {
|
|
if (auto *NS = dyn_cast<DINamespace>(Context)) {
|
|
if (!NS->getName().empty()) {
|
|
getContextName(NS->getScope(), N);
|
|
N = N + NS->getName().str() + "::";
|
|
}
|
|
} else if (auto *TY = dyn_cast<DIType>(Context)) {
|
|
if (!TY->getName().empty()) {
|
|
getContextName(TY->getScope(), N);
|
|
N = N + TY->getName().str() + "::";
|
|
}
|
|
}
|
|
}
|
|
|
|
bool runOnModule(Module &M) override {
|
|
StringSet<> Processed;
|
|
if (NamedMDNode *NMD = M.getNamedMetadata("llvm.dbg.sp"))
|
|
for (unsigned i = 0, e = NMD->getNumOperands(); i != e; ++i) {
|
|
std::string Name;
|
|
auto *SP = cast_or_null<DISubprogram>(NMD->getOperand(i));
|
|
if (!SP)
|
|
continue;
|
|
getContextName(SP->getScope(), Name);
|
|
Name = Name + SP->getName().str();
|
|
if (!Name.empty() && Processed.insert(Name).second) {
|
|
Out << Name << "\n";
|
|
}
|
|
}
|
|
return false;
|
|
}
|
|
|
|
void getAnalysisUsage(AnalysisUsage &AU) const override {
|
|
AU.setPreservesAll();
|
|
}
|
|
};
|
|
|
|
char BreakpointPrinter::ID = 0;
|
|
}
|
|
|
|
ModulePass *llvm::createBreakpointPrinter(raw_ostream &out) {
|
|
return new BreakpointPrinter(out);
|
|
}
|