[PATCH] D10838: Fix invalid shufflevector operands

Moritz Pflanzer moritz.pflanzer14 at imperial.ac.uk
Mon Jul 27 00:49:48 PDT 2015


mpflanzer updated this revision to Diff 30679.
mpflanzer added a comment.

Added test case that fails for the incorrect code generation


http://reviews.llvm.org/D10838

Files:
  lib/CodeGen/CGExprScalar.cpp
  test/CodeGenOpenCL/vector_shufflevector_valid.cl

Index: test/CodeGenOpenCL/vector_shufflevector_valid.cl
===================================================================
--- /dev/null
+++ test/CodeGenOpenCL/vector_shufflevector_valid.cl
@@ -0,0 +1,7 @@
+// RUN: %clang_cc1 -emit-llvm %s -o %t
+
+typedef unsigned int uint2 __attribute((ext_vector_type(2)));
+
+void vector_shufflevector_valid(void) {
+    (uint2)(((uint2)(0)).s0, 0);
+}
Index: lib/CodeGen/CGExprScalar.cpp
===================================================================
--- lib/CodeGen/CGExprScalar.cpp
+++ lib/CodeGen/CGExprScalar.cpp
@@ -1166,6 +1166,16 @@
   return llvm::ConstantInt::get(I32Ty, Off+MV);
 }
 
+static llvm::Constant *getAsInt32(llvm::ConstantInt *C, llvm::Type *I32Ty) {
+  if (C->getBitWidth() != 32) {
+      assert(llvm::ConstantInt::isValueValidForType(I32Ty,
+                                                    C->getZExtValue()) &&
+             "Index operand too large for shufflevector mask!");
+      return llvm::ConstantInt::get(I32Ty, C->getZExtValue());
+  }
+  return C;
+}
+
 Value *ScalarExprEmitter::VisitInitListExpr(InitListExpr *E) {
   bool Ignore = TestAndClearIgnoreResultAssign();
   (void)Ignore;
@@ -1216,7 +1226,8 @@
           Value *LHS = nullptr, *RHS = nullptr;
           if (CurIdx == 0) {
             // insert into undef -> shuffle (src, undef)
-            Args.push_back(C);
+            // shufflemask must use an i32
+            Args.push_back(getAsInt32(C, CGF.Int32Ty));
             Args.resize(ResElts, llvm::UndefValue::get(CGF.Int32Ty));
 
             LHS = EI->getVectorOperand();


-------------- next part --------------
A non-text attachment was scrubbed...
Name: D10838.30679.patch
Type: text/x-patch
Size: 1578 bytes
Desc: not available
URL: <http://lists.llvm.org/pipermail/cfe-commits/attachments/20150727/181309d3/attachment.bin>


More information about the cfe-commits mailing list