On 2026/05/09 18:58, Max Filippov wrote:

I see that code generated with this change for the call0 ABI
clobbers callee-saved registers.
It seems I misunderstood how `validate_change()` works.

Also, this has raised a new concern, so I will post another patch later.

--- >8 ---
No functional changes.

gcc/ChangeLog:

        * config/xtensa/xtensa.cc
        (xtensa_can_eliminate_callee_saved_reg_p):
        Change the arguments that return values from being passed by pointer
        to C++ reference.
        (xtensa_expand_prologue):
        Adjust the call to xtensa_can_eliminate_callee_saved_reg_p() to
        match the above changes.
---
 gcc/config/xtensa/xtensa.cc | 18 ++++++------------
 1 file changed, 6 insertions(+), 12 deletions(-)

diff --git a/gcc/config/xtensa/xtensa.cc b/gcc/config/xtensa/xtensa.cc
index 212086e4e4c..82c0f38f304 100644
--- a/gcc/config/xtensa/xtensa.cc
+++ b/gcc/config/xtensa/xtensa.cc
@@ -3614,17 +3614,16 @@ xtensa_emit_adjust_stack_ptr (HOST_WIDE_INT offset, int 
flags)
static bool
 xtensa_can_eliminate_callee_saved_reg_p (unsigned int regno,
-                                        rtx_insn **p_insnS,
-                                        rtx_insn **p_insnR)
+                                        rtx_insn *&insnS, rtx_insn *&insnR)
 {
   df_ref ref;
-  rtx_insn *insn, *insnS = NULL, *insnR = NULL;
+  rtx_insn *insn;
   rtx pattern;
if (!optimize || !df || call_used_or_fixed_reg_p (regno))
     return false;
- for (ref = DF_REG_DEF_CHAIN (regno);
+  for (insnS = NULL, ref = DF_REG_DEF_CHAIN (regno);
        ref; ref = DF_REF_NEXT_REG (ref))
     if (DF_REF_CLASS (ref) != DF_REF_REGULAR
        || DEBUG_INSN_P (insn = DF_REF_INSN (ref)))
@@ -3644,7 +3643,7 @@ xtensa_can_eliminate_callee_saved_reg_p (unsigned int 
regno,
     else
       return false;
- for (ref = DF_REG_USE_CHAIN (regno);
+  for (insnR = NULL, ref = DF_REG_USE_CHAIN (regno);
        ref; ref = DF_REF_NEXT_REG (ref))
     if (DF_REF_CLASS (ref) != DF_REF_REGULAR
        || DEBUG_INSN_P (insn = DF_REF_INSN (ref)))
@@ -3664,12 +3663,7 @@ xtensa_can_eliminate_callee_saved_reg_p (unsigned int 
regno,
     else
       return false;
- if (!insnS || !insnR)
-    return false;
-
-  *p_insnS = insnS, *p_insnR = insnR;
-
-  return true;
+  return insnS && insnR;
 }
/* minimum frame = reg save area (4 words) plus static chain (1 word)
@@ -3772,7 +3766,7 @@ xtensa_expand_prologue (void)
if (!large_stack_needed
                && xtensa_can_eliminate_callee_saved_reg_p (regno,
-                                                           &insnS, &insnR))
+                                                           insnS, insnR))
              {
                if (frame_pointer_needed)
                  mem = replace_rtx (mem, stack_pointer_rtx,
--
2.39.5

Reply via email to