aboutsummaryrefslogtreecommitdiff
path: root/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
diff options
context:
space:
mode:
authorDevang Patel <dpatel@apple.com>2011-04-21 21:07:35 +0000
committerDevang Patel <dpatel@apple.com>2011-04-21 21:07:35 +0000
commitacc381bee95b5eafcdf3eaa85a66e83a5773aacb (patch)
tree14ab6de52b498c348207f204f51eadce9e79fc06 /lib/CodeGen/AsmPrinter/AsmPrinter.cpp
parent8859df59119969ea96ed0efdab276ba584f5127d (diff)
Refactor.
git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@129938 91177308-0d34-0410-b5e6-96231b3b80d8
Diffstat (limited to 'lib/CodeGen/AsmPrinter/AsmPrinter.cpp')
-rw-r--r--lib/CodeGen/AsmPrinter/AsmPrinter.cpp34
1 files changed, 34 insertions, 0 deletions
diff --git a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
index 8c367d1d7a..609da254fc 100644
--- a/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
+++ b/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
@@ -752,6 +752,40 @@ getDebugValueLocation(const MachineInstr *MI) const {
return MachineLocation();
}
+/// EmitDwarfRegOp - Emit dwarf register operation.
+void AsmPrinter::EmitDwarfRegOp(const MachineLocation &MLoc) const {
+ const TargetRegisterInfo *RI = TM.getRegisterInfo();
+ unsigned Reg = RI->getDwarfRegNum(MLoc.getReg(), false);
+ if (int Offset = MLoc.getOffset()) {
+ // If the value is at a certain offset from frame register then
+ // use DW_OP_fbreg.
+ unsigned OffsetSize = Offset ? MCAsmInfo::getSLEB128Size(Offset) : 1;
+ OutStreamer.AddComment("Loc expr size");
+ EmitInt16(1 + OffsetSize);
+ OutStreamer.AddComment(
+ dwarf::OperationEncodingString(dwarf::DW_OP_fbreg));
+ EmitInt8(dwarf::DW_OP_fbreg);
+ OutStreamer.AddComment("Offset");
+ EmitSLEB128(Offset);
+ } else {
+ if (Reg < 32) {
+ OutStreamer.AddComment("Loc expr size");
+ EmitInt16(1);
+ OutStreamer.AddComment(
+ dwarf::OperationEncodingString(dwarf::DW_OP_reg0 + Reg));
+ EmitInt8(dwarf::DW_OP_reg0 + Reg);
+ } else {
+ OutStreamer.AddComment("Loc expr size");
+ EmitInt16(1 + MCAsmInfo::getULEB128Size(Reg));
+ OutStreamer.AddComment(
+ dwarf::OperationEncodingString(dwarf::DW_OP_regx));
+ EmitInt8(dwarf::DW_OP_regx);
+ OutStreamer.AddComment(Twine(Reg));
+ EmitULEB128(Reg);
+ }
+ }
+}
+
bool AsmPrinter::doFinalization(Module &M) {
// Emit global variables.
for (Module::const_global_iterator I = M.global_begin(), E = M.global_end();