Skip site navigation (1)Skip section navigation (2)
Date:      Sat, 1 Aug 2009 15:40:22 +0000 (UTC)
From:      Nathan Whitehorn <nwhitehorn@FreeBSD.org>
To:        src-committers@freebsd.org, svn-src-projects@freebsd.org
Subject:   svn commit: r196018 - projects/ppc64/sys/powerpc/powerpc
Message-ID:  <200908011540.n71FeMcu085497@svn.freebsd.org>

next in thread | raw e-mail | index | archive | help
Author: nwhitehorn
Date: Sat Aug  1 15:40:22 2009
New Revision: 196018
URL: http://svn.freebsd.org/changeset/base/196018

Log:
  Update setjmp.S to handle both the 32-bit and 64-bit case.

Modified:
  projects/ppc64/sys/powerpc/powerpc/setjmp.S

Modified: projects/ppc64/sys/powerpc/powerpc/setjmp.S
==============================================================================
--- projects/ppc64/sys/powerpc/powerpc/setjmp.S	Sat Aug  1 14:06:56 2009	(r196017)
+++ projects/ppc64/sys/powerpc/powerpc/setjmp.S	Sat Aug  1 15:40:22 2009	(r196018)
@@ -6,61 +6,73 @@
 
 #include <machine/asm.h>
 
-#define JMP_r1	0x04
-#define JMP_r14	0x08
-#define JMP_r15	0x0c
-#define JMP_r16	0x10
-#define JMP_r17	0x14
-#define JMP_r18	0x18
-#define JMP_r19	0x1c
-#define JMP_r20	0x20
-#define JMP_r21	0x24
-#define JMP_r22	0x28
-#define JMP_r23	0x2c
-#define JMP_r24	0x30
-#define JMP_r25	0x34
-#define JMP_r26	0x38
-#define JMP_r27	0x3c
-#define JMP_r28	0x40
-#define JMP_r29	0x44
-#define JMP_r30	0x48
-#define JMP_r31	0x4c
-#define JMP_lr  0x50
-#define JMP_cr  0x54
-#define JMP_ctr	0x58
-#define JMP_xer	0x5c
-#define JMP_sig	0x60
+#ifdef __powerpc64__
+#define LD_REG	ld
+#define	ST_REG	std
+#define	REGWIDTH 8
+#else
+#define	LD_REG	lwz
+#define	ST_REG	stw
+#define	REGWIDTH 4
+#endif
+
+#define JMP_r1	1*REGWIDTH
+#define JMP_r2	2*REGWIDTH
+#define JMP_r14	3*REGWIDTH
+#define JMP_r15 4*REGWIDTH
+#define JMP_r16 5*REGWIDTH
+#define JMP_r17 6*REGWIDTH
+#define JMP_r18 7*REGWIDTH
+#define JMP_r19 8*REGWIDTH
+#define JMP_r20 9*REGWIDTH
+#define JMP_r21 10*REGWIDTH
+#define JMP_r22 11*REGWIDTH
+#define JMP_r23 12*REGWIDTH
+#define JMP_r24 13*REGWIDTH
+#define JMP_r25 14*REGWIDTH
+#define JMP_r26 15*REGWIDTH
+#define JMP_r27 16*REGWIDTH
+#define JMP_r28 17*REGWIDTH
+#define JMP_r29 18*REGWIDTH
+#define JMP_r30 19*REGWIDTH
+#define JMP_r31 20*REGWIDTH
+#define JMP_lr 	21*REGWIDTH
+#define JMP_cr	22*REGWIDTH
+#define JMP_ctr	23*REGWIDTH
+#define JMP_xer	24*REGWIDTH
+#define JMP_sig	25*REGWIDTH
 
 ASENTRY(setjmp)
