From 7ff7bd9b3c7b6b15399b9f03799baceb300e7888 Mon Sep 17 00:00:00 2001 From: Sanjay Patel <spatel@rotateright.com> Date: Mon, 20 Aug 2018 17:31:34 +0000 Subject: [PATCH] [ConstantFolding] add tests for binops on vectors with undef elements; NFC llvm-svn: 340190 --- .../ConstantFolding/vector-undef-elts.ll | 61 +++++++++++++++++++ 1 file changed, 61 insertions(+) create mode 100644 llvm/test/Analysis/ConstantFolding/vector-undef-elts.ll 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 000000000000..c590dd3cdf77 --- /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 +} +