1; REQUIRES: x86-registered-target 2 3; Test case 6 - Full logical view 4 5; test.cpp 6; 1 using INTPTR = const int *; 7; 2 int foo(INTPTR ParamPtr, unsigned ParamUnsigned, bool ParamBool) { 8; 3 if (ParamBool) { 9; 4 typedef int INTEGER; 10; 5 const INTEGER CONSTANT = 7; 11; 6 return CONSTANT; 12; 7 } 13; 8 return ParamUnsigned; 14; 9 } 15 16; Print low level details. 17; The following command prints low level information that includes 18; offsets within the debug information section, debug location 19; operands, linkage names, etc. 20 21; RUN: llvm-debuginfo-analyzer --attribute=all \ 22; RUN: --print=all \ 23; RUN: %p/Inputs/test-dwarf-clang.o 2>&1 | \ 24; RUN: FileCheck --strict-whitespace -check-prefix=ONE %s 25 26; ONE: Logical View: 27; ONE-NEXT: [0x0000000000][000] {File} '{{.*}}test-dwarf-clang.o' -> elf64-x86-64 28; ONE-EMPTY: 29; ONE-NEXT: [0x000000000b][001] {CompileUnit} 'test.cpp' 30; ONE-NEXT: [0x000000000b][002] {Producer} 'clang version 15.0.0 {{.*}}' 31; ONE-NEXT: {Directory} '/data/projects/tests/input/general' 32; ONE-NEXT: {File} 'test.cpp' 33; ONE-NEXT: {Public} 'foo' [0x0000000000:0x000000003a] 34; ONE-NEXT: [0x000000000b][002] {Range} Lines 2:9 [0x0000000000:0x000000003a] 35; ONE-NEXT: [0x00000000bc][002] {BaseType} 'bool' 36; ONE-NEXT: [0x0000000099][002] {BaseType} 'int' 37; ONE-NEXT: [0x00000000b5][002] {BaseType} 'unsigned int' 38; ONE-EMPTY: 39; ONE-NEXT: [0x00000000a0][002] {Source} '/data/projects/tests/input/general/test.cpp' 40; ONE-NEXT: [0x00000000a0][002] 1 {TypeAlias} 'INTPTR' -> [0x00000000ab]'* const int' 41; ONE-NEXT: [0x000000002a][002] 2 {Function} extern not_inlined 'foo' -> [0x0000000099]'int' 42; ONE-NEXT: [0x000000002a][003] {Range} Lines 2:9 [0x0000000000:0x000000003a] 43; ONE-NEXT: [0x000000002a][003] {Linkage} 0x2 '_Z3fooPKijb' 44; ONE-NEXT: [0x0000000071][003] {Block} 45; ONE-NEXT: [0x0000000071][004] {Range} Lines 5:8 [0x000000001c:0x000000002f] 46; ONE-NEXT: [0x000000007e][004] 5 {Variable} 'CONSTANT' -> [0x00000000c3]'const INTEGER' 47; ONE-NEXT: [0x000000007e][005] {Coverage} 100.00% 48; ONE-NEXT: [0x000000007f][005] {Location} 49; ONE-NEXT: [0x000000007f][006] {Entry} fbreg -28 50; ONE-NEXT: [0x000000001c][004] 5 {Line} {NewStatement} '/data/projects/tests/input/general/test.cpp' 51; ONE-NEXT: [0x000000001c][004] {Code} 'movl $0x7, -0x1c(%rbp)' 52; ONE-NEXT: [0x0000000023][004] 6 {Line} {NewStatement} '/data/projects/tests/input/general/test.cpp' 53; ONE-NEXT: [0x0000000023][004] {Code} 'movl $0x7, -0x4(%rbp)' 54; ONE-NEXT: [0x000000002a][004] {Code} 'jmp 0x6' 55; ONE-NEXT: [0x000000002f][004] 8 {Line} {NewStatement} '/data/projects/tests/input/general/test.cpp' 56; ONE-NEXT: [0x000000002f][004] {Code} 'movl -0x14(%rbp), %eax' 57; ONE-NEXT: [0x0000000063][003] 2 {Parameter} 'ParamBool' -> [0x00000000bc]'bool' 58; ONE-NEXT: [0x0000000063][004] {Coverage} 100.00% 59; ONE-NEXT: [0x0000000064][004] {Location} 60; ONE-NEXT: [0x0000000064][005] {Entry} fbreg -21 61; ONE-NEXT: [0x0000000047][003] 2 {Parameter} 'ParamPtr' -> [0x00000000a0]'INTPTR' 62; ONE-NEXT: [0x0000000047][004] {Coverage} 100.00% 63; ONE-NEXT: [0x0000000048][004] {Location} 64; ONE-NEXT: [0x0000000048][005] {Entry} fbreg -16 65; ONE-NEXT: [0x0000000055][003] 2 {Parameter} 'ParamUnsigned' -> [0x00000000b5]'unsigned int' 66; ONE-NEXT: [0x0000000055][004] {Coverage} 100.00% 67; ONE-NEXT: [0x0000000056][004] {Location} 68; ONE-NEXT: [0x0000000056][005] {Entry} fbreg -20 69; ONE-NEXT: [0x000000008d][003] 4 {TypeAlias} 'INTEGER' -> [0x0000000099]'int' 70; ONE-NEXT: [0x0000000000][003] 2 {Line} {NewStatement} '/data/projects/tests/input/general/test.cpp' 71; ONE-NEXT: [0x0000000000][003] {Code} 'pushq %rbp' 72; ONE-NEXT: [0x0000000001][003] {Code} 'movq %rsp, %rbp' 73; ONE-NEXT: [0x0000000004][003] {Code} 'movb %dl, %al' 74; ONE-NEXT: [0x0000000006][003] {Code} 'movq %rdi, -0x10(%rbp)' 75; ONE-NEXT: [0x000000000a][003] {Code} 'movl %esi, -0x14(%rbp)' 76; ONE-NEXT: [0x000000000d][003] {Code} 'andb $0x1, %al' 77; ONE-NEXT: [0x000000000f][003] {Code} 'movb %al, -0x15(%rbp)' 78; ONE-NEXT: [0x0000000012][003] 3 {Line} {NewStatement} {PrologueEnd} '/data/projects/tests/input/general/test.cpp' 79; ONE-NEXT: [0x0000000012][003] {Code} 'testb $0x1, -0x15(%rbp)' 80; ONE-NEXT: [0x0000000016][003] {Code} 'je 0x13' 81; ONE-NEXT: [0x0000000032][003] 8 {Line} '/data/projects/tests/input/general/test.cpp' 82; ONE-NEXT: [0x0000000032][003] {Code} 'movl %eax, -0x4(%rbp)' 83; ONE-NEXT: [0x0000000035][003] 9 {Line} {NewStatement} '/data/projects/tests/input/general/test.cpp' 84; ONE-NEXT: [0x0000000035][003] {Code} 'movl -0x4(%rbp), %eax' 85; ONE-NEXT: [0x0000000038][003] {Code} 'popq %rbp' 86; ONE-NEXT: [0x0000000039][003] {Code} 'retq' 87; ONE-NEXT: [0x000000003a][003] 9 {Line} {NewStatement} {EndSequence} '/data/projects/tests/input/general/test.cpp' 88; ONE-EMPTY: 89; ONE-NEXT: ----------------------------- 90; ONE-NEXT: Element Total Printed 91; ONE-NEXT: ----------------------------- 92; ONE-NEXT: Scopes 3 3 93; ONE-NEXT: Symbols 4 4 94; ONE-NEXT: Types 5 5 95; ONE-NEXT: Lines 25 25 96; ONE-NEXT: ----------------------------- 97; ONE-NEXT: Total 37 37 98; ONE-EMPTY: 99; ONE-NEXT: Scope Sizes: 100; ONE-NEXT: 189 (100.00%) : [0x000000000b][001] {CompileUnit} 'test.cpp' 101; ONE-NEXT: 110 ( 58.20%) : [0x000000002a][002] 2 {Function} extern not_inlined 'foo' -> [0x0000000099]'int' 102; ONE-NEXT: 27 ( 14.29%) : [0x0000000071][003] {Block} 103; ONE-EMPTY: 104; ONE-NEXT: Totals by lexical level: 105; ONE-NEXT: [001]: 189 (100.00%) 106; ONE-NEXT: [002]: 110 ( 58.20%) 107; ONE-NEXT: [003]: 27 ( 14.29%) 108