]> granicus.if.org Git - llvm/commit
Merging r338658:
authorHans Wennborg <hans@hanshq.net>
Thu, 2 Aug 2018 08:02:19 +0000 (08:02 +0000)
committerHans Wennborg <hans@hanshq.net>
Thu, 2 Aug 2018 08:02:19 +0000 (08:02 +0000)
commit3332f064d92e1fc660bf96fa71272c5e1cb16156
tree95edbc22e4b38cd92ff4a26cf9d8eb97d960f9f8
parent02181d6d2a3839bf24dbc17c9e8af54040d2f6fe
Merging r338658:
------------------------------------------------------------------------
r338658 | nemanjai | 2018-08-02 02:03:22 +0200 (Thu, 02 Aug 2018) | 13 lines

[PowerPC] Do not round values prior to converting to integer

Adding the FP_ROUND nodes when combining FP_TO_[SU]INT of elements
feeding a BUILD_VECTOR into an FP_TO_[SU]INT of the built vector
loses precision. This patch removes the code that adds these nodes
to true f64 operands. It also adds patterns required to ensure
the code is still vectorized rather than converting individual
elements and inserting into a vector.

Fixes https://bugs.llvm.org/show_bug.cgi?id=38342

Differential Revision: https://reviews.llvm.org/D50121

------------------------------------------------------------------------

git-svn-id: https://llvm.org/svn/llvm-project/llvm/branches/release_70@338678 91177308-0d34-0410-b5e6-96231b3b80d8
lib/Target/PowerPC/PPCISelLowering.cpp
lib/Target/PowerPC/PPCInstrVSX.td
test/CodeGen/PowerPC/build-vector-tests.ll