[BACK]Return to asm.h CVS log [TXT][DIR] Up to [local] / sys / arch / sh / include

Annotation of sys/arch/sh/include/asm.h, Revision 1.1

1.1     ! nbrk        1: /*     $OpenBSD: asm.h,v 1.1.1.1 2006/10/06 21:02:55 miod Exp $        */
        !             2: /*     $NetBSD: asm.h,v 1.25 2006/01/20 22:02:40 christos Exp $        */
        !             3:
        !             4: /*-
        !             5:  * Copyright (c) 1990 The Regents of the University of California.
        !             6:  * All rights reserved.
        !             7:  *
        !             8:  * This code is derived from software contributed to Berkeley by
        !             9:  * William Jolitz.
        !            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. Neither the name of the University nor the names of its contributors
        !            20:  *    may be used to endorse or promote products derived from this software
        !            21:  *    without specific prior written permission.
        !            22:  *
        !            23:  * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
        !            24:  * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
        !            25:  * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
        !            26:  * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
        !            27:  * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
        !            28:  * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
        !            29:  * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
        !            30:  * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
        !            31:  * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
        !            32:  * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
        !            33:  * SUCH DAMAGE.
        !            34:  *
        !            35:  *     @(#)asm.h       5.5 (Berkeley) 5/7/91
        !            36:  */
        !            37:
        !            38: #ifndef _SH_ASM_H_
        !            39: #define        _SH_ASM_H_
        !            40:
        !            41: #ifdef __ELF__
        !            42: # define _C_LABEL(x)   x
        !            43: #else
        !            44: #ifdef __STDC__
        !            45: # define _C_LABEL(x)   _ ## x
        !            46: #else
        !            47: # define _C_LABEL(x)   _/**/x
        !            48: #endif
        !            49: #endif
        !            50: #define        _ASM_LABEL(x)   x
        !            51:
        !            52: #ifdef __STDC__
        !            53: # define __CONCAT(x,y) x ## y
        !            54: # define __STRING(x)   #x
        !            55: #else
        !            56: # define __CONCAT(x,y) x/**/y
        !            57: # define __STRING(x)   "x"
        !            58: #endif
        !            59:
        !            60: /* let kernels and others override entrypoint alignment */
        !            61: #ifndef _ALIGN_TEXT
        !            62: # define _ALIGN_TEXT .align 2
        !            63: #endif
        !            64:
        !            65: #ifdef __ELF__
        !            66: #define        _ENTRY(x)                                                       \
        !            67:        .text                                                           ;\
        !            68:        _ALIGN_TEXT                                                     ;\
        !            69:        .globl x                                                        ;\
        !            70:        .type x,@function                                               ;\
        !            71:        x:
        !            72: #else /* !__ELF__ */
        !            73: #define        _ENTRY(x)                                                       \
        !            74:        .text                                                           ;\
        !            75:        _ALIGN_TEXT                                                     ;\
        !            76:        .globl x                                                        ;\
        !            77:        x:
        !            78: #endif /* !__ELF__ */
        !            79:
        !            80: #ifdef GPROF
        !            81: #define        _PROF_PROLOGUE                            \
        !            82:        mov.l   1f,r1                           ; \
        !            83:        mova    2f,r0                           ; \
        !            84:        jmp     @r1                             ; \
        !            85:         nop                                    ; \
        !            86:        .align  2                               ; \
        !            87: 1:     .long   __mcount                        ; \
        !            88: 2:
        !            89: #else  /* !GPROF */
        !            90: #define        _PROF_PROLOGUE
        !            91: #endif /* !GPROF */
        !            92:
        !            93: #define        ENTRY(y)        _ENTRY(_C_LABEL(y)) _PROF_PROLOGUE
        !            94: #define        NENTRY(y)       _ENTRY(_C_LABEL(y))
        !            95: #define        ASENTRY(y)      _ENTRY(_ASM_LABEL(y)) _PROF_PROLOGUE
        !            96:
        !            97: #define SET_ENTRY_SIZE(y) \
        !            98:        .size   _C_LABEL(y), . - _C_LABEL(y)
        !            99:
        !           100: #define SET_ASENTRY_SIZE(y) \
        !           101:        .size   _ASM_LABEL(y), . - _ASM_LABEL(y)
        !           102:
        !           103: #ifdef __ELF__
        !           104: #define        ALTENTRY(name)                           \
        !           105:        .globl _C_LABEL(name)                   ;\
        !           106:        .type _C_LABEL(name),@function          ;\
        !           107:        _C_LABEL(name):
        !           108: #else
        !           109: #define        ALTENTRY(name)                           \
        !           110:        .globl _C_LABEL(name)                   ;\
        !           111:        _C_LABEL(name):
        !           112: #endif
        !           113:
        !           114:
        !           115: /*
        !           116:  * Hide the gory details of PIC calls vs. normal calls.  Use as in the
        !           117:  * following example:
        !           118:  *
        !           119:  *     sts.l   pr, @-sp
        !           120:  *     PIC_PROLOGUE(.L_got, r0)        ! saves old r12 on stack
        !           121:  *     ...
        !           122:  *     mov.l   .L_function_1, r0
        !           123:  * 1:  CALL    r0                      ! each call site needs a label
        !           124:  *      nop
        !           125:  *      ...
        !           126:  *     mov.l   .L_function_2, r0
        !           127:  * 2:  CALL    r0
        !           128:  *      nop
        !           129:  *     ...
        !           130:  *     PIC_EPILOGUE                    ! restores r12 from stack
        !           131:  *     lds.l   @sp+, pr                !  so call in right order
        !           132:  *     rts
        !           133:  *      nop
        !           134:  *
        !           135:  *     .align 2
        !           136:  * .L_got:
        !           137:  *     PIC_GOT_DATUM
        !           138:  * .L_function_1:                      ! if you call the same function twice
        !           139:  *     CALL_DATUM(function, 1b)        !  provide call datum for each call
        !           140:  * .L_function_2:
        !           141:  *     CALL_DATUM(function, 2b)
        !           142:  */
        !           143:
        !           144: #ifdef PIC
        !           145:
        !           146: #define        PIC_PLT(x)      x@PLT
        !           147: #define        PIC_GOT(x)      x@GOT
        !           148: #define        PIC_GOTOFF(x)   x@GOTOFF
        !           149:
        !           150: #define        PIC_PROLOGUE(got)                       \
        !           151:                mov.l   r12, @-sp;              \
        !           152:                PIC_PROLOGUE_NOSAVE(got)
        !           153:
        !           154: /*
        !           155:  * Functions that do non local jumps don't need to preserve r12,
        !           156:  * so we can shave off two instructions to save/restore it.
        !           157:  */
        !           158: #define        PIC_PROLOGUE_NOSAVE(got)                \
        !           159:                mov.l   got, r12;               \
        !           160:                mova    got, r0;                \
        !           161:                add     r0, r12
        !           162:
        !           163: #define        PIC_EPILOGUE                            \
        !           164:                mov.l   @sp+, r12
        !           165:
        !           166: #define PIC_EPILOGUE_SLOT                      \
        !           167:                PIC_EPILOGUE
        !           168:
        !           169: #define PIC_GOT_DATUM \
        !           170:                .long   _GLOBAL_OFFSET_TABLE_
        !           171:
        !           172: #define CALL   bsrf
        !           173: #define JUMP   braf
        !           174:
        !           175: #define CALL_DATUM(function, lpcs) \
        !           176:                .long   PIC_PLT(function) - ((lpcs) + 4 - (.))
        !           177:
        !           178: /*
        !           179:  * This will result in text relocations in the shared library,
        !           180:  * unless the function is local or has hidden or protected visibility.
        !           181:  * Does not require PIC prologue.
        !           182:  */
        !           183: #define CALL_DATUM_LOCAL(function, lpcs) \
        !           184:                .long   function - ((lpcs) + 4)
        !           185:
        !           186: #else  /* !PIC */
        !           187:
        !           188: #define        PIC_PROLOGUE(label)
        !           189: #define        PIC_PROLOGUE_NOSAVE(label)
        !           190: #define        PIC_EPILOGUE
        !           191: #define        PIC_EPILOGUE_SLOT       nop
        !           192: #define PIC_GOT_DATUM
        !           193:
        !           194: #define CALL   jsr @
        !           195: #define JUMP   jmp @
        !           196:
        !           197: #define CALL_DATUM(function, lpcs) \
        !           198:                .long   function
        !           199:
        !           200: #define CALL_DATUM_LOCAL(function, lpcs) \
        !           201:                .long   function
        !           202:
        !           203: #endif /* !PIC */
        !           204:
        !           205:
        !           206: #define        ASMSTR          .asciz
        !           207:
        !           208: #ifdef __ELF__
        !           209: #define        WEAK_ALIAS(alias,sym)                                           \
        !           210:        .weak _C_LABEL(alias);                                          \
        !           211:        _C_LABEL(alias) = _C_LABEL(sym)
        !           212: #endif
        !           213:
        !           214: #define        WARN_REFERENCES(_sym,_msg)                              \
        !           215:        .section .gnu.warning._sym; .ascii _msg; .previous
        !           216:
        !           217: #endif /* !_SH_ASM_H_ */

CVSweb