aboutsummaryrefslogtreecommitdiff
path: root/gcc/rtlanal.cc
diff options
context:
space:
mode:
authorJerry DeLisle <jvdelisle@gcc.gnu.org>2025-09-02 15:58:26 -0700
committerJerry DeLisle <jvdelisle@gcc.gnu.org>2025-09-02 15:58:26 -0700
commit071b4126c613881f4cb25b4e5c39032964827f88 (patch)
tree7ed805786566918630d1d617b1ed8f7310f5fd8e /gcc/rtlanal.cc
parent845d23f3ea08ba873197c275a8857eee7edad996 (diff)
parentcaa1c2f42691d68af4d894a5c3e700ecd2dba080 (diff)
downloadgcc-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.cc23
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