diff options
| author | Mazdak Farrokhzad <twingoow@gmail.com> | 2019-03-30 14:14:53 +0100 |
|---|---|---|
| committer | GitHub <noreply@github.com> | 2019-03-30 14:14:53 +0100 |
| commit | ae2551825dbe5a688d00e1d1e7aa7dbaec274e50 (patch) | |
| tree | 4df81cb1ef65b47a84456e6c9fb735765042b5bf /src/test/debuginfo/enum-thinlto.rs | |
| parent | be6b4c06be1481c0ade7ed683fc36b039166a8a1 (diff) | |
| parent | 3a5a8a529a14271f5d8c21bec8746edfa93eec5f (diff) | |
| download | rust-ae2551825dbe5a688d00e1d1e7aa7dbaec274e50.tar.gz rust-ae2551825dbe5a688d00e1d1e7aa7dbaec274e50.zip | |
Rollup merge of #59380 - philipc:thinlto-variant, r=michaelwoerister
Fix invalid DWARF for enums when using ThinLTO We were setting the same identifier for both the DW_TAG_structure_type and the DW_TAG_variant_part. This becomes a problem when using ThinLTO becauses it uses the identifier as a key for a map of types that is used to delete duplicates based on the ODR, so one of them is deleted as a duplicate, resulting in invalid DWARF. The DW_TAG_variant_part isn't a standalone type, so it doesn't need an identifier. Fix by omitting its identifier. ODR uniquing is [enabled here](https://github.com/rust-lang/rust/blob/f21dee2c6179276321a88a63300dce74ff707e92/src/rustllvm/PassWrapper.cpp#L1101).
Diffstat (limited to 'src/test/debuginfo/enum-thinlto.rs')
| -rw-r--r-- | src/test/debuginfo/enum-thinlto.rs | 48 |
1 files changed, 48 insertions, 0 deletions
diff --git a/src/test/debuginfo/enum-thinlto.rs b/src/test/debuginfo/enum-thinlto.rs new file mode 100644 index 00000000000..7f15ed90e67 --- /dev/null +++ b/src/test/debuginfo/enum-thinlto.rs @@ -0,0 +1,48 @@ +// ignore-tidy-linelength + +// Require LLVM with DW_TAG_variant_part and a gdb that can read it. +// min-system-llvm-version: 8.0 +// min-gdb-version: 8.2 + +// compile-flags:-g -Z thinlto + +// === GDB TESTS =================================================================================== + +// gdb-command:run + +// gdb-command:print *abc +// gdbr-check:$1 = enum_thinlto::ABC::TheA{x: 0, y: 8970181431921507452} + +// === LLDB TESTS ================================================================================== + +// lldb-command:run + +// lldb-command:print *abc +// lldbg-check:(enum_thinlto::ABC) $0 = ABC { } + +#![allow(unused_variables)] +#![feature(omit_gdb_pretty_printer_section)] +#![omit_gdb_pretty_printer_section] + +// The first element is to ensure proper alignment, irrespective of the machines word size. Since +// the size of the discriminant value is machine dependent, this has be taken into account when +// datatype layout should be predictable as in this case. +#[derive(Debug)] +enum ABC { + TheA { x: i64, y: i64 }, + TheB (i64, i32, i32), +} + +fn main() { + let abc = ABC::TheA { x: 0, y: 0x7c7c_7c7c_7c7c_7c7c }; + + f(&abc); +} + +fn f(abc: &ABC) { + zzz(); // #break + + println!("{:?}", abc); +} + +fn zzz() {()} |
