Am 12.01.25 um 13:54 schrieb Denis Chertykov:
вс, 12 янв. 2025 г. в 15:38, Georg-Johann Lay <a...@gjlay.de>:
Am 11.01.25 um 19:15 schrieb Denis Chertykov:
The fix for PR117868.
[...]
PR rtl-optimization/117868
gcc/
* lra-spills.cc (assign_stack_slot_num_and_sort_pseudos): Reuse slots
only without allocated memory or only with equal or smaller registers
with equal or smaller alignment.
(lra_spill): Print slot size as width.
diff --git a/gcc/lra-spills.cc b/gcc/lra-spills.cc
index db78dcd28a3..93a0c92db9f 100644
--- a/gcc/lra-spills.cc
+++ b/gcc/lra-spills.cc
@@ -386,7 +386,18 @@ assign_stack_slot_num_and_sort_pseudos (int
*pseudo_regnos, int n)
&& ! (lra_intersected_live_ranges_p
(slots[j].live_ranges,
lra_reg_info[regno].live_ranges)))
- break;
+ {
+ /* A slot without allocated memory can be shared. */
+ if (slots[j].mem == NULL_RTX)
+ break;
+
+ /* A slot with allocated memory can be shared only with equal
+ or smaller register with equal or smaller alignment. */
+ if (slots[j].align >= spill_slot_alignment (mode)
+ && compare_sizes_for_sort (slots[j].size,
+ GET_MODE_SIZE (mode)) != -1)
+ break;
+ }
}
if (j >= slots_num)
{
@@ -656,8 +667,7 @@ lra_spill (void)
for (i = 0; i < slots_num; i++)
{
fprintf (lra_dump_file, " Slot %d regnos (width = ", i);
- print_dec (GET_MODE_SIZE (GET_MODE (slots[i].mem)),
- lra_dump_file, SIGNED);
+ print_dec (slots[i].size, lra_dump_file, SIGNED);
fprintf (lra_dump_file, "):");
for (curr_regno = slots[i].regno;;
curr_regno = pseudo_slots[curr_regno].next - pseudo_slots)
Trying to apply this, I am getting:
.../gcc$ patch -p2 < ~/gnu/patches/pr117868.diff
patching file lra-spills.cc
Hunk #1 FAILED at 386.
Hunk #2 FAILED at 656.
2 out of 2 hunks FAILED -- saving rejects to file lra-spills.cc.rej
Maybe it's because in the mail TABs have been replaced by spaces?
Maybe.
Regenerated against the updated git tree in the attachment.
Denis.
PS: I'm using Thunderbird for sending emails with patches.
According to this guide:
https://www.kernel.org/doc/html/v4.14/process/email-clients.html
Maybe you can suggest a better method ?
Thank you, attaching the patch did the trick.
Johann