.
[glibc/history.git] / sysdeps / sh / sh4 / __longjmp.S
blob2fd137bcba8b08f2aaed56e3c234a1381739624b
1 /* longjmp for SH.
2    Copyright (C) 1999, 2000, 2005, 2006, 2009 Free Software Foundation, Inc.
3    This file is part of the GNU C Library.
5    The GNU C Library is free software; you can redistribute it and/or
6    modify it under the terms of the GNU Lesser General Public
7    License as published by the Free Software Foundation; either
8    version 2.1 of the License, or (at your option) any later version.
10    The GNU C Library is distributed in the hope that it will be useful,
11    but WITHOUT ANY WARRANTY; without even the implied warranty of
12    MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
13    Lesser General Public License for more details.
15    You should have received a copy of the GNU Lesser General Public
16    License along with the GNU C Library; if not, write to the Free
17    Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
18    02111-1307 USA.  */
20 #include <sysdep.h>
21 #define _SETJMP_H
22 #define _ASM
23 #include <bits/setjmp.h>
25 /* __longjmp(jmpbuf, val) */
27 ENTRY (__longjmp)
28         mov.l   @r4+, r8
29         mov.l   @r4+, r9
30         mov.l   @r4+, r10
31         mov.l   @r4+, r11
32         mov.l   @r4+, r12
33         mov     r5, r0          /* get the return value in place */
34         tst     r0, r0
35         bf.s    1f
36          mov.l  @r4+, r13
37         mov     #1,r0           /* can't let setjmp() return zero! */
39 #ifdef PTR_DEMANGLE
40         mov.l   @r4+, r2
41         PTR_DEMANGLE (r2, r1)
42         mov     r2, r14
43         mov.l   @r4+, r2
44         PTR_DEMANGLE2 (r2, r1)
45         mov     r2, r15
46         mov.l   @r4+, r2
47         PTR_DEMANGLE2 (r2, r1)
48         lds     r2, pr
49         mov     #0, r1
50 #else
51         mov.l   @r4+, r14
52         mov.l   @r4+, r15
53         lds.l   @r4+, pr
54 #endif
55 #ifdef __SH_FPU_ANY__
56         ldc.l   @r4+, gbr
57         lds.l   @r4+, fpscr
58         fmov.s  @r4+, fr12
59         fmov.s  @r4+, fr13
60         fmov.s  @r4+, fr14
61         rts
62          fmov.s @r4+, fr15
63 #else
64         rts
65          ldc.l  @r4+, gbr
66 #endif  /* !__SH_FPU_ANY__ */
67 END (__longjmp)