llvm-mirror/test/Transforms/SCCP/ub-shift.ll
Florian Hahn 373d0c84dc Recommit "[SCCP] Use SimplifyBinOp for non-integer constant/expressions & overdef."
This includes a fix reported with simplifications in the presence of
NaN.

This reverts the revert commit 06408451bf12d4baed1fb1312d8af6e6bbb6a797.
2020-04-14 11:48:52 +01:00

83 lines
2.2 KiB
LLVM

; NOTE: Assertions have been autogenerated by utils/update_test_checks.py
; RUN: opt < %s -sccp -S | FileCheck %s
define void @shift_undef_64(i64* %p) {
; CHECK-LABEL: @shift_undef_64(
; CHECK-NEXT: store i64 0, i64* [[P:%.*]]
; CHECK-NEXT: store i64 -1, i64* [[P]]
; CHECK-NEXT: [[R3:%.*]] = shl i64 -1, 4294967298
; CHECK-NEXT: store i64 [[R3]], i64* [[P]]
; CHECK-NEXT: ret void
;
%r1 = lshr i64 -1, 4294967296 ; 2^32
store i64 %r1, i64* %p
%r2 = ashr i64 -1, 4294967297 ; 2^32 + 1
store i64 %r2, i64* %p
%r3 = shl i64 -1, 4294967298 ; 2^32 + 2
store i64 %r3, i64* %p
ret void
}
define void @shift_undef_65(i65* %p) {
; CHECK-LABEL: @shift_undef_65(
; CHECK-NEXT: store i65 0, i65* [[P:%.*]]
; CHECK-NEXT: store i65 0, i65* [[P]]
; CHECK-NEXT: [[R3:%.*]] = shl i65 1, -18446744073709551615
; CHECK-NEXT: store i65 [[R3]], i65* [[P]]
; CHECK-NEXT: ret void
;
%r1 = lshr i65 2, 18446744073709551617
store i65 %r1, i65* %p
%r2 = ashr i65 4, 18446744073709551617
store i65 %r2, i65* %p
%r3 = shl i65 1, 18446744073709551617
store i65 %r3, i65* %p
ret void
}
define void @shift_undef_256(i256* %p) {
; CHECK-LABEL: @shift_undef_256(
; CHECK-NEXT: store i256 0, i256* [[P:%.*]]
; CHECK-NEXT: store i256 0, i256* [[P]]
; CHECK-NEXT: [[R3:%.*]] = shl i256 1, 18446744073709551619
; CHECK-NEXT: store i256 [[R3]], i256* [[P]]
; CHECK-NEXT: ret void
;
%r1 = lshr i256 2, 18446744073709551617
store i256 %r1, i256* %p
%r2 = ashr i256 4, 18446744073709551618
store i256 %r2, i256* %p
%r3 = shl i256 1, 18446744073709551619
store i256 %r3, i256* %p
ret void
}
define void @shift_undef_511(i511* %p) {
; CHECK-LABEL: @shift_undef_511(
; CHECK-NEXT: store i511 0, i511* [[P:%.*]]
; CHECK-NEXT: store i511 -1, i511* [[P]]
; CHECK-NEXT: [[R3:%.*]] = shl i511 -3, 1208925819614629174706180
; CHECK-NEXT: store i511 [[R3]], i511* [[P]]
; CHECK-NEXT: ret void
;
%r1 = lshr i511 -1, 1208925819614629174706276 ; 2^80 + 100
store i511 %r1, i511* %p
%r2 = ashr i511 -2, 1208925819614629174706200
store i511 %r2, i511* %p
%r3 = shl i511 -3, 1208925819614629174706180
store i511 %r3, i511* %p
ret void
}