summaryrefslogtreecommitdiffstats
path: root/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp
diff options
context:
space:
mode:
authorTim Renouf <tpr.llvm@botech.co.uk>2017-12-08 14:09:34 +0000
committerTim Renouf <tpr.llvm@botech.co.uk>2017-12-08 14:09:34 +0000
commitcead41d42fc65a9798430eda9a2eb6728d5a1440 (patch)
treee84c811f5edefa1b03aa51ab17560bd0605836ac /llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp
parent63a3de057eeae94e8c6c68b53b370f5a1611b0fa (diff)
downloadbcm5719-llvm-cead41d42fc65a9798430eda9a2eb6728d5a1440.tar.gz
bcm5719-llvm-cead41d42fc65a9798430eda9a2eb6728d5a1440.zip
[AMDGPU] add labels to +DumpCode output
Summary: +DumpCode is a hack to embed disassembly in the ELF file. This commit fixes it to include labels, to make it slightly more useful. Reviewers: arsenm, kzhuravl Subscribers: nhaehnle, timcorringham, dstuttard, llvm-commits, t-tye, yaxunl, wdng, kzhuravl Differential Revision: https://reviews.llvm.org/D40169 llvm-svn: 320146
Diffstat (limited to 'llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp')
-rw-r--r--llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp27
1 files changed, 25 insertions, 2 deletions
diff --git a/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp b/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp
index 9c87ecada77..c53235db423 100644
--- a/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp
+++ b/llvm/lib/Target/AMDGPU/AMDGPUAsmPrinter.cpp
@@ -219,10 +219,30 @@ void AMDGPUAsmPrinter::EmitFunctionEntryLabel() {
getTargetStreamer()->EmitAMDGPUSymbolType(
SymbolName, ELF::STT_AMDGPU_HSA_KERNEL);
}
+ const AMDGPUSubtarget &STI = MF->getSubtarget<AMDGPUSubtarget>();
+ if (STI.dumpCode()) {
+ // Disassemble function name label to text.
+ DisasmLines.push_back(MF->getFunction()->getName().str() + ":");
+ DisasmLineMaxLen = std::max(DisasmLineMaxLen, DisasmLines.back().size());
+ HexLines.push_back("");
+ }
AsmPrinter::EmitFunctionEntryLabel();
}
+void AMDGPUAsmPrinter::EmitBasicBlockStart(const MachineBasicBlock &MBB) const {
+ const AMDGPUSubtarget &STI = MBB.getParent()->getSubtarget<AMDGPUSubtarget>();
+ if (STI.dumpCode() && !isBlockOnlyReachableByFallthrough(&MBB)) {
+ // Write a line for the basic block label if it is not only fallthrough.
+ DisasmLines.push_back(
+ (Twine("BB") + Twine(getFunctionNumber())
+ + "_" + Twine(MBB.getNumber()) + ":").str());
+ DisasmLineMaxLen = std::max(DisasmLineMaxLen, DisasmLines.back().size());
+ HexLines.push_back("");
+ }
+ AsmPrinter::EmitBasicBlockStart(MBB);
+}
+
void AMDGPUAsmPrinter::EmitGlobalVariable(const GlobalVariable *GV) {
// Group segment variables aren't emitted in HSA.
@@ -406,8 +426,11 @@ bool AMDGPUAsmPrinter::runOnMachineFunction(MachineFunction &MF) {
Context.getELFSection(".AMDGPU.disasm", ELF::SHT_NOTE, 0));
for (size_t i = 0; i < DisasmLines.size(); ++i) {
- std::string Comment(DisasmLineMaxLen - DisasmLines[i].size(), ' ');
- Comment += " ; " + HexLines[i] + "\n";
+ std::string Comment = "\n";
+ if (!HexLines[i].empty()) {
+ Comment = std::string(DisasmLineMaxLen - DisasmLines[i].size(), ' ');
+ Comment += " ; " + HexLines[i] + "\n";
+ }
OutStreamer->EmitBytes(StringRef(DisasmLines[i]));
OutStreamer->EmitBytes(StringRef(Comment));
OpenPOWER on IntegriCloud