<div dir="ltr">FYI reverting due to the LLVM commit getting reverted. See <a href="http://llvm.org/PR37260">http://llvm.org/PR37260</a> for details.</div><br><div class="gmail_quote"><div dir="ltr">On Thu, Apr 19, 2018 at 6:32 AM Alexander Ivchenko via cfe-commits <<a href="mailto:cfe-commits@lists.llvm.org">cfe-commits@lists.llvm.org</a>> wrote:<br></div><blockquote class="gmail_quote" style="margin:0 0 0 .8ex;border-left:1px #ccc solid;padding-left:1ex">Author: aivchenk<br>
Date: Thu Apr 19 05:15:11 2018<br>
New Revision: 330323<br>
<br>
URL: <a href="http://llvm.org/viewvc/llvm-project?rev=330323&view=rev" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project?rev=330323&view=rev</a><br>
Log:<br>
Lowering x86 adds/addus/subs/subus intrinsics (clang)<br>
<br>
This is the patch that lowers x86 intrinsics to native IR<br>
in order to enable optimizations.<br>
<br>
Patch by tkrupa<br>
<br>
Differential Revision: <a href="https://reviews.llvm.org/D44786" rel="noreferrer" target="_blank">https://reviews.llvm.org/D44786</a><br>
<br>
Modified:<br>
    cfe/trunk/lib/CodeGen/CGBuiltin.cpp<br>
    cfe/trunk/test/CodeGen/avx2-builtins.c<br>
    cfe/trunk/test/CodeGen/avx512bw-builtins.c<br>
    cfe/trunk/test/CodeGen/avx512vlbw-builtins.c<br>
    cfe/trunk/test/CodeGen/sse2-builtins.c<br>
<br>
Modified: cfe/trunk/lib/CodeGen/CGBuiltin.cpp<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGBuiltin.cpp?rev=330323&r1=330322&r2=330323&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/lib/CodeGen/CGBuiltin.cpp?rev=330323&r1=330322&r2=330323&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/lib/CodeGen/CGBuiltin.cpp (original)<br>
+++ cfe/trunk/lib/CodeGen/CGBuiltin.cpp Thu Apr 19 05:15:11 2018<br>
@@ -8449,6 +8449,76 @@ static Value *EmitX86SExtMask(CodeGenFun<br>
   return CGF.Builder.CreateSExt(Mask, DstTy, "vpmovm2");<br>
 }<br>
