]> git.ipfire.org Git - thirdparty/gcc.git/commit
rs6000: optimize moving to sf from highpart di
authorJiufu Guo <guojiufu@linux.ibm.com>
Thu, 28 Sep 2023 09:00:04 +0000 (17:00 +0800)
committerguojiufu <guojiufu@linux.ibm.com>
Sat, 7 Oct 2023 07:57:23 +0000 (15:57 +0800)
commit5f56b76ff1c15118200204569389f85cca4e32d3
tree74feeb516abc222dd19f591d893b2b2e4c73b4da
parenta809a556dc0792a34fca7b754ff96ea3ea7d1e7f
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.
gcc/config/rs6000/predicates.md
gcc/config/rs6000/rs6000.md
gcc/testsuite/gcc.target/powerpc/pr108338.c [new file with mode: 0644]