xref: /OK3568_Linux_fs/u-boot/examples/standalone/ppc_setjmp.S (revision 4882a59341e53eb6f0b4789bf948001014eff981)
1*4882a593Smuzhiyun/* setjmp for PowerPC.
2*4882a593Smuzhiyun   Copyright (C) 1995, 1996, 1997, 1999, 2000 Free Software Foundation, Inc.
3*4882a593Smuzhiyun   This file is part of the GNU C Library.
4*4882a593Smuzhiyun
5*4882a593Smuzhiyun * SPDX-License-Identifier:	LGPL-2.1+
6*4882a593Smuzhiyun */
7*4882a593Smuzhiyun
8*4882a593Smuzhiyun#include <ppc_asm.tmpl>
9*4882a593Smuzhiyun
10*4882a593Smuzhiyun# define JB_GPR1   0  /* Also known as the stack pointer */
11*4882a593Smuzhiyun# define JB_GPR2   1
12*4882a593Smuzhiyun# define JB_LR     2  /* The address we will return to */
13*4882a593Smuzhiyun# define JB_GPRS   3  /* GPRs 14 through 31 are saved, 18 in total */
14*4882a593Smuzhiyun# define JB_CR     21 /* Condition code registers. */
15*4882a593Smuzhiyun# define JB_FPRS   22 /* FPRs 14 through 31 are saved, 18*2 words total */
16*4882a593Smuzhiyun# define JB_SIZE   (58*4)
17*4882a593Smuzhiyun
18*4882a593Smuzhiyun#define FP(x...) x
19*4882a593Smuzhiyun
20*4882a593Smuzhiyun.globl      setctxsp;
21*4882a593Smuzhiyunsetctxsp:
22*4882a593Smuzhiyun	mr  r1, r3
23*4882a593Smuzhiyun	blr
24*4882a593Smuzhiyun
25*4882a593Smuzhiyun.globl      ppc_setjmp;
26*4882a593Smuzhiyunppc_setjmp:
27*4882a593Smuzhiyun	stw  r1,(JB_GPR1*4)(3)
28*4882a593Smuzhiyun	mflr r0
29*4882a593Smuzhiyun	stw  r2,(JB_GPR2*4)(3)
30*4882a593Smuzhiyun	stw  r14,((JB_GPRS+0)*4)(3)
31*4882a593SmuzhiyunFP(	stfd 14,((JB_FPRS+0*2)*4)(3))
32*4882a593Smuzhiyun	stw  r0,(JB_LR*4)(3)
33*4882a593Smuzhiyun	stw  r15,((JB_GPRS+1)*4)(3)
34*4882a593SmuzhiyunFP(	stfd 15,((JB_FPRS+1*2)*4)(3))
35*4882a593Smuzhiyun	mfcr r0
36*4882a593Smuzhiyun	stw  r16,((JB_GPRS+2)*4)(3)
37*4882a593SmuzhiyunFP(	stfd 16,((JB_FPRS+2*2)*4)(3))
38*4882a593Smuzhiyun	stw  r0,(JB_CR*4)(3)
39*4882a593Smuzhiyun	stw  r17,((JB_GPRS+3)*4)(3)
40*4882a593SmuzhiyunFP(	stfd 17,((JB_FPRS+3*2)*4)(3))
41*4882a593Smuzhiyun	stw  r18,((JB_GPRS+4)*4)(3)
42*4882a593SmuzhiyunFP(	stfd 18,((JB_FPRS+4*2)*4)(3))
43*4882a593Smuzhiyun	stw  r19,((JB_GPRS+5)*4)(3)
44*4882a593SmuzhiyunFP(	stfd 19,((JB_FPRS+5*2)*4)(3))
45*4882a593Smuzhiyun	stw  r20,((JB_GPRS+6)*4)(3)
46*4882a593SmuzhiyunFP(	stfd 20,((JB_FPRS+6*2)*4)(3))
47*4882a593Smuzhiyun	stw  r21,((JB_GPRS+7)*4)(3)
48*4882a593SmuzhiyunFP(	stfd 21,((JB_FPRS+7*2)*4)(3))
49*4882a593Smuzhiyun	stw  r22,((JB_GPRS+8)*4)(3)
50*4882a593SmuzhiyunFP(	stfd 22,((JB_FPRS+8*2)*4)(3))
51*4882a593Smuzhiyun	stw  r23,((JB_GPRS+9)*4)(3)
52*4882a593SmuzhiyunFP(	stfd 23,((JB_FPRS+9*2)*4)(3))
53*4882a593Smuzhiyun	stw  r24,((JB_GPRS+10)*4)(3)
54*4882a593SmuzhiyunFP(	stfd 24,((JB_FPRS+10*2)*4)(3))
55*4882a593Smuzhiyun	stw  r25,((JB_GPRS+11)*4)(3)
56*4882a593SmuzhiyunFP(	stfd 25,((JB_FPRS+11*2)*4)(3))
57*4882a593Smuzhiyun	stw  r26,((JB_GPRS+12)*4)(3)
58*4882a593SmuzhiyunFP(	stfd 26,((JB_FPRS+12*2)*4)(3))
59*4882a593Smuzhiyun	stw  r27,((JB_GPRS+13)*4)(3)
60*4882a593SmuzhiyunFP(	stfd 27,((JB_FPRS+13*2)*4)(3))
61*4882a593Smuzhiyun	stw  r28,((JB_GPRS+14)*4)(3)
62*4882a593SmuzhiyunFP(	stfd 28,((JB_FPRS+14*2)*4)(3))
63*4882a593Smuzhiyun	stw  r29,((JB_GPRS+15)*4)(3)
64*4882a593SmuzhiyunFP(	stfd 29,((JB_FPRS+15*2)*4)(3))
65*4882a593Smuzhiyun	stw  r30,((JB_GPRS+16)*4)(3)
66*4882a593SmuzhiyunFP(	stfd 30,((JB_FPRS+16*2)*4)(3))
67*4882a593Smuzhiyun	stw  r31,((JB_GPRS+17)*4)(3)
68*4882a593SmuzhiyunFP(	stfd 31,((JB_FPRS+17*2)*4)(3))
69*4882a593Smuzhiyun
70*4882a593Smuzhiyun	li 3, 0
71*4882a593Smuzhiyun	blr
72