0001-xtensa-backport-fix-for-PR-target-90922.patch 1.3 KB

12345678910111213141516171819202122232425262728293031323334353637383940414243
  1. From a592242578e573778241cae6d3928c064dcdfda4 Mon Sep 17 00:00:00 2001
  2. From: jcmvbkbc <jcmvbkbc@138bc75d-0d04-0410-961f-82ee72b054a4>
  3. Date: Tue, 18 Jun 2019 22:19:12 +0000
  4. Subject: [PATCH] xtensa: fix for PR target/90922
  5. Stack pointer adjustment code in prologue missed a case of no
  6. callee-saved registers and a stack frame size bigger than 128 bytes.
  7. Handle that case.
  8. This fixes the following gcc tests with call0 ABI:
  9. gcc.c-torture/execute/stdarg-2.c
  10. gcc.dg/torture/pr55882.c
  11. gcc.dg/torture/pr57569.c
  12. gcc/
  13. 2019-06-18 Max Filippov <jcmvbkbc@gmail.com>
  14. * config/xtensa/xtensa.c (xtensa_expand_prologue): Add stack
  15. pointer adjustment for the case of no callee-saved registers and
  16. stack frame bigger than 128 bytes.
  17. Signed-off-by: Max Filippov <jcmvbkbc@gmail.com>
  18. ---
  19. gcc/config/xtensa/xtensa.c | 3 ++-
  20. 1 file changed, 2 insertions(+), 1 deletion(-)
  21. diff --git a/gcc/config/xtensa/xtensa.c b/gcc/config/xtensa/xtensa.c
  22. index 19bd616d67f6..ee5612441e25 100644
  23. --- a/gcc/config/xtensa/xtensa.c
  24. +++ b/gcc/config/xtensa/xtensa.c
  25. @@ -2862,7 +2862,8 @@ xtensa_expand_prologue (void)
  26. gen_rtx_SET (mem, reg));
  27. }
  28. }
  29. - if (total_size > 1024)
  30. + if (total_size > 1024
  31. + || (!callee_save_size && total_size > 128))
  32. {
  33. rtx tmp_reg = gen_rtx_REG (Pmode, A9_REG);
  34. emit_move_insn (tmp_reg, GEN_INT (total_size -
  35. --
  36. 2.11.0