There is no need to store callee-saved registers in prologue if the
function would never return. Size optimization is paramount for the
microcontroller-class PRU.
Some backends save some registers for noreturn functions. But for PRU
debuggability is a less concern because GDB has not been ported yet
for PRU.
gcc/ChangeLog:
* config/pru/pru.cc (prologue_saved_reg_p): Skip saving
if function will not return.
gcc/testsuite/ChangeLog:
* gcc.target/pru/noreturn-prologue-1.c: New test.
* gcc.target/pru/noreturn-prologue-2.c: New test.
Signed-off-by: Dimitar Dimitrov <dimitar@dinux.eu>
{
gcc_assert (GP_REG_P (regno));
+ /* Do not save the register if function will not return. */
+ if (TREE_THIS_VOLATILE (current_function_decl))
+ return false;
+
if (df_regs_ever_live_p (regno) && !call_used_or_fixed_reg_p (regno))
return true;
--- /dev/null
+/* Ensure prologues are not generated for noreturn functions. */
+/* { dg-do assemble } */
+/* { dg-options "-Os" } */
+/* { dg-final { object-size text == 0 } } */
+
+void test(void)
+{
+ asm volatile ("# \n\t" : : : "r5", "r10");
+ __builtin_unreachable ();
+}
--- /dev/null
+/* Ensure prologues are not generated for noreturn functions. */
+/* { dg-do assemble } */
+/* { dg-options "-Os" } */
+/* { dg-final { object-size text == 4 } } */
+
+void test(void)
+{
+ asm volatile ("# \n\t" : : : "r0", "r9");
+ for (;;)
+ ;
+}