1; RUN: opt < %s -instcombine -S | FileCheck %s 2 3; CHECK: @sub1 4; CHECK: %y = sub i32 0, %x 5; CHECK: %z = sdiv i32 %y, 337 6; CHECK: ret i32 %z 7define i32 @sub1(i32 %x) { 8 %y = sub i32 0, %x 9 %z = sdiv i32 %y, 337 10 ret i32 %z 11} 12 13; CHECK: @sub2 14; CHECK: %z = sdiv i32 %x, -337 15; CHECK: ret i32 %z 16define i32 @sub2(i32 %x) { 17 %y = sub nsw i32 0, %x 18 %z = sdiv i32 %y, 337 19 ret i32 %z 20} 21 22; CHECK: @shl_icmp 23; CHECK: %B = icmp eq i64 %X, 0 24; CHECK: ret i1 %B 25define i1 @shl_icmp(i64 %X) nounwind { 26 %A = shl nuw i64 %X, 2 ; X/4 27 %B = icmp eq i64 %A, 0 28 ret i1 %B 29} 30 31; CHECK: @shl1 32; CHECK: %B = shl nuw nsw i64 %A, 8 33; CHECK: ret i64 %B 34define i64 @shl1(i64 %X, i64* %P) nounwind { 35 %A = and i64 %X, 312 36 store i64 %A, i64* %P ; multiple uses of A. 37 %B = shl i64 %A, 8 38 ret i64 %B 39} 40 41; CHECK: @preserve1 42; CHECK: add nsw i32 %x, 5 43define i32 @preserve1(i32 %x) nounwind { 44 %add = add nsw i32 %x, 2 45 %add3 = add nsw i32 %add, 3 46 ret i32 %add3 47} 48 49; CHECK: @nopreserve1 50; CHECK: add i8 %x, -126 51define i8 @nopreserve1(i8 %x) nounwind { 52 %add = add nsw i8 %x, 127 53 %add3 = add nsw i8 %add, 3 54 ret i8 %add3 55} 56 57; CHECK: @nopreserve2 58; CHECK: add i8 %x, 3 59define i8 @nopreserve2(i8 %x) nounwind { 60 %add = add i8 %x, 1 61 %add3 = add nsw i8 %add, 2 62 ret i8 %add3 63} 64 65; CHECK: @nopreserve3 66; CHECK: add i8 %A, %B 67; CHECK: add i8 68define i8 @nopreserve3(i8 %A, i8 %B) nounwind { 69 %x = add i8 %A, 10 70 %y = add i8 %B, 10 71 %add = add nsw i8 %x, %y 72 ret i8 %add 73} 74 75; CHECK: @nopreserve4 76; CHECK: add i8 %A, %B 77; CHECK: add i8 78define i8 @nopreserve4(i8 %A, i8 %B) nounwind { 79 %x = add nsw i8 %A, 10 80 %y = add nsw i8 %B, 10 81 %add = add nsw i8 %x, %y 82 ret i8 %add 83} 84