Home | History | Annotate | Line # | Download | only in include
asm.h revision 1.7.2.1
      1  1.7.2.1  nathanw /*	$NetBSD: asm.h,v 1.7.2.1 2001/06/21 19:32:08 nathanw Exp $	*/
      2      1.1       ws 
      3      1.1       ws /*
      4      1.1       ws  * Copyright (C) 1995, 1996 Wolfgang Solfrank.
      5      1.1       ws  * Copyright (C) 1995, 1996 TooLs GmbH.
      6      1.1       ws  * All rights reserved.
      7      1.1       ws  *
      8      1.1       ws  * Redistribution and use in source and binary forms, with or without
      9      1.1       ws  * modification, are permitted provided that the following conditions
     10      1.1       ws  * are met:
     11      1.1       ws  * 1. Redistributions of source code must retain the above copyright
     12      1.1       ws  *    notice, this list of conditions and the following disclaimer.
     13      1.1       ws  * 2. Redistributions in binary form must reproduce the above copyright
     14      1.1       ws  *    notice, this list of conditions and the following disclaimer in the
     15      1.1       ws  *    documentation and/or other materials provided with the distribution.
     16      1.1       ws  * 3. All advertising materials mentioning features or use of this software
     17      1.1       ws  *    must display the following acknowledgement:
     18      1.1       ws  *	This product includes software developed by TooLs GmbH.
     19      1.1       ws  * 4. The name of TooLs GmbH may not be used to endorse or promote products
     20      1.1       ws  *    derived from this software without specific prior written permission.
     21      1.1       ws  *
     22      1.1       ws  * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
     23      1.1       ws  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
     24      1.1       ws  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
     25      1.1       ws  * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
     26      1.1       ws  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
     27      1.1       ws  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
     28      1.1       ws  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
     29      1.1       ws  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
     30      1.1       ws  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
     31      1.1       ws  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
     32      1.1       ws  */
     33      1.1       ws 
     34      1.1       ws #ifndef _PPC_ASM_H_
     35      1.1       ws #define _PPC_ASM_H_
     36      1.1       ws 
     37      1.1       ws #ifdef PIC
     38      1.1       ws #define PIC_PROLOGUE	XXX
     39      1.1       ws #define PIC_EPILOGUE	XXX
     40      1.4   tsubai #define PIC_PLT(x)	x@plt
     41      1.1       ws #ifdef	__STDC__
     42      1.1       ws #define PIC_GOT(x)	XXX
     43      1.1       ws #define PIC_GOTOFF(x)	XXX
     44      1.1       ws #else	/* not __STDC__ */
     45      1.1       ws #define PIC_GOT(x)	XXX
     46      1.1       ws #define PIC_GOTOFF(x)	XXX
     47      1.1       ws #endif	/* __STDC__ */
     48      1.1       ws #else
     49      1.1       ws #define PIC_PROLOGUE
     50      1.1       ws #define PIC_EPILOGUE
     51      1.1       ws #define PIC_PLT(x)	x
     52      1.1       ws #define PIC_GOT(x)	x
     53      1.1       ws #define PIC_GOTOFF(x)	x
     54      1.1       ws #endif
     55      1.1       ws 
     56      1.3  thorpej #define	_C_LABEL(x)	x
     57      1.1       ws #define	_ASM_LABEL(x)	x
     58      1.1       ws 
     59      1.3  thorpej #define	_GLOBAL(x) \
     60      1.3  thorpej 	.data; .align 2; .globl x; x:
     61      1.3  thorpej 
     62      1.1       ws #define _ENTRY(x) \
     63      1.1       ws 	.text; .align 2; .globl x; .type x,@function; x:
     64      1.1       ws 
     65      1.2      jtc #ifdef GPROF
     66      1.6   tsubai # define _PROF_PROLOGUE	mflr 0; stw 0,4(1); bl _mcount
     67      1.1       ws #else
     68      1.1       ws # define _PROF_PROLOGUE
     69      1.1       ws #endif
     70      1.1       ws 
     71      1.1       ws #define	ENTRY(y)	_ENTRY(_C_LABEL(y)); _PROF_PROLOGUE
     72      1.1       ws #define	ASENTRY(y)	_ENTRY(_ASM_LABEL(y)); _PROF_PROLOGUE
     73      1.3  thorpej #define	GLOBAL(y)	_GLOBAL(_C_LABEL(y))
     74      1.1       ws 
     75      1.1       ws #define	ASMSTR		.asciz
     76      1.1       ws 
     77      1.1       ws #define RCSID(x)	.text; .asciz x
     78      1.7   kleink 
     79      1.7   kleink #ifdef __ELF__
     80      1.7   kleink #define	WEAK_ALIAS(alias,sym)						\
     81      1.7   kleink 	.weak alias;							\
     82      1.7   kleink 	alias = sym
     83      1.7   kleink #endif
     84      1.5  thorpej 
     85      1.5  thorpej #ifdef __STDC__
     86      1.5  thorpej #define	WARN_REFERENCES(_sym,_msg)				\
     87      1.5  thorpej 	.section .gnu.warning. ## _sym ; .ascii _msg ; .text
     88      1.5  thorpej #else
     89      1.5  thorpej #define	WARN_REFERENCES(_sym,_msg)				\
     90      1.5  thorpej 	.section .gnu.warning./**/_sym ; .ascii _msg ; .text
     91      1.5  thorpej #endif /* __STDC__ */
     92  1.7.2.1  nathanw 
     93  1.7.2.1  nathanw /* Condition Register Bit Fields */
     94  1.7.2.1  nathanw 
     95  1.7.2.1  nathanw #define cr0     0
     96  1.7.2.1  nathanw #define cr1     1
     97  1.7.2.1  nathanw #define cr2     2
     98  1.7.2.1  nathanw #define cr3     3
     99  1.7.2.1  nathanw #define cr4     4
    100  1.7.2.1  nathanw #define cr5     5
    101  1.7.2.1  nathanw #define cr6     6
    102  1.7.2.1  nathanw #define cr7     7
    103  1.7.2.1  nathanw 
    104  1.7.2.1  nathanw /* General Purpose Registers (GPRs) */
    105  1.7.2.1  nathanw 
    106  1.7.2.1  nathanw #define r0      0
    107  1.7.2.1  nathanw #define r1      1
    108  1.7.2.1  nathanw #define r2      2
    109  1.7.2.1  nathanw #define r3      3
    110  1.7.2.1  nathanw #define r4      4
    111  1.7.2.1  nathanw #define r5      5
    112  1.7.2.1  nathanw #define r6      6
    113  1.7.2.1  nathanw #define r7      7
    114  1.7.2.1  nathanw #define r8      8
    115  1.7.2.1  nathanw #define r9      9
    116  1.7.2.1  nathanw #define r10     10
    117  1.7.2.1  nathanw #define r11     11
    118  1.7.2.1  nathanw #define r12     12
    119  1.7.2.1  nathanw #define r13     13
    120  1.7.2.1  nathanw #define r14     14
    121  1.7.2.1  nathanw #define r15     15
    122  1.7.2.1  nathanw #define r16     16
    123  1.7.2.1  nathanw #define r17     17
    124  1.7.2.1  nathanw #define r18     18
    125  1.7.2.1  nathanw #define r19     19
    126  1.7.2.1  nathanw #define r20     20
    127  1.7.2.1  nathanw #define r21     21
    128  1.7.2.1  nathanw #define r22     22
    129  1.7.2.1  nathanw #define r23     23
    130  1.7.2.1  nathanw #define r24     24
    131  1.7.2.1  nathanw #define r25     25
    132  1.7.2.1  nathanw #define r26     26
    133  1.7.2.1  nathanw #define r27     27
    134  1.7.2.1  nathanw #define r28     28
    135  1.7.2.1  nathanw #define r29     29
    136  1.7.2.1  nathanw #define r30     30
    137  1.7.2.1  nathanw #define r31     31
    138  1.7.2.1  nathanw 
    139  1.7.2.1  nathanw /* Floating Point Registers (FPRs) */
    140  1.7.2.1  nathanw 
    141  1.7.2.1  nathanw #define fr0     0
    142  1.7.2.1  nathanw #define fr1     1
    143  1.7.2.1  nathanw #define fr2     2
    144  1.7.2.1  nathanw #define fr3     3
    145  1.7.2.1  nathanw #define fr4     4
    146  1.7.2.1  nathanw #define fr5     5
    147  1.7.2.1  nathanw #define fr6     6
    148  1.7.2.1  nathanw #define fr7     7
    149  1.7.2.1  nathanw #define fr8     8
    150  1.7.2.1  nathanw #define fr9     9
    151  1.7.2.1  nathanw #define fr10    10
    152  1.7.2.1  nathanw #define fr11    11
    153  1.7.2.1  nathanw #define fr12    12
    154  1.7.2.1  nathanw #define fr13    13
    155  1.7.2.1  nathanw #define fr14    14
    156  1.7.2.1  nathanw #define fr15    15
    157  1.7.2.1  nathanw #define fr16    16
    158  1.7.2.1  nathanw #define fr17    17
    159  1.7.2.1  nathanw #define fr18    18
    160  1.7.2.1  nathanw #define fr19    19
    161  1.7.2.1  nathanw #define fr20    20
    162  1.7.2.1  nathanw #define fr21    21
    163  1.7.2.1  nathanw #define fr22    22
    164  1.7.2.1  nathanw #define fr23    23
    165  1.7.2.1  nathanw #define fr24    24
    166  1.7.2.1  nathanw #define fr25    25
    167  1.7.2.1  nathanw #define fr26    26
    168  1.7.2.1  nathanw #define fr27    27
    169  1.7.2.1  nathanw #define fr28    28
    170  1.7.2.1  nathanw #define fr29    29
    171  1.7.2.1  nathanw #define fr30    30
    172  1.7.2.1  nathanw #define fr31    31
    173      1.1       ws 
    174      1.1       ws #endif /* !_PPC_ASM_H_ */
    175