aboutsummaryrefslogtreecommitdiff
path: root/packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch
diff options
context:
space:
mode:
Diffstat (limited to 'packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch')
-rw-r--r--packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch121
1 files changed, 121 insertions, 0 deletions
diff --git a/packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch b/packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch
new file mode 100644
index 00000000..17fc7b64
--- /dev/null
+++ b/packages/gcc/14.2.0/0014-Add-force_lowpart_subreg.patch
@@ -0,0 +1,121 @@
+From 2dcdf9d026ed2e881b0bd8b378ed072e410490fe Mon Sep 17 00:00:00 2001
+From: Richard Sandiford <richard.sandiford@arm.com>
+Date: Tue, 18 Jun 2024 12:22:31 +0100
+Subject: [PATCH 14/16] Add force_lowpart_subreg
+
+optabs had a local function called lowpart_subreg_maybe_copy
+that is very similar to the lowpart version of force_subreg.
+This patch adds a force_lowpart_subreg wrapper around
+force_subreg and uses it in optabs.cc.
+
+The only difference between the old and new functions is that
+the old one asserted success while the new one doesn't.
+It's common not to assert elsewhere when taking subregs;
+normally a null result is enough.
+
+Later patches will make more use of the new function.
+
+gcc/
+ * explow.h (force_lowpart_subreg): Declare.
+ * explow.cc (force_lowpart_subreg): New function.
+ * optabs.cc (lowpart_subreg_maybe_copy): Delete.
+ (expand_absneg_bit): Use force_lowpart_subreg instead of
+ lowpart_subreg_maybe_copy.
+ (expand_copysign_bit): Likewise.
+
+(cherry picked from commit 5f40d1c0cc6ce91ef28d326b8707b3f05e6f239c)
+---
+ gcc/explow.cc | 14 ++++++++++++++
+ gcc/explow.h | 1 +
+ gcc/optabs.cc | 24 ++----------------------
+ 3 files changed, 17 insertions(+), 22 deletions(-)
+
+diff --git a/gcc/explow.cc b/gcc/explow.cc
+index f6843398c4b..5fdfa81f69b 100644
+--- a/gcc/explow.cc
++++ b/gcc/explow.cc
+@@ -760,6 +760,20 @@ force_subreg (machine_mode outermode, rtx op,
+ return simplify_gen_subreg (outermode, op, innermode, byte);
+ }
+
++/* Try to return an rvalue expression for the OUTERMODE lowpart of OP,
++ which has mode INNERMODE. Allow OP to be forced into a new register
++ if necessary.
++
++ Return null on failure. */
++
++rtx
++force_lowpart_subreg (machine_mode outermode, rtx op,
++ machine_mode innermode)
++{
++ auto byte = subreg_lowpart_offset (outermode, innermode);
++ return force_subreg (outermode, op, innermode, byte);
++}
++
+ /* If X is a memory ref, copy its contents to a new temp reg and return
+ that reg. Otherwise, return X. */
+
+diff --git a/gcc/explow.h b/gcc/explow.h
+index cbd1fcb7eb3..dd654649b06 100644
+--- a/gcc/explow.h
++++ b/gcc/explow.h
+@@ -43,6 +43,7 @@ extern rtx copy_to_suggested_reg (rtx, rtx, machine_mode);
+ extern rtx force_reg (machine_mode, rtx);
+
+ extern rtx force_subreg (machine_mode, rtx, machine_mode, poly_uint64);
++extern rtx force_lowpart_subreg (machine_mode, rtx, machine_mode);
+
+ /* Return given rtx, copied into a new temp reg if it was in memory. */
+ extern rtx force_not_mem (rtx);
+diff --git a/gcc/optabs.cc b/gcc/optabs.cc
+index ce91f94ed43..804c0dc73ba 100644
+--- a/gcc/optabs.cc
++++ b/gcc/optabs.cc
+@@ -3096,26 +3096,6 @@ expand_ffs (scalar_int_mode mode, rtx op0, rtx target)
+ return 0;
+ }
+
+-/* Extract the OMODE lowpart from VAL, which has IMODE. Under certain
+- conditions, VAL may already be a SUBREG against which we cannot generate
+- a further SUBREG. In this case, we expect forcing the value into a
+- register will work around the situation. */
+-
+-static rtx
+-lowpart_subreg_maybe_copy (machine_mode omode, rtx val,
+- machine_mode imode)
+-{
+- rtx ret;
+- ret = lowpart_subreg (omode, val, imode);
+- if (ret == NULL)
+- {
+- val = force_reg (imode, val);
+- ret = lowpart_subreg (omode, val, imode);
+- gcc_assert (ret != NULL);
+- }
+- return ret;
+-}
+-
+ /* Expand a floating point absolute value or negation operation via a
+ logical operation on the sign bit. */
+
+@@ -3204,7 +3184,7 @@ expand_absneg_bit (enum rtx_code code, scalar_float_mode mode,
+ gen_lowpart (imode, op0),
+ immed_wide_int_const (mask, imode),
+ gen_lowpart (imode, target), 1, OPTAB_LIB_WIDEN);
+- target = lowpart_subreg_maybe_copy (mode, temp, imode);
++ target = force_lowpart_subreg (mode, temp, imode);
+
+ set_dst_reg_note (get_last_insn (), REG_EQUAL,
+ gen_rtx_fmt_e (code, mode, copy_rtx (op0)),
+@@ -4043,7 +4023,7 @@ expand_copysign_bit (scalar_float_mode mode, rtx op0, rtx op1, rtx target,
+
+ temp = expand_binop (imode, ior_optab, op0, op1,
+ gen_lowpart (imode, target), 1, OPTAB_LIB_WIDEN);
+- target = lowpart_subreg_maybe_copy (mode, temp, imode);
++ target = force_lowpart_subreg (mode, temp, imode);
+ }
+
+ return target;
+--
+2.44.2
+