diff options
author | Sanjay Patel <spatel@rotateright.com> | 2018-08-20 17:31:34 +0000 |
---|---|---|
committer | Sanjay Patel <spatel@rotateright.com> | 2018-08-20 17:31:34 +0000 |
commit | 7ff7bd9b3c7b6b15399b9f03799baceb300e7888 (patch) | |
tree | 27ba8a1316325fb2e27c08e79d7dabedc9d624f7 | |
parent | 651c2cdb4c04fcf3546a15d2fbb1a3296d840376 (diff) | |
download | bcm5719-llvm-7ff7bd9b3c7b6b15399b9f03799baceb300e7888.tar.gz bcm5719-llvm-7ff7bd9b3c7b6b15399b9f03799baceb300e7888.zip |
[ConstantFolding] add tests for binops on vectors with undef elements; NFC
llvm-svn: 340190
-rw-r--r-- | llvm/test/Analysis/ConstantFolding/vector-undef-elts.ll | 61 |
1 files changed, 61 insertions, 0 deletions
diff --git a/llvm/test/Analysis/ConstantFolding/vector-undef-elts.ll b/llvm/test/Analysis/ConstantFolding/vector-undef-elts.ll new file mode 100644 index 00000000000..c590dd3cdf7 --- /dev/null +++ b/llvm/test/Analysis/ConstantFolding/vector-undef-elts.ll @@ -0,0 +1,61 @@ +; NOTE: Assertions have been autogenerated by utils/update_test_checks.py +; RUN: opt < %s -constprop -S -o - | FileCheck %s + +; FIXME: When both operands are undef in a lane, that lane should produce an undef result. + +define <3 x i8> @shl() { +; CHECK-LABEL: @shl( +; CHECK-NEXT: ret <3 x i8> zeroinitializer +; + %c = shl <3 x i8> undef, <i8 undef, i8 4, i8 1> + ret <3 x i8> %c +} + +define <3 x i8> @and() { +; CHECK-LABEL: @and( +; CHECK-NEXT: ret <3 x i8> zeroinitializer +; + %c = and <3 x i8> <i8 undef, i8 42, i8 undef>, undef + ret <3 x i8> %c +} + +define <3 x i8> @and_commute() { +; CHECK-LABEL: @and_commute( +; CHECK-NEXT: ret <3 x i8> zeroinitializer +; + %c = and <3 x i8> undef, <i8 -42, i8 42, i8 undef> + ret <3 x i8> %c +} + +define <3 x i8> @or() { +; CHECK-LABEL: @or( +; CHECK-NEXT: ret <3 x i8> <i8 -1, i8 -1, i8 -1> +; + %c = or <3 x i8> <i8 undef, i8 42, i8 undef>, undef + ret <3 x i8> %c +} + +define <3 x i8> @or_commute() { +; CHECK-LABEL: @or_commute( +; CHECK-NEXT: ret <3 x i8> <i8 -1, i8 -1, i8 -1> +; + %c = or <3 x i8> undef, <i8 -42, i8 42, i8 undef> + ret <3 x i8> %c +} + +define <3 x float> @fadd() { +; CHECK-LABEL: @fadd( +; CHECK-NEXT: ret <3 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000, float 0x7FF8000000000000> +; + %c = fadd <3 x float> <float undef, float 42.0, float undef>, undef + ret <3 x float> %c +} + +define <3 x float> @fadd_commute() { +; CHECK-LABEL: @fadd_commute( +; CHECK-NEXT: ret <3 x float> <float 0x7FF8000000000000, float 0x7FF8000000000000, float 0x7FF8000000000000> +; + %c = fadd <3 x float> undef, <float -42.0, float 42.0, float undef> + ret <3 x float> %c +} + |