Merged revisions 7501-7598 via svnmerge from
[cacao.git] / src / vm / jit / powerpc64 / linux / md-abi.h
index 5de4c3d14522dbed1049eb15c4e0526b28009793..f21759fccade4bf5a877ee58168c2188c4ce35ea 100644 (file)
@@ -1,6 +1,6 @@
 /* src/vm/jit/powerpc64/linux/md-abi.h - defines for PowerPC64 Linux ABI
 
-   Copyright (C) 1996-2005, 2006 R. Grafl, A. Krall, C. Kruegel,
+   Copyright (C) 1996-2005, 2006, 2007 R. Grafl, A. Krall, C. Kruegel,
    C. Oates, R. Obermaisser, M. Platter, M. Probst, S. Ring,
    E. Steiner, C. Thalinger, D. Thuernbeck, P. Tomsich, C. Ullrich,
    J. Wenninger, Institut f. Computersprachen - TU Wien
    Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA
    02110-1301, USA.
 
-   Contact: cacao@cacaojvm.org
-
-   Authors: Christian Thalinger
-
-   Changes:
-
-   $Id: md-abi.h 5232 2006-08-11 13:11:44Z tbfg $
+   $Id: md-abi.h 7596 2007-03-28 21:05:53Z twisti $
 
 */
 
@@ -39,7 +33,9 @@
 /* preallocated registers *****************************************************/
 
 /* integer registers */
-  
+
+#define REG_ZERO        0   /* almost always zero (in address caluclation)   */
+#define REG_TOC                 2   /* TOC (see function descriptors ELF ABI)        */
 #define REG_RESULT       3   /* to deliver method results                     */
 
 #define REG_PV          14   /* procedure vector, must be provided by caller  */
 #define REG_SP           1   /* stack pointer                                 */
 #define REG_ZERO         0   /* almost always zero: only in address calc.     */
 
+#define REG_A0           3   /* define some argument registers                */
+#define REG_A1           4
+#define REG_A2           5
+#define REG_A3           6
+
 /* floating point registers */
 
 #define REG_FRESULT      1   /* to deliver floating point method results      */
 #define REG_FTMP2       17   /* temporary floating point register             */
 #define REG_FTMP3        0   /* temporary floating point register             */
 
-#define REG_IFTMP        0   /* temporary integer and floating point register */
+#define REG_IFTMP       16   /* temporary integer and floating point register */
+
+#define REG_FA0          1   /* define some argument registers                */
+#define REG_FA1          2
 
 
 #define INT_REG_CNT     32   /* number of integer registers                   */
-#define INT_SAV_CNT     10   /* number of int callee saved registers          */
+#define INT_SAV_CNT      9   /* number of int callee saved registers          */
 #define INT_ARG_CNT      8   /* number of int argument registers              */
 #define INT_TMP_CNT      7   /* number of integer temporary registers         */
-#define INT_RES_CNT      7   /* number of integer reserved registers          */
+#define INT_RES_CNT      8   /* number of integer reserved registers          */
 
 #define FLT_REG_CNT     32   /* number of float registers                     */
-#define FLT_SAV_CNT     10   /* number of float callee saved registers        */
-#define FLT_ARG_CNT      8   /* number of float argument registers            */
-#define FLT_TMP_CNT     11   /* number of float temporary registers           */
+#define FLT_SAV_CNT     16   /* number of float callee saved registers        */
+#define FLT_ARG_CNT     13   /* number of float argument registers            */
+#define FLT_TMP_CNT      0   /* number of float temporary registers           */
 #define FLT_RES_CNT      3   /* number of float reserved registers            */
 
 #define TRACE_ARGS_NUM   8
 
 #define LA_SIZE         48   /* linkage area size                             */
 #define LA_SIZE_ALIGNED 16   /* linkage area size aligned to 16-byte          */
-#define LA_SIZE_IN_POINTERS    LA_SIZE / SIZEOF_VOID_P   
-
+#define LA_SIZE_IN_POINTERS    (LA_SIZE / SIZEOF_VOID_P)
 #define LA_LR_OFFSET    16   /* link register offset in linkage area          */
+#define PA_SIZE                (PA_SIZE_IN_POINTERS*8) 
+#define PA_SIZE_IN_POINTERS    8 /* linux/ppc64 has a minimun parameter save area size, XXX:darwin? */
 
 /* #define ALIGN_FRAME_SIZE(sp)       (sp) */