OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [newlib-1.17.0/] [newlib/] [libc/] [machine/] [i960/] [setjmp.S] - Blame information for rev 148

Go to most recent revision | Details | Compare with Previous | View Log

Line No. Rev Author Line
1 148 jeremybenn
/*******************************************************************************
2
 *
3
 * Copyright (c) 1993 Intel Corporation
4
 *
5
 * Intel hereby grants you permission to copy, modify, and distribute this
6
 * software and its documentation.  Intel grants this permission provided
7
 * that the above copyright notice appears in all copies and that both the
8
 * copyright notice and this permission notice appear in supporting
9
 * documentation.  In addition, Intel grants this permission provided that
10
 * you prominently mark as "not part of the original" any modifications
11
 * made to this software or documentation, and that the name of Intel
12
 * Corporation not be used in advertising or publicity pertaining to
13
 * distribution of the software or the documentation without specific,
14
 * written prior permission.
15
 *
16
 * Intel Corporation provides this AS IS, WITHOUT ANY WARRANTY, EXPRESS OR
17
 * IMPLIED, INCLUDING, WITHOUT LIMITATION, ANY WARRANTY OF MERCHANTABILITY
18
 * OR FITNESS FOR A PARTICULAR PURPOSE.  Intel makes no guarantee or
19
 * representations regarding the use of, or the results of the use of,
20
 * the software and documentation in terms of correctness, accuracy,
21
 * reliability, currentness, or otherwise; and you rely on the software,
22
 * documentation and results solely at your own risk.
23
 *
24
 * IN NO EVENT SHALL INTEL BE LIABLE FOR ANY LOSS OF USE, LOSS OF BUSINESS,
25
 * LOSS OF PROFITS, INDIRECT, INCIDENTAL, SPECIAL OR CONSEQUENTIAL DAMAGES
26
 * OF ANY KIND.  IN NO EVENT SHALL INTEL'S TOTAL LIABILITY EXCEED THE SUM
27
 * PAID TO INTEL FOR THE PRODUCT LICENSED HEREUNDER.
28
 *
29
 ******************************************************************************/
30
 
31
/******************************************************************************/
32
/*                                                                            */
33
/*      setjmp(), longjmp()                                                   */
34
/*                                                                            */
35
/******************************************************************************/
36
        .file "setjmp.as"
37
        .text
38
        /* .link_pix */
39
 
40
        .align  4
41
        .globl  _setjmp
42
_setjmp:
43
        flushreg
44
        andnot  0xf,pfp,g1      /* get pfp, mask out return status bits */
45
        st      g1, 0x58(g0)    /* save fp of caller*/
46
   /* save globals not killed by the calling convention */
47
        stq     g8, 0x40(g0)    /* save g8-g11*/
48
        st      g12, 0x50(g0)   /* save g12*/
49
        st      g14, 0x54(g0)   /* save g14*/
50
   /* save previous frame local registers */
51
        ldq     (g1), g4        /* get previous frame pfp, sp, rip, r3 */
52
        stq     g4, (g0)        /* save pfp, sp, rip, r3 */
53
        ldq     0x10(g1), g4    /* get previous frame r4-r7 */
54
        stq     g4, 0x10(g0)    /* save r4-r7 */
55
        ldq     0x20(g1), g4    /* get previous frame r8-r11 */
56
        stq     g4, 0x20(g0)    /* save r8-r11 */
57
        ldq     0x30(g1), g4    /* get previous frame r12-r15 */
58
        stq     g4, 0x30(g0)    /* save r12-r15 */
59
 
60
        mov     0, g0           /* return 0 */
61
        ret
62
 
63
   /*
64
    * fake a return to the place that called the corresponding _setjmp
65
   */
66
        .align  4
67
        .globl  _longjmp
68
_longjmp:
69
        call    0f              /* ensure there is at least one stack frame */
70
 
71
0:
72
        flushreg                /* do this before swapping stack */
73
        ld      0x58(g0), pfp   /* get fp of caller of setjmp */
74
   /* restore local registers
75
    * the following code modifies the frame of the function which originally
76
    *  called setjmp.
77
    */
78
        ldq     (g0), g4        /* get pfp, sp, rip, r3 */
79
        stq     g4, (pfp)       /* restore pfp, sp, rip, r3 */
80
        ldq     0x10(g0), g4    /* get r4-r7 */
81
        stq     g4, 0x10(pfp)   /* restore r4-r7 */
82
        ldq     0x20(g0), g4    /* get r8-r11 */
83
        stq     g4, 0x20(pfp)   /* restore r8-r11 */
84
        ldq     0x30(g0), g4    /* get r12-r15 */
85
        stq     g4, 0x30(pfp)   /* restore r12-r15 */
86
   /* restore global registers */
87
        ldq     0x40(g0), g8    /* get old g8-g11 values */
88
        ld      0x50(g0), g12   /* get old g12 value */
89
        ld      0x54(g0), g14   /* get old g14 value */
90
 
91
        mov     g1, g0          /* get return value */
92
        cmpo    g0, 0           /* make sure it is not zero */
93
        bne     0f
94
        mov     1, g0           /* return 1 by default */
95
0:
96
        ret                     /* return to caller of _setjmp */

powered by: WebSVN 2.1.0

© copyright 1999-2025 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.