blob: cf200a121d0f182aef0bf21e17c805ece9658973 [file] [log] [blame]
; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py
; RUN: llc -O3 < %s -relocation-model=pic -mtriple=sparc -mcpu=v9 | FileCheck --check-prefix=SPARC %s
; RUN: llc -O3 < %s -relocation-model=pic -mtriple=sparcv9 | FileCheck --check-prefix=SPARC64 %s
; RUN: llc -O3 < %s -relocation-model=pic -mtriple=sparc -mcpu=v9 -mattr=+no-predictor | FileCheck --check-prefix=SPARC-NO-PREDICTOR %s
; RUN: llc -O3 < %s -relocation-model=pic -mtriple=sparcv9 -mattr=+no-predictor | FileCheck --check-prefix=SPARC64-NO-PREDICTOR %s
;; Normally, highly predictable selects should be turned into branches.
;; On the other hand, early Niagara processors should prefer conditional moves
;; over branches even when it's predictable.
define i32 @cdiv(i32 %cond, i32 %num) #0 {
; SPARC-LABEL: cdiv:
; SPARC: ! %bb.0: ! %entry
; SPARC-NEXT: cmp %o0, 0
; SPARC-NEXT: be %icc, .LBB0_2
; SPARC-NEXT: mov %o1, %o0
; SPARC-NEXT: ! %bb.1: ! %select.end
; SPARC-NEXT: retl
; SPARC-NEXT: nop
; SPARC-NEXT: .LBB0_2: ! %select.true.sink
; SPARC-NEXT: sethi 1398101, %o1
; SPARC-NEXT: or %o1, 342, %o1
; SPARC-NEXT: smul %o0, %o1, %o0
; SPARC-NEXT: rd %y, %o0
; SPARC-NEXT: srl %o0, 31, %o1
; SPARC-NEXT: retl
; SPARC-NEXT: add %o0, %o1, %o0
;
; SPARC64-LABEL: cdiv:
; SPARC64: ! %bb.0: ! %entry
; SPARC64-NEXT: cmp %o0, 0
; SPARC64-NEXT: be %icc, .LBB0_2
; SPARC64-NEXT: mov %o1, %o0
; SPARC64-NEXT: ! %bb.1: ! %select.end
; SPARC64-NEXT: retl
; SPARC64-NEXT: nop
; SPARC64-NEXT: .LBB0_2: ! %select.true.sink
; SPARC64-NEXT: sra %o0, 0, %o0
; SPARC64-NEXT: sethi 1398101, %o1
; SPARC64-NEXT: or %o1, 342, %o1
; SPARC64-NEXT: mulx %o0, %o1, %o0
; SPARC64-NEXT: srlx %o0, 63, %o1
; SPARC64-NEXT: srlx %o0, 32, %o0
; SPARC64-NEXT: retl
; SPARC64-NEXT: add %o0, %o1, %o0
;
; SPARC-NO-PREDICTOR-LABEL: cdiv:
; SPARC-NO-PREDICTOR: ! %bb.0: ! %entry
; SPARC-NO-PREDICTOR-NEXT: sethi 1398101, %o2
; SPARC-NO-PREDICTOR-NEXT: or %o2, 342, %o2
; SPARC-NO-PREDICTOR-NEXT: smul %o1, %o2, %o2
; SPARC-NO-PREDICTOR-NEXT: rd %y, %o2
; SPARC-NO-PREDICTOR-NEXT: srl %o2, 31, %o3
; SPARC-NO-PREDICTOR-NEXT: add %o2, %o3, %o2
; SPARC-NO-PREDICTOR-NEXT: cmp %o0, 0
; SPARC-NO-PREDICTOR-NEXT: move %icc, %o2, %o1
; SPARC-NO-PREDICTOR-NEXT: retl
; SPARC-NO-PREDICTOR-NEXT: mov %o1, %o0
;
; SPARC64-NO-PREDICTOR-LABEL: cdiv:
; SPARC64-NO-PREDICTOR: ! %bb.0: ! %entry
; SPARC64-NO-PREDICTOR-NEXT: sra %o1, 0, %o2
; SPARC64-NO-PREDICTOR-NEXT: sethi 1398101, %o3
; SPARC64-NO-PREDICTOR-NEXT: or %o3, 342, %o3
; SPARC64-NO-PREDICTOR-NEXT: mulx %o2, %o3, %o2
; SPARC64-NO-PREDICTOR-NEXT: srlx %o2, 63, %o3
; SPARC64-NO-PREDICTOR-NEXT: srlx %o2, 32, %o2
; SPARC64-NO-PREDICTOR-NEXT: add %o2, %o3, %o2
; SPARC64-NO-PREDICTOR-NEXT: cmp %o0, 0
; SPARC64-NO-PREDICTOR-NEXT: move %icc, %o2, %o1
; SPARC64-NO-PREDICTOR-NEXT: retl
; SPARC64-NO-PREDICTOR-NEXT: mov %o1, %o0
entry:
%div = sdiv i32 %num, 3
%cmp = icmp eq i32 %cond, 0
%ret = select i1 %cmp, i32 %div, i32 %num
ret i32 %ret
}
attributes #0 = { nounwind }