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, + 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> , 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, + ret <3 x i8> %c +} + +define <3 x i8> @or() { +; CHECK-LABEL: @or( +; CHECK-NEXT: ret <3 x i8> +; + %c = or <3 x i8> , undef + ret <3 x i8> %c +} + +define <3 x i8> @or_commute() { +; CHECK-LABEL: @or_commute( +; CHECK-NEXT: ret <3 x i8> +; + %c = or <3 x i8> undef, + ret <3 x i8> %c +} + +define <3 x float> @fadd() { +; CHECK-LABEL: @fadd( +; CHECK-NEXT: ret <3 x float> +; + %c = fadd <3 x float> , undef + ret <3 x float> %c +} + +define <3 x float> @fadd_commute() { +; CHECK-LABEL: @fadd_commute( +; CHECK-NEXT: ret <3 x float> +; + %c = fadd <3 x float> undef, + ret <3 x float> %c +} +