-	stw 31, JMP_r31(3)
-	/* r1, r14-r30 */
-	stw 1,  JMP_r1 (3)
-	stw 14, JMP_r14(3)
-	stw 15, JMP_r15(3)
-	stw 16, JMP_r16(3)
-	stw 17, JMP_r17(3)
-	stw 18, JMP_r18(3)
-	stw 19, JMP_r19(3)
-	stw 20, JMP_r20(3)
-	stw 21, JMP_r21(3)
-	stw 22, JMP_r22(3)
-	stw 23, JMP_r23(3)
-	stw 24, JMP_r24(3)
-	stw 25, JMP_r25(3)
-	stw 26, JMP_r26(3)
-	stw 27, JMP_r27(3)
-	stw 28, JMP_r28(3)
-	stw 29, JMP_r29(3)
-	stw 30, JMP_r30(3)
+	ST_REG 31, JMP_r31(3)
+	/* r1, r2, r14-r30 */
+	ST_REG 1,  JMP_r1 (3)
+	ST_REG 2,  JMP_r2 (3)
+	ST_REG 14, JMP_r14(3)
+	ST_REG 15, JMP_r15(3)
+	ST_REG 16, JMP_r16(3)
+	ST_REG 17, JMP_r17(3)
+	ST_REG 18, JMP_r18(3)
+	ST_REG 19, JMP_r19(3)
+	ST_REG 20, JMP_r20(3)
+	ST_REG 21, JMP_r21(3)
+	ST_REG 22, JMP_r22(3)
+	ST_REG 23, JMP_r23(3)
+	ST_REG 24, JMP_r24(3)
+	ST_REG 25, JMP_r25(3)
+	ST_REG 26, JMP_r26(3)
+	ST_REG 27, JMP_r27(3)
+	ST_REG 28, JMP_r28(3)
+	ST_REG 29, JMP_r29(3)
+	ST_REG 30, JMP_r30(3)
 	/* cr, lr, ctr, xer */
 	mfcr 0
-	stw 0, JMP_cr(3)
+	ST_REG 0, JMP_cr(3)
 	mflr 0
-	stw 0, JMP_lr(3)
+	ST_REG 0, JMP_lr(3)
 	mfctr 0
-	stw 0, JMP_ctr(3)
+	ST_REG 0, JMP_ctr(3)
 	mfxer 0
-	stw 0, JMP_xer(3)
+	ST_REG 0, JMP_xer(3)
 	/* f14-f31, fpscr */
 	li 3, 0
 	blr
@@ -68,34 +80,35 @@ ASENTRY(setjmp)
 
 .extern sigsetmask
 ASENTRY(longjmp)
-	lwz 31, JMP_r31(3)
-	/* r1, r14-r30 */
-	lwz 1,  JMP_r1 (3)
-	lwz 14, JMP_r14(3)
-	lwz 15, JMP_r15(3)
-	lwz 16, JMP_r16(3)
-	lwz 17, JMP_r17(3)
-	lwz 18, JMP_r18(3)
-	lwz 19, JMP_r19(3)
-	lwz 20, JMP_r20(3)
-	lwz 21, JMP_r21(3)
-	lwz 22, JMP_r22(3)
-	lwz 23, JMP_r23(3)
-	lwz 24, JMP_r24(3)
-	lwz 25, JMP_r25(3)
-	lwz 26, JMP_r26(3)
-	lwz 27, JMP_r27(3)
-	lwz 28, JMP_r28(3)
-	lwz 29, JMP_r29(3)
-	lwz 30, JMP_r30(3)
+	LD_REG 31, JMP_r31(3)
+	/* r1, r2, r14-r30 */
+	LD_REG 1,  JMP_r1 (3)
+	LD_REG 2,  JMP_r2 (3)
+	LD_REG 14, JMP_r14(3)
+	LD_REG 15, JMP_r15(3)
+	LD_REG 16, JMP_r16(3)
+	LD_REG 17, JMP_r17(3)
+	LD_REG 18, JMP_r18(3)
+	LD_REG 19, JMP_r19(3)
+	LD_REG 20, JMP_r20(3)
+	LD_REG 21, JMP_r21(3)
+	LD_REG 22, JMP_r22(3)
+	LD_REG 23, JMP_r23(3)
+	LD_REG 24, JMP_r24(3)
+	LD_REG 25, JMP_r25(3)
+	LD_REG 26, JMP_r26(3)
+	LD_REG 27, JMP_r27(3)
+	LD_REG 28, JMP_r28(3)
+	LD_REG 29, JMP_r29(3)
+	LD_REG 30, JMP_r30(3)
 	/* cr, lr, ctr, xer */
-	lwz 0, JMP_cr(3)
+	LD_REG 0, JMP_cr(3)
 	mtcr 0
-	lwz 0, JMP_lr(3)
+	LD_REG 0, JMP_lr(3)
 	mtlr 0
-	lwz 0, JMP_ctr(3)
+	LD_REG 0, JMP_ctr(3)
 	mtctr 0
-	lwz 0, JMP_xer(3)
+	LD_REG 0, JMP_xer(3)
 	mtxer 0
 	/* f14-f31, fpscr */
 	mr 3, 4



Want to link to this message? Use this URL: <https://mail-archive.FreeBSD.org/cgi/mid.cgi?200908011540.n71FeMcu085497>