diff options
| author | Eric Christopher <echristo@apple.com> | 2012-07-04 02:02:18 +0000 | 
|---|---|---|
| committer | Eric Christopher <echristo@apple.com> | 2012-07-04 02:02:18 +0000 | 
| commit | ef9d710ea60c92fc683d71c7fe7ba7e5bdb9b0b0 (patch) | |
| tree | 08710c093445b182971a6b30ccee198d50d7f295 /llvm/lib/CodeGen/AsmPrinter | |
| parent | 585c0ec8e19e3d1f0cdd015bf7a46a9e681184cb (diff) | |
| download | bcm5719-llvm-ef9d710ea60c92fc683d71c7fe7ba7e5bdb9b0b0.tar.gz bcm5719-llvm-ef9d710ea60c92fc683d71c7fe7ba7e5bdb9b0b0.zip | |
Reduce some code duplication.
llvm-svn: 159701
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter')
| -rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp | 23 | 
1 files changed, 4 insertions, 19 deletions
| diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp index 9d17767f3bc..d2316657579 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfCompileUnit.cpp @@ -419,27 +419,12 @@ void CompileUnit::addBlockByrefAddress(DbgVariable *&DV, DIE *Die,    // Decode the original location, and use that as the start of the byref    // variable's location. -  const TargetRegisterInfo *RI = Asm->TM.getRegisterInfo(); -  unsigned Reg = RI->getDwarfRegNum(Location.getReg(), false);    DIEBlock *Block = new (DIEValueAllocator) DIEBlock(); -  if (Location.isReg()) { -    if (Reg < 32) -      addUInt(Block, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_reg0 + Reg); -    else { -      addUInt(Block, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_regx); -      addUInt(Block, 0, dwarf::DW_FORM_udata, Reg); -    } -  } else { -    if (Reg < 32) -      addUInt(Block, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_breg0 + Reg); -    else { -      addUInt(Block, 0, dwarf::DW_FORM_data1, dwarf::DW_OP_bregx); -      addUInt(Block, 0, dwarf::DW_FORM_udata, Reg); -    } - -    addUInt(Block, 0, dwarf::DW_FORM_sdata, Location.getOffset()); -  } +  if (Location.isReg()) +    addRegisterOp(Block, Location.getReg()); +  else +    addRegisterOffset(Block, Location.getReg(), Location.getOffset());    // If we started with a pointer to the __Block_byref... struct, then    // the first thing we need to do is dereference the pointer (DW_OP_deref). | 