<br>
+// Emit addition or subtraction with saturation.<br>
+// Handles both signed and unsigned intrinsics.<br>
+static Value *EmitX86AddSubSatExpr(CodeGenFunction &CGF, const CallExpr *E,<br>
+                                   SmallVectorImpl<Value *> &Ops,<br>
+                                   bool IsAddition, bool Signed) {<br>
+<br>
+  // Collect vector elements and type data.<br>
+  llvm::Type *ResultType = CGF.ConvertType(E->getType());<br>
+  int NumElements = ResultType->getVectorNumElements();<br>
+  Value *Res;<br>
+  if (!IsAddition && !Signed) {<br>
+    Value *ICmp = CGF.Builder.CreateICmp(ICmpInst::ICMP_UGT, Ops[0], Ops[1]);<br>
+    Value *Select = CGF.Builder.CreateSelect(ICmp, Ops[0], Ops[1]);<br>
+    Res = CGF.Builder.CreateSub(Select, Ops[1]);<br>
+  } else {<br>
+    unsigned EltSizeInBits = ResultType->getScalarSizeInBits();<br>
+    llvm::Type *ExtElementType = EltSizeInBits == 8 ?<br>
+                                 CGF.Builder.getInt16Ty() :<br>
+                                 CGF.Builder.getInt32Ty();<br>
+<br>
+    // Extending vectors to next possible width to make space for possible<br>
+    // overflow.<br>
+    llvm::Type *ExtType = llvm::VectorType::get(ExtElementType, NumElements);<br>
+    Value *VecA = Signed ? CGF.Builder.CreateSExt(Ops[0], ExtType)<br>
+                         : CGF.Builder.CreateZExt(Ops[0], ExtType);<br>
+    Value *VecB = Signed ? CGF.Builder.CreateSExt(Ops[1], ExtType)<br>
+                         : CGF.Builder.CreateZExt(Ops[1], ExtType);<br>
+<br>
+    llvm::Value *ExtProduct = IsAddition ? CGF.Builder.CreateAdd(VecA, VecB)<br>
+                                         : CGF.Builder.CreateSub(VecA, VecB);<br>
+<br>
+    // Create vector of the same type as expected result with max possible<br>
+    // values and extend it to the same type as the product of the addition.<br>
+    APInt SignedMaxValue =<br>
+        llvm::APInt::getSignedMaxValue(EltSizeInBits);<br>
+    Value *Max = Signed ? llvm::ConstantInt::get(ResultType, SignedMaxValue)<br>
+                        : llvm::Constant::getAllOnesValue(ResultType);<br>
+    Value *ExtMaxVec = Signed ? CGF.Builder.CreateSExt(Max, ExtType)<br>
+                              : CGF.Builder.CreateZExt(Max, ExtType);<br>
+    // In Product, replace all overflowed values with max values of non-extended<br>
+    // type.<br>
+    ICmpInst::Predicate Pred = Signed ? ICmpInst::ICMP_SLE : ICmpInst::ICMP_ULE;<br>
+    Value *Cmp = CGF.Builder.CreateICmp(Pred, ExtProduct,<br>
+                                        ExtMaxVec); // 1 if no overflow.<br>
+    Value *SaturatedProduct = CGF.Builder.CreateSelect(<br>
+        Cmp, ExtProduct, ExtMaxVec); // If overflowed, copy from max values.<br>
+<br>
+    if (Signed) {<br>
+      APInt SignedMinValue =<br>
+          llvm::APInt::getSignedMinValue(EltSizeInBits);<br>
+      Value *Min = llvm::ConstantInt::get(ResultType, SignedMinValue);<br>
+      Value *ExtMinVec = CGF.Builder.CreateSExt(Min, ExtType);<br>
+      Value *IsNegative =<br>
+        CGF.Builder.CreateICmp(ICmpInst::ICMP_SLT, SaturatedProduct, ExtMinVec);<br>
+      SaturatedProduct =<br>
+        CGF.Builder.CreateSelect(IsNegative, ExtMinVec, SaturatedProduct);<br>
+    }<br>
+<br>
+    Res = CGF.Builder.CreateTrunc(SaturatedProduct,<br>
+                                  ResultType); // Trunc to ResultType.<br>
+  }<br>
+  if (E->getNumArgs() == 4) { // For masked intrinsics.<br>
+    Value *VecSRC = Ops[2];<br>
+    Value *Mask = Ops[3];<br>
+    return EmitX86Select(CGF, Mask, Res, VecSRC);<br>
+  }<br>
+<br>
+  return Res;<br>
+}<br>
+<br>
 Value *CodeGenFunction::EmitX86CpuIs(const CallExpr *E) {<br>
   const Expr *CPUExpr = E->getArg(0)->IgnoreParenCasts();<br>
   StringRef CPUStr = cast<clang::StringLiteral>(CPUExpr)->getString();<br>
@@ -9516,10 +9586,37 @@ Value *CodeGenFunction::EmitX86BuiltinEx<br>
     Load->setVolatile(true);<br>
     return Load;<br>
   }<br>
