diff options
author | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2025-09-02 15:58:26 -0700 |
---|---|---|
committer | Jerry DeLisle <jvdelisle@gcc.gnu.org> | 2025-09-02 15:58:26 -0700 |
commit | 071b4126c613881f4cb25b4e5c39032964827f88 (patch) | |
tree | 7ed805786566918630d1d617b1ed8f7310f5fd8e /gcc/rtlanal.cc | |
parent | 845d23f3ea08ba873197c275a8857eee7edad996 (diff) | |
parent | caa1c2f42691d68af4d894a5c3e700ecd2dba080 (diff) | |
download | gcc-devel/gfortran-test.zip gcc-devel/gfortran-test.tar.gz gcc-devel/gfortran-test.tar.bz2 |
Merge branch 'master' into gfortran-testdevel/gfortran-test
Diffstat (limited to 'gcc/rtlanal.cc')
-rw-r--r-- | gcc/rtlanal.cc | 23 |
1 files changed, 22 insertions, 1 deletions
diff --git a/gcc/rtlanal.cc b/gcc/rtlanal.cc index 87332ff..63a1d08 100644 --- a/gcc/rtlanal.cc +++ b/gcc/rtlanal.cc @@ -5740,7 +5740,8 @@ pattern_cost (rtx pat, bool speed) rtx x = XVECEXP (pat, 0, i); if (GET_CODE (x) == SET) { - if (GET_CODE (SET_SRC (x)) == COMPARE) + if (GET_CODE (SET_SRC (x)) == COMPARE + || GET_MODE_CLASS (GET_MODE (SET_DEST (x))) == MODE_CC) { if (comparison) return 0; @@ -6976,6 +6977,26 @@ add_auto_inc_notes (rtx_insn *insn, rtx x) } } +/* Return true if INSN is the second element of a pair of macro-fused + single_sets, both of which having the same register output as another. */ +bool +single_output_fused_pair_p (rtx_insn *insn) +{ + rtx set, prev_set; + rtx_insn *prev; + + return INSN_P (insn) + && SCHED_GROUP_P (insn) + && (prev = prev_nonnote_nondebug_insn (insn)) + && (set = single_set (insn)) != NULL_RTX + && (prev_set = single_set (prev)) + != NULL_RTX + && REG_P (SET_DEST (set)) + && REG_P (SET_DEST (prev_set)) + && (!reload_completed + || REGNO (SET_DEST (set)) == REGNO (SET_DEST (prev_set))); +} + /* Return true if X is register asm. */ bool |