1996-10-09 11:28:40 +04:00
|
|
|
/* $NetBSD: asm.h,v 1.7 1996/10/09 07:28:40 matthias Exp $ */
|
1994-10-26 11:23:50 +03:00
|
|
|
|
1993-09-10 03:53:45 +04:00
|
|
|
/*
|
|
|
|
* Mach Operating System
|
|
|
|
* Copyright (c) 1992 Carnegie Mellon University
|
|
|
|
* Copyright (c) 1992 Helsinki University of Technology
|
|
|
|
* All Rights Reserved.
|
|
|
|
*
|
|
|
|
* Permission to use, copy, modify and distribute this software and its
|
|
|
|
* documentation is hereby granted, provided that both the copyright
|
|
|
|
* notice and this permission notice appear in all copies of the
|
|
|
|
* software, derivative works or modified versions, and any portions
|
|
|
|
* thereof, and that both notices appear in supporting documentation.
|
|
|
|
*
|
|
|
|
* CARNEGIE MELLON AND HELSINKI UNIVERSITY OF TECHNOLOGY ALLOW FREE USE
|
|
|
|
* OF THIS SOFTWARE IN ITS "AS IS" CONDITION. CARNEGIE MELLON AND
|
|
|
|
* HELSINKI UNIVERSITY OF TECHNOLOGY DISCLAIM ANY LIABILITY OF ANY KIND
|
|
|
|
* FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
|
|
|
|
*
|
|
|
|
* Carnegie Mellon requests users of this software to return to
|
|
|
|
*
|
|
|
|
* Software Distribution Coordinator or Software.Distribution@CS.CMU.EDU
|
|
|
|
* School of Computer Science
|
|
|
|
* Carnegie Mellon University
|
|
|
|
* Pittsburgh PA 15213-3890
|
|
|
|
*
|
|
|
|
* any improvements or extensions that they make and grant Carnegie Mellon
|
|
|
|
* the rights to redistribute these changes.
|
|
|
|
*/
|
|
|
|
|
|
|
|
/*
|
|
|
|
* File: asm.h
|
|
|
|
* Author: Johannes Helander, Tero Kivinen, Tatu Ylonen
|
|
|
|
* Modified by Phil Nelson for NetBSD.
|
1994-05-03 11:29:37 +04:00
|
|
|
* Modified by Matthias Pfaller for PIC.
|
1993-09-10 03:53:45 +04:00
|
|
|
* Helsinki University of Technology 1992.
|
|
|
|
*/
|
|
|
|
|
1993-10-25 09:11:58 +03:00
|
|
|
#ifndef _MACHINE_ASM_H_
|
|
|
|
#define _MACHINE_ASM_H_
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#ifdef __STDC__
|
|
|
|
#define CAT(a, b) a ## b
|
|
|
|
#define EX(x) _ ## x
|
|
|
|
#define LEX(x) _ ## x ## :
|
|
|
|
#else
|
|
|
|
#define CAT(a, b) a/**/b
|
|
|
|
#define EX(x) _/**/x
|
|
|
|
#define LEX(x) _/**/x/**/:
|
|
|
|
#endif
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#define FRAME enter [],0
|
1993-09-10 03:53:45 +04:00
|
|
|
#define EMARF exit []
|
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#define S_ARG0 4(sp)
|
|
|
|
#define S_ARG1 8(sp)
|
|
|
|
#define S_ARG2 12(sp)
|
|
|
|
#define S_ARG3 16(sp)
|
|
|
|
|
1993-09-10 03:53:45 +04:00
|
|
|
#define B_ARG0 8(fp)
|
|
|
|
#define B_ARG1 12(fp)
|
|
|
|
#define B_ARG2 16(fp)
|
|
|
|
#define B_ARG3 20(fp)
|
|
|
|
|
|
|
|
#define ALIGN 0
|
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#ifdef PIC
|
|
|
|
#define PIC_PROLOGUE \
|
|
|
|
sprd sb,tos; \
|
|
|
|
addr __GLOBAL_OFFSET_TABLE_(pc),r1; \
|
|
|
|
lprd sb,r1
|
|
|
|
#define PIC_EPILOGUE \
|
|
|
|
lprd sb,tos
|
|
|
|
#define PIC_GOT(x) 0(x(sb))
|
|
|
|
|
|
|
|
#define PIC_S_ARG0 8(sp)
|
|
|
|
#define PIC_S_ARG1 12(sp)
|
|
|
|
#define PIC_S_ARG2 16(sp)
|
|
|
|
#define PIC_S_ARG3 20(sp)
|
|
|
|
#else
|
|
|
|
#define PIC_PROLOGUE
|
|
|
|
#define PIC_EPILOGUE
|
|
|
|
#define PIC_GOT(x) x(pc)
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#define PIC_S_ARG0 4(sp)
|
|
|
|
#define PIC_S_ARG1 8(sp)
|
|
|
|
#define PIC_S_ARG2 12(sp)
|
|
|
|
#define PIC_S_ARG3 16(sp)
|
|
|
|
#endif
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1996-10-09 11:28:40 +04:00
|
|
|
#if defined(PROF) || defined(GPROF)
|
1994-05-03 11:29:37 +04:00
|
|
|
#define MC1 .data; 1:; .long 0; .text
|
1996-10-09 11:28:40 +04:00
|
|
|
#define MC2 enter [r0],0; addr 1b(pc),r0; bsr mcount; exit [r0]
|
1994-05-03 11:29:37 +04:00
|
|
|
#else
|
|
|
|
#define MC1
|
|
|
|
#define MC2
|
|
|
|
#endif
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#define DECL(x) MC1; .globl x; .type x,@function; .align ALIGN; CAT(x,:); MC2
|
1996-10-09 11:28:40 +04:00
|
|
|
#define _DECL(x) .globl x; .type x,@function; .align ALIGN; CAT(x,:)
|
1993-09-10 03:53:45 +04:00
|
|
|
|
1994-05-03 11:29:37 +04:00
|
|
|
#define ENTRY(x) DECL(EX(x))
|
1996-10-09 11:28:40 +04:00
|
|
|
#define _ENTRY(x) _DECL(EX(x))
|
1994-05-03 11:29:37 +04:00
|
|
|
#define ASENTRY(x) DECL(x)
|
1996-10-09 11:28:40 +04:00
|
|
|
#define _ASENTRY(x) _DECL(x)
|
1994-05-03 11:29:37 +04:00
|
|
|
#define ASMSTR .asciz
|
1996-10-09 11:28:40 +04:00
|
|
|
#define RCSID(x) .text; .asciz x
|
1993-09-10 03:53:45 +04:00
|
|
|
|
|
|
|
#define SVC svc
|
|
|
|
|
1993-10-25 09:11:58 +03:00
|
|
|
#endif
|