summaryrefslogtreecommitdiffstats
path: root/llvm/unittests/CodeGen/ScalableVectorMVTsTest.cpp
diff options
context:
space:
mode:
authorPetar Jovanovic <petar.jovanovic@imgtec.com>2017-04-20 13:26:46 +0000
committerPetar Jovanovic <petar.jovanovic@imgtec.com>2017-04-20 13:26:46 +0000
commit2b6fe3ffa62dec78afda4bd7a6750c103a5bf0f4 (patch)
tree394f1ae20d3515fed8771d444d39b67c33b42489 /llvm/unittests/CodeGen/ScalableVectorMVTsTest.cpp
parent505478205289c10eb63bf1f815e3bcf4bb64f13e (diff)
downloadbcm5719-llvm-2b6fe3ffa62dec78afda4bd7a6750c103a5bf0f4.tar.gz
bcm5719-llvm-2b6fe3ffa62dec78afda4bd7a6750c103a5bf0f4.zip
[mips][msa] Mask vectors holding shift amounts
Masked vectors which hold shift amounts when creating the following nodes: ISD::SHL, ISD::SRL or ISD::SRA. Instructions that use said nodes, which have had their arguments altered are sll, srl, sra, bneg, bclr and bset. For said instructions, the shift amount or the bit position that is specified in the corresponding vector elements will be interpreted as the shift amount/bit position modulo the size of the element in bits. The problem lies in compiling with -O2 enabled, where the instructions for formats .w and .d are not generated, but are instead optimized away. In this case, having shift amounts that are either negative or greater than the element bit size results in generation of incorrect results when constant folding. We remedy this by masking the operands for the nodes mentioned above before actually creating them, so that the final result is correct before placed into the constant pool. Patch by Stefan Maksimovic. Differential Revision: https://reviews.llvm.org/D31331 llvm-svn: 300839
Diffstat (limited to 'llvm/unittests/CodeGen/ScalableVectorMVTsTest.cpp')
0 files changed, 0 insertions, 0 deletions
OpenPOWER on IntegriCloud