blob: e175238d3bea923a22aef6e56c8ba44a66fc22bc [file] [log] [blame]
Adrian Prantlf0a41082016-05-17 20:12:08 +00001; RUN: llc -O0 -filetype=obj -mtriple=armeb-none-freebsd -debugger-tune=lldb %s -o - \
Adrian Prantl16aa4cf2017-09-11 23:05:20 +00002; RUN: | llvm-dwarfdump -v --debug-info - | FileCheck %s
Adrian Prantlf393d312016-04-28 15:37:48 +00003; Generated from:
4; struct S {
5; int j:5;
6; int k:6;
7; int m:5;
8; int n:8;
9; } s;
10
Adrian Prantl1eadba12016-12-22 00:45:21 +000011source_filename = "test/DebugInfo/ARM/big-endian-bitfield.ll"
Adrian Prantlf393d312016-04-28 15:37:48 +000012target datalayout = "E-m:e-p:32:32-i64:64-v128:64:128-n32-S64"
13
14%struct.S = type { i24 }
15
Adrian Prantl1eadba12016-12-22 00:45:21 +000016@s = common global %struct.S zeroinitializer, align 4, !dbg !0
Adrian Prantlf393d312016-04-28 15:37:48 +000017
Adrian Prantl1eadba12016-12-22 00:45:21 +000018!llvm.dbg.cu = !{!2}
19!llvm.module.flags = !{!13, !14, !15}
20!llvm.ident = !{!16}
Adrian Prantlf393d312016-04-28 15:37:48 +000021
Adrian Prantl05782212017-08-30 18:06:51 +000022!0 = distinct !DIGlobalVariableExpression(var: !1, expr: !DIExpression())
Adrian Prantl1eadba12016-12-22 00:45:21 +000023!1 = !DIGlobalVariable(name: "s", scope: !2, file: !3, line: 6, type: !6, isLocal: false, isDefinition: true)
24!2 = distinct !DICompileUnit(language: DW_LANG_C99, file: !3, producer: "clang version 3.9.0 (trunk 267633)", isOptimized: false, runtimeVersion: 0, emissionKind: FullDebug, enums: !4, globals: !5)
25!3 = !DIFile(filename: "bitfield.c", directory: "/Volumes/Data/llvm")
26!4 = !{}
27!5 = !{!0}
28!6 = distinct !DICompositeType(tag: DW_TAG_structure_type, name: "S", file: !3, line: 1, size: 32, elements: !7)
29!7 = !{!8, !10, !11, !12}
30!8 = !DIDerivedType(tag: DW_TAG_member, name: "j", scope: !6, file: !3, line: 2, baseType: !9, size: 5)
Adrian Prantlf393d312016-04-28 15:37:48 +000031; CHECK: DW_TAG_member
32; CHECK-NEXT: DW_AT_name{{.*}}"j"
33; CHECK-NOT: DW_TAG
34; CHECK: DW_AT_data_bit_offset [DW_FORM_data1] (0x00)
Adrian Prantl1eadba12016-12-22 00:45:21 +000035!9 = !DIBasicType(name: "int", size: 32, encoding: DW_ATE_signed)
36!10 = !DIDerivedType(tag: DW_TAG_member, name: "k", scope: !6, file: !3, line: 3, baseType: !9, size: 6, offset: 5)
37!11 = !DIDerivedType(tag: DW_TAG_member, name: "m", scope: !6, file: !3, line: 4, baseType: !9, size: 5, offset: 11)
38!12 = !DIDerivedType(tag: DW_TAG_member, name: "n", scope: !6, file: !3, line: 5, baseType: !9, size: 8, offset: 16)
39!13 = !{i32 2, !"Dwarf Version", i32 4}
Adrian Prantlf393d312016-04-28 15:37:48 +000040; CHECK: DW_TAG_member
41; CHECK-NEXT: DW_AT_name{{.*}}"k"
42; CHECK-NOT: DW_TAG
43; CHECK: DW_AT_data_bit_offset [DW_FORM_data1] (0x05)
Adrian Prantl1eadba12016-12-22 00:45:21 +000044!14 = !{i32 2, !"Debug Info Version", i32 3}
Adrian Prantlf393d312016-04-28 15:37:48 +000045; CHECK: DW_TAG_member
46; CHECK-NEXT: DW_AT_name{{.*}}"m"
47; CHECK-NOT: DW_TAG
48; CHECK: DW_AT_data_bit_offset [DW_FORM_data1] (0x0b)
Adrian Prantl1eadba12016-12-22 00:45:21 +000049!15 = !{i32 1, !"PIC Level", i32 2}
Adrian Prantlf393d312016-04-28 15:37:48 +000050; CHECK: DW_TAG_member
51; CHECK-NEXT: DW_AT_name{{.*}}"n"
52; CHECK-NOT: DW_TAG
53; CHECK: DW_AT_data_bit_offset [DW_FORM_data1] (0x10)
Adrian Prantl1eadba12016-12-22 00:45:21 +000054!16 = !{!"clang version 3.9.0 (trunk 267633)"}
55