diff options
author | Keno Fischer <kfischer@college.harvard.edu> | 2016-01-16 01:11:33 +0000 |
---|---|---|
committer | Keno Fischer <kfischer@college.harvard.edu> | 2016-01-16 01:11:33 +0000 |
commit | f8eb6a14147315b076e1acc5340b776b631e6f78 (patch) | |
tree | ba42c231fc73f23c6a97320e19a174da202f4a3b /llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | |
parent | 12b094d5f470da9f4fb16145ec3d8a7b1512ea77 (diff) | |
download | bcm5719-llvm-f8eb6a14147315b076e1acc5340b776b631e6f78.tar.gz bcm5719-llvm-f8eb6a14147315b076e1acc5340b776b631e6f78.zip |
[DwarfDebug] Move MergeValues to .cpp, NFC
llvm-svn: 257977
Diffstat (limited to 'llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp')
-rw-r--r-- | llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp | 17 |
1 files changed, 17 insertions, 0 deletions
diff --git a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp index a4fb07eacb3..6a1596232be 100644 --- a/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp +++ b/llvm/lib/CodeGen/AsmPrinter/DwarfDebug.cpp @@ -805,6 +805,23 @@ static bool piecesOverlap(const DIExpression *P1, const DIExpression *P2) { return (l1 < r2) && (l2 < r1); } +/// \brief If this and Next are describing different pieces of the same +/// variable, merge them by appending Next's values to the current +/// list of values. +/// Return true if the merge was successful. +bool DebugLocEntry::MergeValues(const DebugLocEntry &Next) { + if (Begin == Next.Begin) { + auto *Expr = cast_or_null<DIExpression>(Values[0].Expression); + auto *NextExpr = cast_or_null<DIExpression>(Next.Values[0].Expression); + if (Expr->isBitPiece() && NextExpr->isBitPiece()) { + addValues(Next.Values); + End = Next.End; + return true; + } + } + return false; +} + /// Build the location list for all DBG_VALUEs in the function that /// describe the same variable. If the ranges of several independent /// pieces of the same variable overlap partially, split them up and |