| ; NOTE: Assertions have been autogenerated by utils/update_llc_test_checks.py |
| ; RUN: llc < %s -mtriple=powerpc64le-unknown-linux-gnu -verify-machineinstrs\ |
| ; RUN: -mcpu=pwr9 --ppc-enable-pipeliner 2>&1 | FileCheck %s |
| |
| define void @phi5() unnamed_addr { |
| ; CHECK-LABEL: phi5: |
| ; CHECK: # %bb.0: |
| ; CHECK-NEXT: # %bb.1: |
| ; CHECK-NEXT: li 3, 0 |
| ; CHECK-NEXT: li 4, 1 |
| ; CHECK-NEXT: slw 3, 4, 3 |
| ; CHECK-NEXT: andi. 3, 3, 6336 |
| ; CHECK-NEXT: beqlr 0 |
| ; CHECK-NEXT: # %bb.2: |
| ; CHECK-NEXT: lhz 3, 0(3) |
| ; CHECK-NEXT: slwi 3, 3, 15 |
| ; CHECK-NEXT: clrlwi 3, 3, 31 |
| ; CHECK-NEXT: rlwinm 4, 3, 31, 17, 31 |
| ; CHECK-NEXT: or 3, 3, 4 |
| ; CHECK-NEXT: rlwimi 3, 3, 15, 0, 16 |
| ; CHECK-NEXT: # %bb.3: |
| ; CHECK-NEXT: blr |
| switch i12 undef, label %21 [ |
| i12 6, label %1 |
| i12 7, label %1 |
| i12 12, label %1 |
| i12 11, label %1 |
| ] |
| |
| 1: ; preds = %0, %0, %0, %0 |
| %2 = load i16, i16* undef, align 2 |
| br label %3 |
| |
| 3: ; preds = %3, %1 |
| %4 = phi i16 [ %18, %3 ], [ undef, %1 ] |
| %5 = phi i16 [ %13, %3 ], [ undef, %1 ] |
| %6 = phi i16 [ %11, %3 ], [ undef, %1 ] |
| %7 = phi i16 [ undef, %3 ], [ %2, %1 ] |
| %8 = phi i32 [ %19, %3 ], [ undef, %1 ] |
| %9 = lshr i16 %6, 1 |
| %10 = shl i16 %7, 15 |
| %11 = or i16 %10, %9 |
| %12 = shl i16 %6, 15 |
| %13 = or i16 %12, 0 |
| %14 = and i16 %4, 1 |
| %15 = lshr i16 %4, 1 |
| %16 = shl i16 %5, 15 |
| %17 = or i16 %14, %15 |
| %18 = or i16 %17, %16 |
| %19 = add i32 %8, -1 |
| %20 = icmp eq i32 %19, 0 |
| br i1 %20, label %21, label %3 |
| |
| 21: ; preds = %3, %0 |
| ret void |
| } |