diff options
author | Jiufu Guo <guojiufu@linux.ibm.com> | 2023-09-28 17:00:04 +0800 |
---|---|---|
committer | guojiufu <guojiufu@linux.ibm.com> | 2023-10-07 15:57:23 +0800 |
commit | 5f56b76ff1c15118200204569389f85cca4e32d3 (patch) | |
tree | 74feeb516abc222dd19f591d893b2b2e4c73b4da /gcc/graphite-optimize-isl.cc | |
parent | a809a556dc0792a34fca7b754ff96ea3ea7d1e7f (diff) | |
download | gcc-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