diff options
author | Daniel Sanders <daniel.sanders@imgtec.com> | 2013-09-24 13:33:07 +0000 |
---|---|---|
committer | Daniel Sanders <daniel.sanders@imgtec.com> | 2013-09-24 13:33:07 +0000 |
commit | f49dd82e064b7a8d745adc5938d1229f5cbc39d9 (patch) | |
tree | d64c7e9090eb773d4b1c5edc8445f782a20df8f8 /llvm/lib/Support/ErrorHandling.cpp | |
parent | bfd88f2c7e58d475f5642a277c97d0a65e7d07af (diff) | |
download | bcm5719-llvm-f49dd82e064b7a8d745adc5938d1229f5cbc39d9.tar.gz bcm5719-llvm-f49dd82e064b7a8d745adc5938d1229f5cbc39d9.zip |
[mips][msa] Remove the VSPLAT and VSPLATD nodes in favour of matching BUILD_VECTOR.
Most constant BUILD_VECTOR's are matched using ComplexPatterns which cover
bitcasted as well as normal vectors. However, it doesn't seem to be possible to
match ldi.[bhwd] in a type-agnostic manner (e.g. to support the widest range of
immediates, it should be possible to use ldi.b to load v2i64) using TableGen so
ldi.[bhwd] is matched using custom code in MipsSEISelDAGToDAG.cpp
This made the majority of the constant splat BUILD_VECTOR lowering redundant.
The only transformation remaining for constant splats is when an (up-to) 32-bit
constant splat is possible but the value does not fit into a 10-bit signed
integer. In this case, the BUILD_VECTOR is transformed into a bitcasted
BUILD_VECTOR so that fill.[bhw] can be used to splat the vector from a GPR32
register (which is initialized using the usual lui/addui sequence).
There are no additional tests since this is a re-implementation of previous
functionality. The change is intended to make it easier to implement some of
the upcoming instruction selection patches since they can rely on existing
support for BUILD_VECTOR's in the DAGCombiner.
compare_float.ll changed slightly because a BITCAST is no longer
introduced during legalization.
llvm-svn: 191299
Diffstat (limited to 'llvm/lib/Support/ErrorHandling.cpp')
0 files changed, 0 insertions, 0 deletions