DebugInfo: PR14763/r183329 correct the location of indirect parameters
authorDavid Blaikie <dblaikie@gmail.com>
Wed, 19 Jun 2013 21:55:13 +0000 (21:55 +0000)
committerDavid Blaikie <dblaikie@gmail.com>
Wed, 19 Jun 2013 21:55:13 +0000 (21:55 +0000)
commit81a4dc75e9d0fdf645bffe08c2858a196dca3533
tree39adce2b4d8b4e18f8089ea022da4228bd31f31c
parentb9c667d808ae36ba08d463135feb8fd37ebe8050
DebugInfo: PR14763/r183329 correct the location of indirect parameters

We had been papering over a problem with location info for non-trivial
types passed by value by emitting their type as references (this caused
the debugger to interpret the location information correctly, but broke
the type of the function). r183329 corrected the type information but
lead to the debugger interpreting the pointer parameter as the value -
the debug info describing the location needed an extra dereference.

Use a new flag in DIVariable to add the extra indirection (either by
promoting an existing DW_OP_reg (parameter passed in a register) to
DW_OP_breg + 0 or by adding DW_OP_deref to an existing DW_OP_breg + n
(parameter passed on the stack).

llvm-svn: 184368
llvm/include/llvm/CodeGen/AsmPrinter.h
llvm/lib/CodeGen/AsmPrinter/AsmPrinter.cpp
llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp
llvm/lib/Target/ARM/ARMAsmPrinter.cpp
llvm/lib/Target/ARM/ARMAsmPrinter.h
llvm/test/DebugInfo/X86/parameters.ll [new file with mode: 0644]