+  case X86::BI__builtin_ia32_paddusb512_mask:<br>
+  case X86::BI__builtin_ia32_paddusw512_mask:<br>
+  case X86::BI__builtin_ia32_paddusb256:<br>
+  case X86::BI__builtin_ia32_paddusw256:<br>
+  case X86::BI__builtin_ia32_paddusb128:<br>
+  case X86::BI__builtin_ia32_paddusw128:<br>
+    return EmitX86AddSubSatExpr(*this, E, Ops, true, false); // Add, unsigned.<br>
+  case X86::BI__builtin_ia32_paddsb512_mask:<br>
+  case X86::BI__builtin_ia32_paddsw512_mask:<br>
+  case X86::BI__builtin_ia32_paddsb256:<br>
+  case X86::BI__builtin_ia32_paddsw256:<br>
+  case X86::BI__builtin_ia32_paddsb128:<br>
+  case X86::BI__builtin_ia32_paddsw128:<br>
+    return EmitX86AddSubSatExpr(*this, E, Ops, true, true); // Add, signed.<br>
+  case X86::BI__builtin_ia32_psubusb512_mask:<br>
+  case X86::BI__builtin_ia32_psubusw512_mask:<br>
+  case X86::BI__builtin_ia32_psubusb256:<br>
+  case X86::BI__builtin_ia32_psubusw256:<br>
+  case X86::BI__builtin_ia32_psubusb128:<br>
+  case X86::BI__builtin_ia32_psubusw128:<br>
+    return EmitX86AddSubSatExpr(*this, E, Ops, false, false); // Sub, unsigned.<br>
+  case X86::BI__builtin_ia32_psubsb512_mask:<br>
+  case X86::BI__builtin_ia32_psubsw512_mask:<br>
+  case X86::BI__builtin_ia32_psubsb256:<br>
+  case X86::BI__builtin_ia32_psubsw256:<br>
+  case X86::BI__builtin_ia32_psubsb128:<br>
+  case X86::BI__builtin_ia32_psubsw128:<br>
+    return EmitX86AddSubSatExpr(*this, E, Ops, false, true); // Sub, signed.<br>
   }<br>
 }<br>
