diff options
| author | Simon Pilgrim <llvm-dev@redking.me.uk> | 2015-08-02 15:28:10 +0000 |
|---|---|---|
| committer | Simon Pilgrim <llvm-dev@redking.me.uk> | 2015-08-02 15:28:10 +0000 |
| commit | 4034b9f0b932c7e8c47a18fe1ef7d43e273e2913 (patch) | |
| tree | 1950dc3e2b31fe83f60f6b4ffbf718623fb013c5 /clang/test | |
| parent | 87368fdd3064ac1ec5bedc8461b470af374e0534 (diff) | |
| download | bcm5719-llvm-4034b9f0b932c7e8c47a18fe1ef7d43e273e2913.tar.gz bcm5719-llvm-4034b9f0b932c7e8c47a18fe1ef7d43e273e2913.zip | |
Fix invalid shufflevector operands
This patch fixes bug 23800 ( https://llvm.org/bugs/show_bug.cgi?id=23800#c2 ). There existed a case where the index operand from extractelement was directly used to create a shufflevector mask. Since the index can be of any integral type but the mask must only contain 32 bit integers a 64 bit index operand led to an assertion error later on.
Committed on behalf of mpflanzer (Moritz Pflanzer)
Differential Revision: http://reviews.llvm.org/D10838
llvm-svn: 243851
Diffstat (limited to 'clang/test')
| -rw-r--r-- | clang/test/CodeGenOpenCL/vector_shufflevector_valid.cl | 13 |
1 files changed, 13 insertions, 0 deletions
diff --git a/clang/test/CodeGenOpenCL/vector_shufflevector_valid.cl b/clang/test/CodeGenOpenCL/vector_shufflevector_valid.cl new file mode 100644 index 00000000000..0953c66f58e --- /dev/null +++ b/clang/test/CodeGenOpenCL/vector_shufflevector_valid.cl @@ -0,0 +1,13 @@ +// RUN: %clang_cc1 -emit-llvm -O0 %s -o - | FileCheck %s + +// The shuffle vector mask must always be of i32 vector type +// See http://reviews.llvm.org/D10838 and https://llvm.org/bugs/show_bug.cgi?id=23800#c2 +// for more information about a bug where a 64 bit index operand causes the generation +// of an invalid mask + +typedef unsigned int uint2 __attribute((ext_vector_type(2))); + +void vector_shufflevector_valid(void) { + //CHECK: {{%.*}} = shufflevector <2 x i32> {{%.*}}, <2 x i32> undef, <2 x i32> <i32 0, i32 undef> + (uint2)(((uint2)(0)).s0, 0); +} |

