llvm/test/DebugInfo/Inputs/split-dwarf-dwp.cpp
David Blaikie fe2090ab78 Migrate llvm-symbolizer tests to not use %T
(context around the %T removal here: https://reviews.llvm.org/D35396 )

git-svn-id: https://llvm.org/svn/llvm-project/llvm/trunk@312828 91177308-0d34-0410-b5e6-96231b3b80d8
2017-09-08 21:10:01 +00:00

23 lines
828 B
C++

void f1() {}
__attribute__((always_inline)) inline void f2() {
f1();
}
// throw a gap in the address range to force use of DW_AT_ranges, ranges_base,
// range contribution in the .dwo file, etc.
__attribute__((nodebug)) void gap() {
}
int main() {
f2();
}
// To produce split-dwarf-dwp.o{,dwp}, Create another file that has ranges, so
// the ranges_base of the CU for split-dwarf-dwp.cpp is non-zero.
//
// $ cat > other.cpp
// void other1() {}
// __attribute__((nodebug)) void other2() {}
// void other3() {}
// $ clang++ other.cpp split-dwarf-dwp.cpp -gsplit-dwarf -c -Xclang -fdebug-compilation-dir -Xclang . -fno-split-dwarf-inlining
// $ llvm-dwp other.dwo split-dwarf-dwp.dwo -o test/DebugInfo/Inputs/split-dwarf-dwp.o.dwp
// $ ld -r other.o split-dwarf-dwp.o -o test/DebugInfo/Inputs/split-dwarf-dwp.o