aboutsummaryrefslogtreecommitdiff
path: root/clang/lib/Frontend/InitPreprocessor.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2015-02-12 02:30:56 +0000
committerChandler Carruth <chandlerc@gmail.com>2015-02-12 02:30:56 +0000
commit63aaa98d94afaf7b1fd73d8b50a00ebf7392ba83 (patch)
treed8288b9a1eb3e329608bee955d7d800316dcce10 /clang/lib/Frontend/InitPreprocessor.cpp
parent15b385f8547e6d7236b39e66a8d3a53df5b3f454 (diff)
downloadllvm-63aaa98d94afaf7b1fd73d8b50a00ebf7392ba83.zip
llvm-63aaa98d94afaf7b1fd73d8b50a00ebf7392ba83.tar.gz
llvm-63aaa98d94afaf7b1fd73d8b50a00ebf7392ba83.tar.bz2
[slp] Fix a nasty bug in the SLP vectorizer that Joerg pointed out.
Apparently some code finally started to tickle this after my canonicalization changes to instcombine. The bug stems from trying to form a vector type out of scalars that aren't compatible at all. In this example, from x86_mmx values. The code in the vectorizer that checks for reasonable types whas checking for aggregates or vectors, but there are lots of other types that should just never reach the vectorizer. Debugging this was made more confusing by the lie in an assert in VectorType::get() -- it isn't that the types are *primitive*. The types must be integer, pointer, or floating point types. No other types are allowed. I've improved the assert and added a helper to the vectorizer to handle the element type validity checks. It now re-uses the VectorType static function and then further excludes weird target-specific types that we probably shouldn't be touching here (x86_fp80 and ppc_fp128). Neither of these are really reachable anyways (neither 80-bit nor 128-bit things will get vectorized) but it seems better to just eagerly exclude such nonesense. I've added a test case, but while it definitely covers two of the paths through this code there may be more paths that would benefit from test coverage. I'm not familiar enough with the SLP vectorizer to synthesize test cases for all of these, but was able to update the code itself by inspection. llvm-svn: 228899
Diffstat (limited to 'clang/lib/Frontend/InitPreprocessor.cpp')
0 files changed, 0 insertions, 0 deletions