aboutsummaryrefslogtreecommitdiff
path: root/gcc/graphite-optimize-isl.cc
diff options
context:
space:
mode:
authorJiufu Guo <guojiufu@linux.ibm.com>2023-09-28 17:00:04 +0800
committerguojiufu <guojiufu@linux.ibm.com>2023-10-07 15:57:23 +0800
commit5f56b76ff1c15118200204569389f85cca4e32d3 (patch)
tree74feeb516abc222dd19f591d893b2b2e4c73b4da /gcc/graphite-optimize-isl.cc
parenta809a556dc0792a34fca7b754ff96ea3ea7d1e7f (diff)
downloadgcc-5f56b76ff1c15118200204569389f85cca4e32d3.zip
gcc-5f56b76ff1c15118200204569389f85cca4e32d3.tar.gz
gcc-5f56b76ff1c15118200204569389f85cca4e32d3.tar.bz2
rs6000: optimize moving to sf from highpart di
Currently, we have the pattern "movsf_from_si2" which was trying to support moving high part DI to SF. But current pattern only accepts "ashiftrt": XX:SF=bitcast:SF(subreg(YY:DI>>32),0), but actually "lshiftrt" should also be ok. And current pattern only supports BE. Here, updating the pattern to support BE and "lshiftrt". PR target/108338 gcc/ChangeLog: * config/rs6000/predicates.md (lowpart_subreg_operator): New define_predicate. * config/rs6000/rs6000.md (any_rshift): New code_iterator. (movsf_from_si2): Rename to ... (movsf_from_si2_<code>): ... this. gcc/testsuite/ChangeLog: * gcc.target/powerpc/pr108338.c: New test.
Diffstat (limited to 'gcc/graphite-optimize-isl.cc')
0 files changed, 0 insertions, 0 deletions