|
| 1 | +// compile-flags: -g -Zmir-opt-level=0 -Zmir-enable-passes=+ScalarReplacementOfAggregates |
| 2 | +// compile-flags: -Cno-prepopulate-passes |
| 3 | +// |
| 4 | +// Tested offsets are only correct for x86_64. |
| 5 | +// only-x86_64 |
| 6 | + |
| 7 | +#![crate_type = "lib"] |
| 8 | + |
| 9 | +pub struct ExtraSlice<'input> { |
| 10 | + slice: &'input [u8], |
| 11 | + extra: u32, |
| 12 | +} |
| 13 | + |
| 14 | +#[no_mangle] |
| 15 | +pub fn extra(s: &[u8]) { |
| 16 | +// CHECK: void @extra( |
| 17 | +// CHECK: %slice.dbg.spill1 = alloca i32, |
| 18 | +// CHECK: %slice.dbg.spill = alloca { ptr, i64 }, |
| 19 | +// CHECK: %s.dbg.spill = alloca { ptr, i64 }, |
| 20 | +// CHECK: call void @llvm.dbg.declare(metadata ptr %s.dbg.spill, metadata ![[S_EXTRA:.*]], metadata !DIExpression()), |
| 21 | +// CHECK: call void @llvm.dbg.declare(metadata ptr %slice.dbg.spill, metadata ![[SLICE_EXTRA:.*]], metadata !DIExpression(DW_OP_LLVM_fragment, 0, 128)), |
| 22 | +// CHECK: call void @llvm.dbg.declare(metadata ptr %slice.dbg.spill1, metadata ![[SLICE_EXTRA]], metadata !DIExpression(DW_OP_LLVM_fragment, 128, 32)), |
| 23 | + let slice = ExtraSlice { slice: s, extra: s.len() as u32 }; |
| 24 | +} |
| 25 | + |
| 26 | +struct Zst; |
| 27 | + |
| 28 | +pub struct ZstSlice<'input> { |
| 29 | + slice: &'input [u8], |
| 30 | + extra: Zst, |
| 31 | +} |
| 32 | + |
| 33 | +#[no_mangle] |
| 34 | +pub fn zst(s: &[u8]) { |
| 35 | + // The field `extra` is a ZST. The fragment for the field `slice` encompasses the whole |
| 36 | + // variable, so is not a fragment. In that case, the variable must have no fragment. |
| 37 | + |
| 38 | +// CHECK: void @zst( |
| 39 | +// CHECK-NOT: call void @llvm.dbg.declare(metadata ptr %slice.dbg.spill, metadata !{}, metadata !DIExpression(DW_OP_LLVM_fragment, |
| 40 | +// CHECK: call void @llvm.dbg.declare(metadata ptr %{{.*}}, metadata ![[SLICE_ZST:.*]], metadata !DIExpression()), |
| 41 | +// CHECK-NOT: call void @llvm.dbg.declare(metadata ptr %{{.*}}, metadata ![[SLICE_ZST]], |
| 42 | + let slice = ZstSlice { slice: s, extra: Zst }; |
| 43 | +} |
| 44 | + |
| 45 | +// CHECK: ![[S_EXTRA]] = !DILocalVariable(name: "s", |
| 46 | +// CHECK: ![[SLICE_EXTRA]] = !DILocalVariable(name: "slice", |
0 commit comments