; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py UTC_ARGS: --version 2
; RUN: llc < %s -mtriple=x86_64-linux | FileCheck %s
; @foo is optimized for size. Variables %p2, %p3, %p4, %p5 and %p6 are not split
; in cold blocks.
define i64 @foo(ptr %ptr, i64 %p2, i64 %p3, i64 %p4, i64 %p5, i64 %p6) optsize {
; CHECK-LABEL: foo:
; CHECK: # %bb.0: # %entry
; CHECK-NEXT: pushq %r15
; CHECK-NEXT: .cfi_def_cfa_offset 16
; CHECK-NEXT: pushq %r14
; CHECK-NEXT: .cfi_def_cfa_offset 24
; CHECK-NEXT: pushq %r13
; CHECK-NEXT: .cfi_def_cfa_offset 32
; CHECK-NEXT: pushq %r12
; CHECK-NEXT: .cfi_def_cfa_offset 40
; CHECK-NEXT: pushq %rbx
; CHECK-NEXT: .cfi_def_cfa_offset 48
; CHECK-NEXT: .cfi_offset %rbx, -48
; CHECK-NEXT: .cfi_offset %r12, -40
; CHECK-NEXT: .cfi_offset %r13, -32
; CHECK-NEXT: .cfi_offset %r14, -24
; CHECK-NEXT: .cfi_offset %r15, -16
; CHECK-NEXT: movq %r9, %r14
; CHECK-NEXT: movq %r8, %rbx
; CHECK-NEXT: movq %rcx, %r12
; CHECK-NEXT: movq %rdx, %r15
; CHECK-NEXT: movq %rsi, %r13
; CHECK-NEXT: testq %rdi, %rdi
; CHECK-NEXT: je .LBB0_1
; CHECK-NEXT: # %bb.2: # %if.else
; CHECK-NEXT: testq %r13, %r13
; CHECK-NEXT: movq %r15, %rax
; CHECK-NEXT: je .LBB0_3
; CHECK-NEXT: .LBB0_4: # %if.end
; CHECK-NEXT: addq %r13, %rax
; CHECK-NEXT: addq %r12, %r15
; CHECK-NEXT: addq %rax, %r15
; CHECK-NEXT: addq %r14, %rbx
; CHECK-NEXT: addq %r15, %rbx
; CHECK-NEXT: movq %rbx, %rax
; CHECK-NEXT: popq %rbx
; CHECK-NEXT: .cfi_def_cfa_offset 40
; CHECK-NEXT: popq %r12
; CHECK-NEXT: .cfi_def_cfa_offset 32
; CHECK-NEXT: popq %r13
; CHECK-NEXT: .cfi_def_cfa_offset 24
; CHECK-NEXT: popq %r14
; CHECK-NEXT: .cfi_def_cfa_offset 16
; CHECK-NEXT: popq %r15
; CHECK-NEXT: .cfi_def_cfa_offset 8
; CHECK-NEXT: retq
; CHECK-NEXT: .LBB0_1: # %if.then
; CHECK-NEXT: .cfi_def_cfa_offset 48
; CHECK-NEXT: callq bar1@PLT
; CHECK-NEXT: jmp .LBB0_4
; CHECK-NEXT: .LBB0_3: # %if.then2
; CHECK-NEXT: callq bar2@PLT
; CHECK-NEXT: jmp .LBB0_4
entry:
%tobool.not = icmp eq ptr %ptr, null
br i1 %tobool.not, label %if.then, label %if.else, !prof !5
if.then: ; preds = %entry
%call1 = call i64 @bar1()
br label %if.end
if.else:
%cond = icmp eq i64 %p2, 0
br i1 %cond, label %if.then2, label %if.end, !prof !5
if.then2:
%call2 = call i64 @bar2()
br label %if.end
if.end:
%call = phi i64 [ %call1, %if.then ], [%call2, %if.then2], [ %p3, %if.else ]
%add1 = add i64 %call, %p2
%add2 = add i64 %add1, %p3
%add3 = add i64 %add2, %p4
%add4 = add i64 %add3, %p5
%res = add i64 %add4, %p6
ret i64 %res
}
!5 = !{!"branch_weights", i32 1, i32 2000}
declare i64 @bar1()
declare i64 @bar2()