<br>
-<br>
 Value *CodeGenFunction::EmitPPCBuiltinExpr(unsigned BuiltinID,<br>
                                            const CallExpr *E) {<br>
   SmallVector<Value*, 4> Ops;<br>
<br>
Modified: cfe/trunk/test/CodeGen/avx2-builtins.c<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx2-builtins.c?rev=330323&r1=330322&r2=330323&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx2-builtins.c?rev=330323&r1=330322&r2=330323&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/CodeGen/avx2-builtins.c (original)<br>
+++ cfe/trunk/test/CodeGen/avx2-builtins.c Thu Apr 19 05:15:11 2018<br>
@@ -56,25 +56,53 @@ __m256i test_mm256_add_epi64(__m256i a,<br>
<br>
 __m256i test_mm256_adds_epi8(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_adds_epi8<br>
-  // CHECK: call <32 x i8> @llvm.x86.avx2.padds.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK-NOT: call <32 x i8> @llvm.x86.avx2.padds.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <32 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <32 x i16> %{{.*}}<br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   return _mm256_adds_epi8(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_adds_epi16(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_adds_epi16<br>
-  // CHECK: call <16 x i16> @llvm.x86.avx2.padds.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK-NOT: call <16 x i16> @llvm.x86.avx2.padds.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <16 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <16 x i32> %{{.*}}<br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   return _mm256_adds_epi16(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_adds_epu8(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_adds_epu8<br>
-  // CHECK: call <32 x i8> @llvm.x86.avx2.paddus.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK-NOT: call <32 x i8> @llvm.x86.avx2.paddus.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   return _mm256_adds_epu8(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_adds_epu16(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_adds_epu16<br>
-  // CHECK: call <16 x i16> @llvm.x86.avx2.paddus.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK-NOT: call <16 x i16> @llvm.x86.avx2.paddus.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <16 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   return _mm256_adds_epu16(a, b);<br>
 }<br>
<br>
@@ -1171,25 +1199,47 @@ __m256i test_mm256_sub_epi64(__m256i a,<br>
<br>
 __m256i test_mm256_subs_epi8(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_subs_epi8<br>
-  // CHECK: call <32 x i8> @llvm.x86.avx2.psubs.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK-NOT: call <32 x i8> @llvm.x86.avx2.psubs.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: sub <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <32 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <32 x i16> %{{.*}}<br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   return _mm256_subs_epi8(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_subs_epi16(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_subs_epi16<br>
-  // CHECK: call <16 x i16> @llvm.x86.avx2.psubs.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK-NOT: call <16 x i16> @llvm.x86.avx2.psubs.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: sub <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <16 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <16 x i32> %{{.*}}<br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   return _mm256_subs_epi16(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_subs_epu8(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_subs_epu8<br>
-  // CHECK: call <32 x i8> @llvm.x86.avx2.psubus.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK-NOT: call <32 x i8> @llvm.x86.avx2.psubus.b(<32 x i8> %{{.*}}, <32 x i8> %{{.*}})<br>
+  // CHECK: icmp ugt <32 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> {{.*}}, <32 x i8> {{.*}}, <32 x i8> {{.*}}<br>
+  // CHECK: sub <32 x i8> {{.*}}, {{.*}}<br>
   return _mm256_subs_epu8(a, b);<br>
 }<br>
<br>
 __m256i test_mm256_subs_epu16(__m256i a, __m256i b) {<br>
   // CHECK-LABEL: test_mm256_subs_epu16<br>
-  // CHECK: call <16 x i16> @llvm.x86.avx2.psubus.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK-NOT: call <16 x i16> @llvm.x86.avx2.psubus.w(<16 x i16> %{{.*}}, <16 x i16> %{{.*}})<br>
+  // CHECK: icmp ugt <16 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <16 x i1> {{.*}}, <16 x i16> {{.*}}, <16 x i16> {{.*}}<br>
+  // CHECK: sub <16 x i16> {{.*}}, {{.*}}<br>
   return _mm256_subs_epu16(a, b);<br>
 }<br>
<br>
<br>
Modified: cfe/trunk/test/CodeGen/avx512bw-builtins.c<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx512bw-builtins.c?rev=330323&r1=330322&r2=330323&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx512bw-builtins.c?rev=330323&r1=330322&r2=330323&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/CodeGen/avx512bw-builtins.c (original)<br>
+++ cfe/trunk/test/CodeGen/avx512bw-builtins.c Thu Apr 19 05:15:11 2018<br>
@@ -594,62 +594,154 @@ __m512i test_mm512_maskz_packus_epi16(__<br>
 }<br>
 __m512i test_mm512_adds_epi8(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_adds_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.b.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
   return _mm512_adds_epi8(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_adds_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_adds_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.b.512<br>
-  return _mm512_mask_adds_epi8(__W,__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
+ return _mm512_mask_adds_epi8(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_adds_epi8(__mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_adds_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.b.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
   return _mm512_maskz_adds_epi8(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_adds_epi16(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_adds_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.w.512<br>
-  return _mm512_adds_epi16(__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+ return _mm512_adds_epi16(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_adds_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_adds_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.w.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
   return _mm512_mask_adds_epi16(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_adds_epi16(__mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_adds_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.padds.w.512<br>
-  return _mm512_maskz_adds_epi16(__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.padds.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
+return _mm512_maskz_adds_epi16(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_adds_epu8(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_adds_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <64 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
   return _mm512_adds_epu8(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_adds_epu8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_adds_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <64 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
   return _mm512_mask_adds_epu8(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_adds_epu8(__mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_adds_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.b.512<br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: zext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: add <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <64 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
   return _mm512_maskz_adds_epu8(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_adds_epu16(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_adds_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
   return _mm512_adds_epu16(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_adds_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_adds_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
   return _mm512_mask_adds_epu16(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_adds_epu16(__mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_adds_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.paddus.w.512<br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: zext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: add <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
   return _mm512_maskz_adds_epu16(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_avg_epu8(__m512i __A, __m512i __B) {<br>
@@ -903,63 +995,137 @@ __m512i test_mm512_maskz_shuffle_epi8(__<br>
 }<br>
 __m512i test_mm512_subs_epi8(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_subs_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.b.512<br>
-  return _mm512_subs_epi8(__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sub <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+return _mm512_subs_epi8(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_subs_epi8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_subs_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.b.512<br>
-  return _mm512_mask_subs_epi8(__W,__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sub <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
+return _mm512_mask_subs_epi8(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_subs_epi8(__mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_subs_epi8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.b.512<br>
-  return _mm512_maskz_subs_epi8(__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.b.512<br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sext <64 x i8> %{{.*}} to <64 x i16><br>
+  // CHECK: sub <64 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <64 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> %{{.*}}, <64 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <64 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <64 x i16> %{{.*}}<br>
+  // CHECK: trunc <64 x i16> %{{.*}} to <64 x i8><br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
+return _mm512_maskz_subs_epi8(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_subs_epi16(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_subs_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.w.512<br>
-  return _mm512_subs_epi16(__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sub <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+return _mm512_subs_epi16(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_subs_epi16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_subs_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.w.512<br>
-  return _mm512_mask_subs_epi16(__W,__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sub <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
+return _mm512_mask_subs_epi16(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_subs_epi16(__mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_subs_epi16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubs.w.512<br>
-  return _mm512_maskz_subs_epi16(__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubs.w.512<br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sext <32 x i16> %{{.*}} to <32 x i32><br>
+  // CHECK: sub <32 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> %{{.*}}, <32 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <32 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <32 x i32> %{{.*}}<br>
+  // CHECK: trunc <32 x i32> %{{.*}} to <32 x i16><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
+return _mm512_maskz_subs_epi16(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_subs_epu8(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_subs_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.b.512<br>
-  return _mm512_subs_epu8(__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.b.512<br>
+  // CHECK: icmp ugt <64 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <64 x i1> {{.*}}, <64 x i8> {{.*}}, <64 x i8> {{.*}}<br>
+  // CHECK: sub <64 x i8> {{.*}}, {{.*}}<br>
+return _mm512_subs_epu8(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_subs_epu8(__m512i __W, __mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_subs_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.b.512<br>
-  return _mm512_mask_subs_epu8(__W,__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.b.512<br>
+  // CHECK: icmp ugt <64 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <64 x i1> {{.*}}, <64 x i8> {{.*}}, <64 x i8> {{.*}}<br>
+  // CHECK: sub <64 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
+return _mm512_mask_subs_epu8(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_subs_epu8(__mmask64 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_subs_epu8<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.b.512<br>
-  return _mm512_maskz_subs_epu8(__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.b.512<br>
+  // CHECK: icmp ugt <64 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <64 x i1> {{.*}}, <64 x i8> {{.*}}, <64 x i8> {{.*}}<br>
+  // CHECK: sub <64 x i8> {{.*}}, {{.*}}<br>
+  // CHECK: select <64 x i1> %{{.*}}, <64 x i8> %{{.*}}, <64 x i8> %{{.*}}<br>
+return _mm512_maskz_subs_epu8(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_subs_epu16(__m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_subs_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.w.512<br>
-  return _mm512_subs_epu16(__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.w.512<br>
+  // CHECK: icmp ugt <32 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> {{.*}}, <32 x i16> {{.*}}, <32 x i16> {{.*}}<br>
+  // CHECK: sub <32 x i16> {{.*}}, {{.*}}<br>
+return _mm512_subs_epu16(__A,__B); <br>
 }<br>
 __m512i test_mm512_mask_subs_epu16(__m512i __W, __mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask_subs_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.w.512<br>
-  return _mm512_mask_subs_epu16(__W,__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.w.512<br>
+  // CHECK: icmp ugt <32 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> {{.*}}, <32 x i16> {{.*}}, <32 x i16> {{.*}}<br>
+  // CHECK: sub <32 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
+return _mm512_mask_subs_epu16(__W,__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_maskz_subs_epu16(__mmask32 __U, __m512i __A, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_maskz_subs_epu16<br>
-  // CHECK: @llvm.x86.avx512.mask.psubus.w.512<br>
-  return _mm512_maskz_subs_epu16(__U,__A,__B); <br>
+  // CHECK-NOT: @llvm.x86.avx512.mask.psubus.w.512<br>
+  // CHECK: icmp ugt <32 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> {{.*}}, <32 x i16> {{.*}}, <32 x i16> {{.*}}<br>
+  // CHECK: sub <32 x i16> {{.*}}, {{.*}}<br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> %{{.*}}<br>
+return _mm512_maskz_subs_epu16(__U,__A,__B); <br>
 }<br>
 __m512i test_mm512_mask2_permutex2var_epi16(__m512i __A, __m512i __I, __mmask32 __U, __m512i __B) {<br>
   // CHECK-LABEL: @test_mm512_mask2_permutex2var_epi16<br>
<br>
Modified: cfe/trunk/test/CodeGen/avx512vlbw-builtins.c<br>
URL: <a href="http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx512vlbw-builtins.c?rev=330323&r1=330322&r2=330323&view=diff" rel="noreferrer" target="_blank">http://llvm.org/viewvc/llvm-project/cfe/trunk/test/CodeGen/avx512vlbw-builtins.c?rev=330323&r1=330322&r2=330323&view=diff</a><br>
==============================================================================<br>
--- cfe/trunk/test/CodeGen/avx512vlbw-builtins.c (original)<br>
+++ cfe/trunk/test/CodeGen/avx512vlbw-builtins.c Thu Apr 19 05:15:11 2018<br>
@@ -1075,97 +1075,211 @@ __m256i test_mm256_mask_packus_epi16(__m<br>
<br>
 __m128i test_mm_mask_adds_epi8(__m128i __W, __mmask16 __U, __m128i __A,        __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_mask_adds_epi8<br>
-  // CHECK: @llvm.x86.sse2.padds.b<br>
+  // CHECK-NOT: @llvm.x86.sse2.padds.b<br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: add <16 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <16 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+<br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <16 x i16> %{{.*}}<br>
+  // CHECK: trunc <16 x i16> %{{.*}} to <16 x i8><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}<br>
   return _mm_mask_adds_epi8(__W,__U,__A,__B); <br>
 }<br>
 __m128i test_mm_maskz_adds_epi8(__mmask16 __U, __m128i __A, __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_maskz_adds_epi8<br>
-  // CHECK: @llvm.x86.sse2.padds.b<br>
+  // CHECK-NOT: @llvm.x86.sse2.padds.b<br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: add <16 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <16 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+<br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <16 x i16> %{{.*}}<br>
+  // CHECK: trunc <16 x i16> %{{.*}} to <16 x i8><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}<br>
   return _mm_maskz_adds_epi8(__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_mask_adds_epi8(__m256i __W, __mmask32 __U, __m256i __A,           __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_mask_adds_epi8<br>
-  // CHECK: @llvm.x86.avx2.padds.b<br>
+  // CHECK-NOT: @llvm.x86.avx2.padds.b<br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <32 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <32 x i16> %{{.*}}<br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   // CHECK: select <32 x i1> %{{.*}}, <32 x i8> %{{.*}}, <32 x i8> %{{.*}}<br>
   return _mm256_mask_adds_epi8(__W,__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_maskz_adds_epi8(__mmask32 __U, __m256i __A, __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_maskz_adds_epi8<br>
-  // CHECK: @llvm.x86.avx2.padds.b<br>
+  // CHECK-NOT: @llvm.x86.avx2.padds.b<br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: sext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <32 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: icmp slt <32 x i16> %{{.*}}, <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> <i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128, i16 -128>, <32 x i16> %{{.*}}<br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   // CHECK: select <32 x i1> %{{.*}}, <32 x i8> %{{.*}}, <32 x i8> %{{.*}}<br>
   return _mm256_maskz_adds_epi8(__U,__A,__B); <br>
 }<br>
 __m128i test_mm_mask_adds_epi16(__m128i __W, __mmask8 __U, __m128i __A,         __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_mask_adds_epi16<br>
-  // CHECK: @llvm.x86.sse2.padds.w<br>
+  // CHECK-NOT: @llvm.x86.sse2.padds.w<br>
+  // CHECK: sext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: sext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: add <8 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <8 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> %{{.*}}, <8 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <8 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <8 x i32> %{{.*}}<br>
+  // CHECK: trunc <8 x i32> %{{.*}} to <8 x i16><br>
   // CHECK: select <8 x i1> %{{.*}}, <8 x i16> %{{.*}}, <8 x i16> %{{.*}}<br>
   return _mm_mask_adds_epi16(__W,__U,__A,__B); <br>
 }<br>
 __m128i test_mm_maskz_adds_epi16(__mmask8 __U, __m128i __A, __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_maskz_adds_epi16<br>
-  // CHECK: @llvm.x86.sse2.padds.w<br>
+  // CHECK-NOT: @llvm.x86.sse2.padds.w<br>
+  // CHECK: sext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: sext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: add <8 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <8 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> %{{.*}}, <8 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <8 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <8 x i32> %{{.*}}<br>
+  // CHECK: trunc <8 x i32> %{{.*}} to <8 x i16><br>
   // CHECK: select <8 x i1> %{{.*}}, <8 x i16> %{{.*}}, <8 x i16> %{{.*}}<br>
   return _mm_maskz_adds_epi16(__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_mask_adds_epi16(__m256i __W, __mmask16 __U, __m256i __A,      __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_mask_adds_epi16<br>
-  // CHECK: @llvm.x86.avx2.padds.w<br>
+  // CHECK-NOT: @llvm.x86.avx2.padds.w<br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <16 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <16 x i32> %{{.*}}<br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}}<br>
   return _mm256_mask_adds_epi16(__W,__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_maskz_adds_epi16(__mmask16 __U, __m256i __A, __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_maskz_adds_epi16<br>
-  // CHECK: @llvm.x86.avx2.padds.w<br>
+  // CHECK-NOT: @llvm.x86.avx2.padds.w<br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: sext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i32> %{{.*}}, <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767, i32 32767><br>
+  // CHECK: icmp slt <16 x i32> %{{.*}}, <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> <i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768, i32 -32768>, <16 x i32> %{{.*}}<br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}}<br>
   return _mm256_maskz_adds_epi16(__U,__A,__B); <br>
 }<br>
-__m128i test_mm_mask_adds_epu8(__m128i __W, __mmask16 __U, __m128i __A,        __m128i __B) {<br>
+__m128i test_mm_mask_adds_epu8(__m128i __W, __mmask16 __U, __m128i __A, __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_mask_adds_epu8<br>
-  // CHECK: @llvm.x86.sse2.paddus.b<br>
+  // CHECK-NOT: @llvm.x86.sse2.paddus.b<br>
+  // CHECK: zext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: zext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: add <16 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <16 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <16 x i16> %{{.*}} to <16 x i8><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}<br>
   return _mm_mask_adds_epu8(__W,__U,__A,__B); <br>
 }<br>
 __m128i test_mm_maskz_adds_epu8(__mmask16 __U, __m128i __A, __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_maskz_adds_epu8<br>
-  // CHECK: @llvm.x86.sse2.paddus.b<br>
+  // CHECK-NOT: @llvm.x86.sse2.paddus.b<br>
+  // CHECK: zext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: zext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: add <16 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <16 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <16 x i16> %{{.*}} to <16 x i8><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i8> %{{.*}}, <16 x i8> %{{.*}}<br>
   return _mm_maskz_adds_epu8(__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_mask_adds_epu8(__m256i __W, __mmask32 __U, __m256i __A,           __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_mask_adds_epu8<br>
-  // CHECK: @llvm.x86.avx2.paddus.b<br>
+  // CHECK-NOT: @llvm.x86.avx2.paddus.b<br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   // CHECK: select <32 x i1> %{{.*}}, <32 x i8> %{{.*}}, <32 x i8> %{{.*}}<br>
   return _mm256_mask_adds_epu8(__W,__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_maskz_adds_epu8(__mmask32 __U, __m256i __A, __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_maskz_adds_epu8<br>
-  // CHECK: @llvm.x86.avx2.paddus.b<br>
+  // CHECK-NOT: @llvm.x86.avx2.paddus.b<br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: zext <32 x i8> %{{.*}} to <32 x i16><br>
+  // CHECK: add <32 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <32 x i16> %{{.*}}, <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: select <32 x i1> %{{.*}}, <32 x i16> %{{.*}}, <32 x i16> <i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255, i16 255><br>
+  // CHECK: trunc <32 x i16> %{{.*}} to <32 x i8><br>
   // CHECK: select <32 x i1> %{{.*}}, <32 x i8> %{{.*}}, <32 x i8> %{{.*}}<br>
   return _mm256_maskz_adds_epu8(__U,__A,__B); <br>
 }<br>
 __m128i test_mm_mask_adds_epu16(__m128i __W, __mmask8 __U, __m128i __A,         __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_mask_adds_epu16<br>
-  // CHECK: @llvm.x86.sse2.paddus.w<br>
+  // CHECK-NOT: @llvm.x86.sse2.paddus.w<br>
+  // CHECK: zext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: zext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: add <8 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <8 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> %{{.*}}, <8 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <8 x i32> %{{.*}} to <8 x i16><br>
   // CHECK: select <8 x i1> %{{.*}}, <8 x i16> %{{.*}}, <8 x i16> %{{.*}}<br>
   return _mm_mask_adds_epu16(__W,__U,__A,__B); <br>
 }<br>
 __m128i test_mm_maskz_adds_epu16(__mmask8 __U, __m128i __A, __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_maskz_adds_epu16<br>
-  // CHECK: @llvm.x86.sse2.paddus.w<br>
+  // CHECK-NOT: @llvm.x86.sse2.paddus.w<br>
+  // CHECK: zext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: zext <8 x i16> %{{.*}} to <8 x i32><br>
+  // CHECK: add <8 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <8 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <8 x i1> %{{.*}}, <8 x i32> %{{.*}}, <8 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <8 x i32> %{{.*}} to <8 x i16><br>
   // CHECK: select <8 x i1> %{{.*}}, <8 x i16> %{{.*}}, <8 x i16> %{{.*}}<br>
   return _mm_maskz_adds_epu16(__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_mask_adds_epu16(__m256i __W, __mmask16 __U, __m256i __A,      __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_mask_adds_epu16<br>
-  // CHECK: @llvm.x86.avx2.paddus.w<br>
+  // CHECK-NOT: @llvm.x86.avx2.paddus.w<br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <16 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}}<br>
   return _mm256_mask_adds_epu16(__W,__U,__A,__B); <br>
 }<br>
 __m256i test_mm256_maskz_adds_epu16(__mmask16 __U, __m256i __A, __m256i __B) {<br>
   // CHECK-LABEL: @test_mm256_maskz_adds_epu16<br>
-  // CHECK: @llvm.x86.avx2.paddus.w<br>
+  // CHECK-NOT: @llvm.x86.avx2.paddus.w<br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: zext <16 x i16> %{{.*}} to <16 x i32><br>
+  // CHECK: add <16 x i32> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp ule <16 x i32> %{{.*}}, <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x i32> %{{.*}}, <16 x i32> <i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535, i32 65535><br>
+  // CHECK: trunc <16 x i32> %{{.*}} to <16 x i16><br>
   // CHECK: select <16 x i1> %{{.*}}, <16 x i16> %{{.*}}, <16 x i16> %{{.*}}<br>
   return _mm256_maskz_adds_epu16(__U,__A,__B); <br>
 }<br>
@@ -1519,102 +1633,191 @@ __m256i test_mm256_maskz_shuffle_epi8(__<br>
 }<br>
 __m128i test_mm_mask_subs_epi8(__m128i __W, __mmask16 __U, __m128i __A,        __m128i __B) {<br>
   // CHECK-LABEL: @test_mm_mask_subs_epi8<br>
-  // CHECK: @llvm.x86.sse2.psubs.b<br>
+  // CHECK-NOT: @llvm.x86.sse2.psubs.b<br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: sext <16 x i8> %{{.*}} to <16 x i16><br>
+  // CHECK: sub <16 x i16> %{{.*}}, %{{.*}}<br>
+  // CHECK: icmp sle <16 x i16> %{{.*}}, <i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127, i16 127><br>
+  // CHECK: select <16 x i1> %{{.*}}, <16 x</blockquote></div>