| ; REQUIRES: x86-registered-target |
| |
| ; * Added incorrect logical instructions for: --print=lines,instructions |
| ; 'bar' and 'foo' showing extra instruction from compiler generated functions: |
| ; '_cxx_global_var_init' and '_GLOBAL_sub_l_suite_lexical_01.cpp' |
| ; |
| ; * Missing logical instructions for: --print=instructions |
| ; Only 'foo' showing logical instructions. |
| |
| ; pr-incorrect-instructions-dwarf-clang.cpp |
| ; 1 int ABCDE = 56; int XYZ = ABCDE * 65; |
| ; 2 int bar(int Param) { |
| ; 3 return Param + 999999 * Param - 66; |
| ; 4 } |
| ; 5 |
| ; 6 int foo(int Param) { |
| ; 7 return Param - bar(Param) / Param * 66 + ABCDE; |
| ; 8 } |
| ; 9 |
| ; 10 int test(int P1) { |
| ; 11 int Local_1 = P1 - ABCDE; |
| ; 12 { |
| ; 13 int Local_A = 0; |
| ; 14 Local_A = P1 + foo(Local_1); |
| ; 15 ++Local_1; |
| ; 16 } |
| ; 17 return Local_1; |
| ; 18 } |
| ; 19 |
| ; 20 int main() { |
| ; 21 return 0; |
| ; 22 } |
| |
| ; RUN: llvm-debuginfo-analyzer --attribute=level \ |
| ; RUN: --print=lines,instructions \ |
| ; RUN: %p/Inputs/pr-incorrect-instructions-dwarf-clang.o 2>&1 | \ |
| ; RUN: FileCheck --strict-whitespace -check-prefix=ONE %s |
| |
| ; ONE: Logical View: |
| ; ONE-NEXT: [000] {File} 'pr-incorrect-instructions-dwarf-clang.o' |
| ; ONE-EMPTY: |
| ; ONE-NEXT: [001] {CompileUnit} 'pr-incorrect-instructions-dwarf-clang.cpp' |
| ; ONE-NEXT: [002] 2 {Function} extern not_inlined 'bar' -> 'int' |
| ; ONE-NEXT: [003] 2 {Line} |
| ; ONE-NEXT: [003] {Code} 'pushq %rbp' |
| ; ONE-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; ONE-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; ONE-NEXT: [003] 3 {Line} |
| ; ONE-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; ONE-NEXT: [003] 3 {Line} |
| ; ONE-NEXT: [003] {Code} 'imull $0xf423f, -0x4(%rbp), %ecx' |
| ; ONE-NEXT: [003] 3 {Line} |
| ; ONE-NEXT: [003] {Code} 'addl %ecx, %eax' |
| ; ONE-NEXT: [003] 3 {Line} |
| ; ONE-NEXT: [003] {Code} 'subl $0x42, %eax' |
| ; ONE-NEXT: [003] 3 {Line} |
| ; ONE-NEXT: [003] {Code} 'popq %rbp' |
| ; ONE-NEXT: [003] {Code} 'retq' |
| ; ONE-NEXT: [002] 6 {Function} extern not_inlined 'foo' -> 'int' |
| ; ONE-NEXT: [003] 6 {Line} |
| ; ONE-NEXT: [003] {Code} 'pushq %rbp' |
| ; ONE-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; ONE-NEXT: [003] {Code} 'subq $0x10, %rsp' |
| ; ONE-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; ONE-NEXT: [003] {Code} 'movl %eax, -0x8(%rbp)' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'movl -0x4(%rbp), %edi' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'callq 0x0' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'cltd' |
| ; ONE-NEXT: [003] {Code} 'idivl -0x4(%rbp)' |
| ; ONE-NEXT: [003] {Code} 'movl %eax, %ecx' |
| ; ONE-NEXT: [003] {Code} 'movl -0x8(%rbp), %eax' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'imull $0x42, %ecx, %ecx' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'subl %ecx, %eax' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'addl (%rip), %eax' |
| ; ONE-NEXT: [003] 7 {Line} |
| ; ONE-NEXT: [003] {Code} 'addq $0x10, %rsp' |
| ; ONE-NEXT: [003] {Code} 'popq %rbp' |
| ; ONE-NEXT: [003] {Code} 'retq' |
| ; ONE-NEXT: [003] {Code} 'data16' |
| ; ONE-NEXT: [002] 10 {Function} extern not_inlined 'test' -> 'int' |
| ; ONE-NEXT: [003] {Block} |
| ; ONE-NEXT: [004] 13 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl $0x0, -0xc(%rbp)' |
| ; ONE-NEXT: [004] 14 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl -0x4(%rbp), %eax' |
| ; ONE-NEXT: [004] {Code} 'movl %eax, -0x10(%rbp)' |
| ; ONE-NEXT: [004] 14 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl -0x8(%rbp), %edi' |
| ; ONE-NEXT: [004] 14 {Line} |
| ; ONE-NEXT: [004] {Code} 'callq 0x0' |
| ; ONE-NEXT: [004] {Code} 'movl %eax, %ecx' |
| ; ONE-NEXT: [004] {Code} 'movl -0x10(%rbp), %eax' |
| ; ONE-NEXT: [004] 14 {Line} |
| ; ONE-NEXT: [004] {Code} 'addl %ecx, %eax' |
| ; ONE-NEXT: [004] 14 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl %eax, -0xc(%rbp)' |
| ; ONE-NEXT: [004] 15 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl -0x8(%rbp), %eax' |
| ; ONE-NEXT: [004] {Code} 'addl $0x1, %eax' |
| ; ONE-NEXT: [004] {Code} 'movl %eax, -0x8(%rbp)' |
| ; ONE-NEXT: [004] 17 {Line} |
| ; ONE-NEXT: [004] {Code} 'movl -0x8(%rbp), %eax' |
| ; ONE-NEXT: [003] 10 {Line} |
| ; ONE-NEXT: [003] {Code} 'pushq %rbp' |
| ; ONE-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; ONE-NEXT: [003] {Code} 'subq $0x10, %rsp' |
| ; ONE-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; ONE-NEXT: [003] 11 {Line} |
| ; ONE-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; ONE-NEXT: [003] 11 {Line} |
| ; ONE-NEXT: [003] {Code} 'subl (%rip), %eax' |
| ; ONE-NEXT: [003] 11 {Line} |
| ; ONE-NEXT: [003] {Code} 'movl %eax, -0x8(%rbp)' |
| ; ONE-NEXT: [003] 17 {Line} |
| ; ONE-NEXT: [003] {Code} 'addq $0x10, %rsp' |
| ; ONE-NEXT: [003] {Code} 'popq %rbp' |
| ; ONE-NEXT: [003] {Code} 'retq' |
| ; ONE-NEXT: [002] 20 {Function} extern not_inlined 'main' -> 'int' |
| ; ONE-NEXT: [003] 20 {Line} |
| ; ONE-NEXT: [003] {Code} 'pushq %rbp' |
| ; ONE-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; ONE-NEXT: [003] {Code} 'movl $0x0, -0x4(%rbp)' |
| ; ONE-NEXT: [003] 21 {Line} |
| ; ONE-NEXT: [003] {Code} 'xorl %eax, %eax' |
| ; ONE-NEXT: [003] {Code} 'popq %rbp' |
| ; ONE-NEXT: [003] {Code} 'retq' |
| ; ONE-NEXT: [003] 21 {Line} |
| |
| ; RUN: llvm-debuginfo-analyzer --attribute=level \ |
| ; RUN: --print=instructions \ |
| ; RUN: %p/Inputs/pr-incorrect-instructions-dwarf-clang.o 2>&1 | \ |
| ; RUN: FileCheck --strict-whitespace -check-prefix=TWO %s |
| |
| ; TWO: Logical View: |
| ; TWO-NEXT: [000] {File} 'pr-incorrect-instructions-dwarf-clang.o' |
| ; TWO-EMPTY: |
| ; TWO-NEXT: [001] {CompileUnit} 'pr-incorrect-instructions-dwarf-clang.cpp' |
| ; TWO-NEXT: [002] 2 {Function} extern not_inlined 'bar' -> 'int' |
| ; TWO-NEXT: [003] {Code} 'pushq %rbp' |
| ; TWO-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; TWO-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; TWO-NEXT: [003] {Code} 'imull $0xf423f, -0x4(%rbp), %ecx' |
| ; TWO-NEXT: [003] {Code} 'addl %ecx, %eax' |
| ; TWO-NEXT: [003] {Code} 'subl $0x42, %eax' |
| ; TWO-NEXT: [003] {Code} 'popq %rbp' |
| ; TWO-NEXT: [003] {Code} 'retq' |
| ; TWO-NEXT: [002] 6 {Function} extern not_inlined 'foo' -> 'int' |
| ; TWO-NEXT: [003] {Code} 'pushq %rbp' |
| ; TWO-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; TWO-NEXT: [003] {Code} 'subq $0x10, %rsp' |
| ; TWO-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; TWO-NEXT: [003] {Code} 'movl %eax, -0x8(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'movl -0x4(%rbp), %edi' |
| ; TWO-NEXT: [003] {Code} 'callq 0x0' |
| ; TWO-NEXT: [003] {Code} 'cltd' |
| ; TWO-NEXT: [003] {Code} 'idivl -0x4(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'movl %eax, %ecx' |
| ; TWO-NEXT: [003] {Code} 'movl -0x8(%rbp), %eax' |
| ; TWO-NEXT: [003] {Code} 'imull $0x42, %ecx, %ecx' |
| ; TWO-NEXT: [003] {Code} 'subl %ecx, %eax' |
| ; TWO-NEXT: [003] {Code} 'addl (%rip), %eax' |
| ; TWO-NEXT: [003] {Code} 'addq $0x10, %rsp' |
| ; TWO-NEXT: [003] {Code} 'popq %rbp' |
| ; TWO-NEXT: [003] {Code} 'retq' |
| ; TWO-NEXT: [003] {Code} 'data16' |
| ; TWO-NEXT: [002] 10 {Function} extern not_inlined 'test' -> 'int' |
| ; TWO-NEXT: [003] {Block} |
| ; TWO-NEXT: [004] {Code} 'movl $0x0, -0xc(%rbp)' |
| ; TWO-NEXT: [004] {Code} 'movl -0x4(%rbp), %eax' |
| ; TWO-NEXT: [004] {Code} 'movl %eax, -0x10(%rbp)' |
| ; TWO-NEXT: [004] {Code} 'movl -0x8(%rbp), %edi' |
| ; TWO-NEXT: [004] {Code} 'callq 0x0' |
| ; TWO-NEXT: [004] {Code} 'movl %eax, %ecx' |
| ; TWO-NEXT: [004] {Code} 'movl -0x10(%rbp), %eax' |
| ; TWO-NEXT: [004] {Code} 'addl %ecx, %eax' |
| ; TWO-NEXT: [004] {Code} 'movl %eax, -0xc(%rbp)' |
| ; TWO-NEXT: [004] {Code} 'movl -0x8(%rbp), %eax' |
| ; TWO-NEXT: [004] {Code} 'addl $0x1, %eax' |
| ; TWO-NEXT: [004] {Code} 'movl %eax, -0x8(%rbp)' |
| ; TWO-NEXT: [004] {Code} 'movl -0x8(%rbp), %eax' |
| ; TWO-NEXT: [003] {Code} 'pushq %rbp' |
| ; TWO-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; TWO-NEXT: [003] {Code} 'subq $0x10, %rsp' |
| ; TWO-NEXT: [003] {Code} 'movl %edi, -0x4(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'movl -0x4(%rbp), %eax' |
| ; TWO-NEXT: [003] {Code} 'subl (%rip), %eax' |
| ; TWO-NEXT: [003] {Code} 'movl %eax, -0x8(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'addq $0x10, %rsp' |
| ; TWO-NEXT: [003] {Code} 'popq %rbp' |
| ; TWO-NEXT: [003] {Code} 'retq' |
| ; TWO-NEXT: [002] 20 {Function} extern not_inlined 'main' -> 'int' |
| ; TWO-NEXT: [003] {Code} 'pushq %rbp' |
| ; TWO-NEXT: [003] {Code} 'movq %rsp, %rbp' |
| ; TWO-NEXT: [003] {Code} 'movl $0x0, -0x4(%rbp)' |
| ; TWO-NEXT: [003] {Code} 'xorl %eax, %eax' |
| ; TWO-NEXT: [003] {Code} 'popq %rbp' |
| ; TWO-NEXT: [003] {Code} 'retq' |