; 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'