1*9880d681SAndroid Build Coastguard Worker; NOTE: Assertions have been autogenerated by utils/update_test_checks.py 2*9880d681SAndroid Build Coastguard Worker; RUN: opt < %s -instcombine -S | FileCheck %s 3*9880d681SAndroid Build Coastguard Worker 4*9880d681SAndroid Build Coastguard Worker; These would crash if we didn't check for a negative shift. 5*9880d681SAndroid Build Coastguard Worker 6*9880d681SAndroid Build Coastguard Worker; https://llvm.org/bugs/show_bug.cgi?id=12967 7*9880d681SAndroid Build Coastguard Worker 8*9880d681SAndroid Build Coastguard Workerdefine void @pr12967() { 9*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @pr12967( 10*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: entry: 11*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br label %loop 12*9880d681SAndroid Build Coastguard Worker; CHECK: loop: 13*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br label %loop 14*9880d681SAndroid Build Coastguard Worker; 15*9880d681SAndroid Build Coastguard Workerentry: 16*9880d681SAndroid Build Coastguard Worker br label %loop 17*9880d681SAndroid Build Coastguard Worker 18*9880d681SAndroid Build Coastguard Workerloop: 19*9880d681SAndroid Build Coastguard Worker %c = phi i32 [ %shl, %loop ], [ undef, %entry ] 20*9880d681SAndroid Build Coastguard Worker %shr = shl i32 %c, 7 21*9880d681SAndroid Build Coastguard Worker %shl = lshr i32 %shr, -2 22*9880d681SAndroid Build Coastguard Worker br label %loop 23*9880d681SAndroid Build Coastguard Worker} 24*9880d681SAndroid Build Coastguard Worker 25*9880d681SAndroid Build Coastguard Worker; https://llvm.org/bugs/show_bug.cgi?id=26760 26*9880d681SAndroid Build Coastguard Worker 27*9880d681SAndroid Build Coastguard Workerdefine void @pr26760() { 28*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @pr26760( 29*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: entry: 30*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br label %loop 31*9880d681SAndroid Build Coastguard Worker; CHECK: loop: 32*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br label %loop 33*9880d681SAndroid Build Coastguard Worker; 34*9880d681SAndroid Build Coastguard Workerentry: 35*9880d681SAndroid Build Coastguard Worker br label %loop 36*9880d681SAndroid Build Coastguard Worker 37*9880d681SAndroid Build Coastguard Workerloop: 38*9880d681SAndroid Build Coastguard Worker %c = phi i32 [ %shl, %loop ], [ undef, %entry ] 39*9880d681SAndroid Build Coastguard Worker %shr = lshr i32 %c, 7 40*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %shr, -2 41*9880d681SAndroid Build Coastguard Worker br label %loop 42*9880d681SAndroid Build Coastguard Worker} 43*9880d681SAndroid Build Coastguard Worker 44*9880d681SAndroid Build Coastguard Worker; Converting the 2 shifts to SHL 6 without the AND is wrong. 45*9880d681SAndroid Build Coastguard Worker; https://llvm.org/bugs/show_bug.cgi?id=8547 46*9880d681SAndroid Build Coastguard Worker 47*9880d681SAndroid Build Coastguard Workerdefine i32 @pr8547(i32* %g) { 48*9880d681SAndroid Build Coastguard Worker; CHECK-LABEL: @pr8547( 49*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: codeRepl: 50*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br label %for.cond 51*9880d681SAndroid Build Coastguard Worker; CHECK: for.cond: 52*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: [[STOREMERGE:%.*]] = phi i32 [ 0, %codeRepl ], [ 5, %for.cond ] 53*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: store i32 [[STOREMERGE]], i32* %g, align 4 54*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: [[TMP0:%.*]] = shl nuw nsw i32 [[STOREMERGE]], 6 55*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: [[CONV2:%.*]] = and i32 [[TMP0]], 64 56*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: [[TOBOOL:%.*]] = icmp eq i32 [[CONV2]], 0 57*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: br i1 [[TOBOOL]], label %for.cond, label %codeRepl2 58*9880d681SAndroid Build Coastguard Worker; CHECK: codeRepl2: 59*9880d681SAndroid Build Coastguard Worker; CHECK-NEXT: ret i32 [[CONV2]] 60*9880d681SAndroid Build Coastguard Worker; 61*9880d681SAndroid Build Coastguard WorkercodeRepl: 62*9880d681SAndroid Build Coastguard Worker br label %for.cond 63*9880d681SAndroid Build Coastguard Worker 64*9880d681SAndroid Build Coastguard Workerfor.cond: 65*9880d681SAndroid Build Coastguard Worker %storemerge = phi i32 [ 0, %codeRepl ], [ 5, %for.cond ] 66*9880d681SAndroid Build Coastguard Worker store i32 %storemerge, i32* %g, align 4 67*9880d681SAndroid Build Coastguard Worker %shl = shl i32 %storemerge, 30 68*9880d681SAndroid Build Coastguard Worker %conv2 = lshr i32 %shl, 24 69*9880d681SAndroid Build Coastguard Worker %tobool = icmp eq i32 %conv2, 0 70*9880d681SAndroid Build Coastguard Worker br i1 %tobool, label %for.cond, label %codeRepl2 71*9880d681SAndroid Build Coastguard Worker 72*9880d681SAndroid Build Coastguard WorkercodeRepl2: 73*9880d681SAndroid Build Coastguard Worker ret i32 %conv2 74*9880d681SAndroid Build Coastguard Worker} 75*9880d681SAndroid Build Coastguard Worker 76