| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc -verify-machineinstrs -mtriple=powerpc64le -ppc-asm-full-reg-names \ |
| ; RUN: < %s | FileCheck %s |
| |
| define i64 @julia_div_i64(i64 %0, i64 %1) local_unnamed_addr #0 { |
| ; CHECK-LABEL: julia_div_i64: |
| ; CHECK: # %bb.0: # %entry |
| ; CHECK-NEXT: divd r5, r3, r4 |
| ; CHECK-NEXT: lis r6, -1592 |
| ; CHECK-NEXT: cmpdi r3, 0 |
| ; CHECK-NEXT: ori r7, r6, 21321 |
| ; CHECK-NEXT: ori r6, r6, 65519 |
| ; CHECK-NEXT: rldic r7, r7, 4, 17 |
| ; CHECK-NEXT: rldic r6, r6, 4, 17 |
| ; CHECK-NEXT: iselgt r8, r6, r7 |
| ; CHECK-NEXT: cmpdi r4, 0 |
| ; CHECK-NEXT: iselgt r6, r6, r7 |
| ; CHECK-NEXT: xor r6, r8, r6 |
| ; CHECK-NEXT: cntlzd r6, r6 |
| ; CHECK-NEXT: rldicl r6, r6, 58, 63 |
| ; CHECK-NEXT: mulld r4, r5, r4 |
| ; CHECK-NEXT: xor r3, r4, r3 |
| ; CHECK-NEXT: addic r4, r3, -1 |
| ; CHECK-NEXT: subfe r3, r4, r3 |
| ; CHECK-NEXT: and r3, r6, r3 |
| ; CHECK-NEXT: add r3, r5, r3 |
| ; CHECK-NEXT: blr |
| entry: |
| %2 = sdiv i64 %0, %1 |
| %3 = icmp sgt i64 %0, 0 |
| %4 = icmp sgt i64 %1, 0 |
| %5 = select i1 %3, i64 140735820070640, i64 140735819363472 |
| %6 = select i1 %4, i64 140735820070640, i64 140735819363472 |
| %7 = icmp eq i64 %5, %6 |
| %8 = mul i64 %2, %1 |
| %9 = icmp ne i64 %8, %0 |
| %10 = and i1 %7, %9 |
| %11 = zext i1 %10 to i64 |
| %12 = add i64 %2, %11 |
| ret i64 %12 |
| } |