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