asm.h revision 1.5
1/*	$NetBSD: asm.h,v 1.5 1996/11/30 02:49:06 jtc Exp $ */
2/*
3 * Copyright (c) 1982, 1993
4 *	The Regents of the University of California.  All rights reserved.
5 *
6 * Redistribution and use in source and binary forms, with or without
7 * modification, are permitted provided that the following conditions
8 * are met:
9 * 1. Redistributions of source code must retain the above copyright
10 *    notice, this list of conditions and the following disclaimer.
11 * 2. Redistributions in binary form must reproduce the above copyright
12 *    notice, this list of conditions and the following disclaimer in the
13 *    documentation and/or other materials provided with the distribution.
14 * 3. All advertising materials mentioning features or use of this software
15 *    must display the following acknowledgement:
16 *	This product includes software developed by the University of
17 *	California, Berkeley and its contributors.
18 * 4. Neither the name of the University nor the names of its contributors
19 *    may be used to endorse or promote products derived from this software
20 *    without specific prior written permission.
21 *
22 * THIS SOFTWARE IS PROVIDED BY THE REGENTS AND CONTRIBUTORS ``AS IS'' AND
23 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
24 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
25 * ARE DISCLAIMED.  IN NO EVENT SHALL THE REGENTS OR CONTRIBUTORS BE LIABLE
26 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
27 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
28 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
29 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
30 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
31 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
32 * SUCH DAMAGE.
33 *
34 *	@(#)DEFS.h	8.1 (Berkeley) 6/4/93
35 */
36
37#ifndef _MACHINE_ASM_H_
38#define _MACHINE_ASM_H_
39
40#define R0	0x001
41#define R1	0x002
42#define R2	0x004
43#define R3	0x008
44#define R4	0x010
45#define R5	0x020
46#define R6	0x040
47#define	R7 	0x080
48#define	R8	0x100
49#define	R9	0x200
50#define	R10	0x400
51#define	R11	0x800
52
53#ifdef __STDC__
54#ifdef GPROF
55#define	ENTRY(x, regs) \
56	.globl _ ## x ## ; .align 2; _ ## x ## : .word regs; \
57	.data; 1:; .long 0; .text; moval 1b,r0; jsb mcount
58#define	ASENTRY(x, regs) \
59	.globl x; .align 2; x ## : .word regs; \
60	.data; 1:; .long 0; .text; moval 1b,r0; jsb mcount
61#else
62#define	ENTRY(x, regs) \
63	.globl _ ## x; .align 2; _ ## x ## : .word regs
64#define	ASENTRY(x, regs) \
65	.globl x; .align 2; x ## : .word regs
66#endif
67# else
68#ifdef GPROF
69#define ENTRY(x, regs) \
70	.globl _/**/x; .align 2; _/**/x: .word regs; \
71	.data; 1:; .long 0; .text; moval 1b,r0; jsb mcount
72#define ASENTRY(x, regs) \
73	.globl x; .align 2; x: .word regs; \
74	.data; 1:; .long 0; .text; moval 1b,r0; jsb mcount
75#else
76#define ENTRY(x, regs) \
77	.globl _/**/x; .align 2; _/**/x: .word regs
78#define ASENTRY(x, regs) \
79	.globl x; .align 2; x: .word regs
80#endif
81#endif
82
83#endif
84