aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorIain Sandoe <iain@sandoe.co.uk>2020-12-11 00:29:42 +0000
committerIain Sandoe <iain@sandoe.co.uk>2021-09-28 20:16:05 +0100
commitb12d6e79899fd27833c53ffc3c973538244f62e1 (patch)
treed4db52cf60ca41b0b56e5611c868809be3702a44
parent45f775f5f813224daed1f2234deacc1c9365009e (diff)
downloadgcc-b12d6e79899fd27833c53ffc3c973538244f62e1.zip
gcc-b12d6e79899fd27833c53ffc3c973538244f62e1.tar.gz
gcc-b12d6e79899fd27833c53ffc3c973538244f62e1.tar.bz2
Darwin, PPC : Fix R13 for PPC64.
We have a somewhat unusual situation in that for PPC64, R13 is both reserved and callee-saved (it is used internally by the pthreads implementation to contain pthread_self). So add R13 to the fixed regs, but also keep it in the callee- saved set. gcc/ChangeLog: * config/rs6000/darwin.h (FIXED_R13): Add for PPC64. (FIRST_SAVED_GP_REGNO): Save from R13 even when it is one of the fixed regs.
-rw-r--r--gcc/config/rs6000/darwin.h5
1 files changed, 4 insertions, 1 deletions
diff --git a/gcc/config/rs6000/darwin.h b/gcc/config/rs6000/darwin.h
index 6abf8e8..120b01f 100644
--- a/gcc/config/rs6000/darwin.h
+++ b/gcc/config/rs6000/darwin.h
@@ -203,7 +203,7 @@
/* Make both r2 and r13 available for allocation. */
#define FIXED_R2 0
-#define FIXED_R13 0
+#define FIXED_R13 TARGET_64BIT
/* Base register for access to local variables of the function. */
@@ -213,6 +213,9 @@
#undef RS6000_PIC_OFFSET_TABLE_REGNUM
#define RS6000_PIC_OFFSET_TABLE_REGNUM 31
+#undef FIRST_SAVED_GP_REGNO
+#define FIRST_SAVED_GP_REGNO 13
+
/* Darwin's stack must remain 16-byte aligned for both 32 and 64 bit
ABIs. */