[BACK]Return to setstack.S CVS log [TXT][DIR] Up to [local] / sys / arch / arm / arm

Annotation of sys/arch/arm/arm/setstack.S, Revision 1.1.1.1

1.1       nbrk        1: /*     $OpenBSD: setstack.S,v 1.2 2004/02/01 06:10:33 drahn Exp $      */
                      2: /*     $NetBSD: setstack.S,v 1.2 2002/08/15 01:37:02 briggs Exp $      */
                      3:
                      4: /*
                      5:  * Copyright (c) 1994 Mark Brinicombe.
                      6:  * Copyright (c) 1994 Brini.
                      7:  * All rights reserved.
                      8:  *
                      9:  * This code is derived from software written for Brini by Mark Brinicombe
                     10:  *
                     11:  * Redistribution and use in source and binary forms, with or without
                     12:  * modification, are permitted provided that the following conditions
                     13:  * are met:
                     14:  * 1. Redistributions of source code must retain the above copyright
                     15:  *    notice, this list of conditions and the following disclaimer.
                     16:  * 2. Redistributions in binary form must reproduce the above copyright
                     17:  *    notice, this list of conditions and the following disclaimer in the
                     18:  *    documentation and/or other materials provided with the distribution.
                     19:  * 3. All advertising materials mentioning features or use of this software
                     20:  *    must display the following acknowledgement:
                     21:  *     This product includes software developed by Brini.
                     22:  * 4. The name of the company nor the name of the author may be used to
                     23:  *    endorse or promote products derived from this software without specific
                     24:  *    prior written permission.
                     25:  *
                     26:  * THIS SOFTWARE IS PROVIDED BY BRINI ``AS IS'' AND ANY EXPRESS OR IMPLIED
                     27:  * WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES OF
                     28:  * MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
                     29:  * IN NO EVENT SHALL BRINI OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT,
                     30:  * INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
                     31:  * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR
                     32:  * SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
                     33:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
                     34:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
                     35:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
                     36:  * SUCH DAMAGE.
                     37:  *
                     38:  * RiscBSD kernel project
                     39:  *
                     40:  * setstack.S
                     41:  *
                     42:  * Miscellaneous routine to play with the stack pointer in different CPU modes
                     43:  *
                     44:  * Eventually this routine can be inline assembly.
                     45:  *
                     46:  * Created      : 17/09/94
                     47:  *
                     48:  * Based of kate/display/setstack.s
                     49:  */
                     50:
                     51: #include <machine/cpu.h>
                     52: #include <machine/asm.h>
                     53:
                     54: /* To set the stack pointer for a particular mode we must switch
                     55:  * to that mode update the banked r13 and then switch back.
                     56:  * This routine provides an easy way of doing this for any mode
                     57:  *
                     58:  * r0 = CPU mode
                     59:  * r1 = stackptr
                     60:  */
                     61:
                     62: ENTRY(set_stackptr)
                     63:         mrs    r3, cpsr                /* Switch to the appropriate mode */
                     64:        bic     r2, r3, #(PSR_MODE)
                     65:        orr     r2, r2, r0
                     66:         msr    cpsr_all, r2
                     67:
                     68:        mov     sp, r1                  /* Set the stack pointer */
                     69:
                     70:         msr    cpsr_all, r3            /* Restore the old mode */
                     71:
                     72:        mov     pc, lr                  /* Exit */
                     73:
                     74: /* To get the stack pointer for a particular mode we must switch
                     75:  * to that mode copy the banked r13 and then switch back.
                     76:  * This routine provides an easy way of doing this for any mode
                     77:  *
                     78:  * r0 = CPU mode
                     79:  */
                     80:
                     81: ENTRY(get_stackptr)
                     82:         mrs    r3, cpsr                /* Switch to the appropriate mode */
                     83:        bic     r2, r3, #(PSR_MODE)
                     84:        orr     r2, r2, r0
                     85:         msr    cpsr_all, r2
                     86:
                     87:        mov     r0, sp                  /* Set the stack pointer */
                     88:
                     89:         msr    cpsr_all, r3            /* Restore the old mode */
                     90:
                     91:        mov     pc, lr                  /* Exit */
                     92:
                     93: /* End of setstack.S */

CVSweb