Skip to content

Commit a930111

Browse files
committed
[Asm] Add debug printing for assembler macros
This adds some debug printing (gated behind the "asm-macros" debug flag) which can help tracing complicated assembly macros. Differential revision: https://reviews.llvm.org/D43937 llvm-svn: 326795
1 parent 5c032ce commit a930111

File tree

4 files changed

+58
-1
lines changed

4 files changed

+58
-1
lines changed

llvm/include/llvm/MC/MCAsmMacro.h

Lines changed: 7 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -11,6 +11,7 @@
1111
#define LLVM_MC_MCASMMACRO_H
1212

1313
#include "llvm/MC/MCParser/MCAsmLexer.h"
14+
#include "llvm/Support/Debug.h"
1415

1516
namespace llvm {
1617

@@ -21,6 +22,9 @@ struct MCAsmMacroParameter {
2122
bool Vararg = false;
2223

2324
MCAsmMacroParameter() = default;
25+
26+
void dump() const { dump(dbgs()); }
27+
void dump(raw_ostream &OS) const;
2428
};
2529

2630
typedef std::vector<MCAsmMacroParameter> MCAsmMacroParameters;
@@ -32,6 +36,9 @@ struct MCAsmMacro {
3236
public:
3337
MCAsmMacro(StringRef N, StringRef B, MCAsmMacroParameters P)
3438
: Name(N), Body(B), Parameters(std::move(P)) {}
39+
40+
void dump() const { dump(dbgs()); }
41+
void dump(raw_ostream &OS) const;
3542
};
3643
} // namespace llvm
3744

llvm/include/llvm/MC/MCContext.h

Lines changed: 8 additions & 1 deletion
Original file line numberDiff line numberDiff line change
@@ -634,10 +634,17 @@ namespace llvm {
634634
}
635635

636636
void defineMacro(StringRef Name, MCAsmMacro Macro) {
637+
DEBUG_WITH_TYPE("asm-macros", dbgs() << "Defining new macro:\n";
638+
Macro.dump());
637639
MacroMap.insert(std::make_pair(Name, std::move(Macro)));
638640
}
639641

640-
void undefineMacro(StringRef Name) { MacroMap.erase(Name); }
642+
void undefineMacro(StringRef Name) {
643+
if (MacroMap.erase(Name)) {
644+
DEBUG_WITH_TYPE("asm-macros",
645+
dbgs() << "Un-defining macro: " << Name << "\n");
646+
}
647+
}
641648
};
642649

643650
} // end namespace llvm

llvm/lib/MC/CMakeLists.txt

Lines changed: 1 addition & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -7,6 +7,7 @@ add_llvm_library(LLVMMC
77
MCAsmInfoDarwin.cpp
88
MCAsmInfoELF.cpp
99
MCAsmInfoWasm.cpp
10+
MCAsmMacro.cpp
1011
MCAsmStreamer.cpp
1112
MCAssembler.cpp
1213
MCCodeEmitter.cpp

llvm/lib/MC/MCAsmMacro.cpp

Lines changed: 42 additions & 0 deletions
Original file line numberDiff line numberDiff line change
@@ -0,0 +1,42 @@
1+
//===- MCAsmMacro.h - Assembly Macros ---------------------------*- C++ -*-===//
2+
//
3+
// The LLVM Compiler Infrastructure
4+
//
5+
// This file is distributed under the University of Illinois Open Source
6+
// License. See LICENSE.TXT for details.
7+
//
8+
//===----------------------------------------------------------------------===//
9+
10+
#include "llvm/MC/MCAsmMacro.h"
11+
#include "llvm/Support/raw_ostream.h"
12+
13+
using namespace llvm;
14+
15+
void MCAsmMacroParameter::dump(raw_ostream &OS) const {
16+
OS << "\"" << Name << "\"";
17+
if (Required)
18+
OS << ":req";
19+
if (Vararg)
20+
OS << ":vararg";
21+
if (!Value.empty()) {
22+
OS << " = ";
23+
bool first = true;
24+
for (const AsmToken &T : Value) {
25+
if (!first)
26+
OS << ", ";
27+
first = false;
28+
T.dump();
29+
}
30+
}
31+
OS << "\n";
32+
}
33+
34+
void MCAsmMacro::dump(raw_ostream &OS) const {
35+
OS << "Macro " << Name << ":\n";
36+
OS << " Parameters:\n";
37+
for (const MCAsmMacroParameter &P : Parameters) {
38+
OS << " ";
39+
P.dump();
40+
}
41+
OS << " (BEGIN BODY)" << Body << "(END BODY)\n";
42+
}

0 commit comments

Comments
 (0)