summaryrefslogtreecommitdiffstats
path: root/llvm/lib/CodeGen/EarlyIfConversion.cpp
diff options
context:
space:
mode:
authorChandler Carruth <chandlerc@gmail.com>2015-10-01 02:21:34 +0000
committerChandler Carruth <chandlerc@gmail.com>2015-10-01 02:21:34 +0000
commit9143378db0ec22c92a0af0c51fcfbcbfd24c359d (patch)
tree45cb9f2409d47dda6eecdab1e368a3831fbc9c87 /llvm/lib/CodeGen/EarlyIfConversion.cpp
parentf7ed23f744650b7c1bf21c4f8686d618ba415a93 (diff)
downloadbcm5719-llvm-9143378db0ec22c92a0af0c51fcfbcbfd24c359d.tar.gz
bcm5719-llvm-9143378db0ec22c92a0af0c51fcfbcbfd24c359d.zip
Patch over a really horrible bug in our vector builtins that showed up
recently when we started using direct conversion to model sign extension. The __v16qi type we use for SSE v16i8 vectors is defined in terms of 'char' which may or may not be signed! This causes us to generate pmovsx and pmovzx depending on the setting of -funsigned-char. This patch just forms an explicitly signed type and uses that to formulate the sign extension. While this gets the correct behavior (which we now verify with the enhanced test) this is just the tip of the ice berg. Now that I know what to look for, I have found errors of this sort *throughout* our vector code. Fortunately, this is the only specific place where I know of users actively having their code miscompiled by Clang due to this, so I'm keeping the fix for those users minimal and targeted. I'll be sending a proper email for discussion of how to fix these systematically, what the implications are, and just how widely broken this is... From what I can tell, we have never shipped a correct set of builtin headers for x86 when users rely on -funsigned-char. Oops. llvm-svn: 248980
Diffstat (limited to 'llvm/lib/CodeGen/EarlyIfConversion.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud