xref: /netbsd-src/sys/arch/hppa/include/asm.h (revision 3dc08fb5f4d7b90747a75b174b7d0c0370c06766)
1 /*	$NetBSD: asm.h,v 1.20 2025/01/06 10:46:43 martin Exp $	*/
2 
3 /*	$OpenBSD: asm.h,v 1.12 2001/03/29 02:15:57 mickey Exp $	*/
4 
5 /*
6  * Copyright (c) 1990,1991,1994 The University of Utah and
7  * the Computer Systems Laboratory (CSL).  All rights reserved.
8  *
9  * Permission to use, copy, modify and distribute this software is hereby
10  * granted provided that (1) source code retains these copyright, permission,
11  * and disclaimer notices, and (2) redistributions including binaries
12  * reproduce the notices in supporting documentation, and (3) all advertising
13  * materials mentioning features or use of this software display the following
14  * acknowledgement: ``This product includes software developed by the
15  * Computer Systems Laboratory at the University of Utah.''
16  *
17  * THE UNIVERSITY OF UTAH AND CSL ALLOW FREE USE OF THIS SOFTWARE IN ITS "AS
18  * IS" CONDITION.  THE UNIVERSITY OF UTAH AND CSL DISCLAIM ANY LIABILITY OF
19  * ANY KIND FOR ANY DAMAGES WHATSOEVER RESULTING FROM THE USE OF THIS SOFTWARE.
20  *
21  * CSL requests users of this software to return to csl-dist@cs.utah.edu any
22  * improvements that they make and grant CSL redistribution rights.
23  *
24  *	Utah $Hdr: asm.h 1.8 94/12/14$
25  */
26 
27 #ifndef _HPPA_ASM_H_
28 #define _HPPA_ASM_H_
29 
30 #include <machine/frame.h>
31 /*
32  *	hppa assembler definitions
33  */
34 
35 #ifdef __STDC__
36 #define	__CONCAT(a,b)	a ## b
37 #else
38 #define	__CONCAT(a,b)	a/**/b
39 #endif
40 
41 #define _C_LABEL(x)	x
42 
43 #define _ASM_LS_CHAR	!
44 
45 #define	_ENTRY(x) \
46 	 ! .text ! .align 4				!\
47 	.export x, entry ! .label x ! .proc
48 
49 #define	LEAF_ENTRY_NOPROFILE(x)				!\
50 	_ENTRY(x)					!\
51 	.callinfo frame=0, no_calls, save_rp		!\
52 	.entry
53 
54 #define	ENTRY_NOPROFILE(x,n)				!\
55 	_ENTRY(x)					!\
56 	.callinfo frame=n, calls, save_rp, save_sp	!\
57 	.entry
58 
59 #ifdef GPROF
60 
61 #define	_PROF_PROLOGUE				!\
62 1:						!\
63 	stw	%rp, HPPA_FRAME_CRP(%sp)	!\
64 	stw	%arg0, HPPA_FRAME_ARG(0)(%sp)	!\
65 	stw	%arg1, HPPA_FRAME_ARG(1)(%sp)	!\
66 	stw	%arg2, HPPA_FRAME_ARG(2)(%sp)	!\
67 	stw	%arg3, HPPA_FRAME_ARG(3)(%sp)	!\
68 	ldo	HPPA_FRAME_SIZE(%sp), %sp	!\
69 	copy	%rp, %arg0			!\
70 	bl	2f, %arg1			!\
71 	 depi	0, 31, 2, %arg1			!\
72 2:						!\
73 	bl	_mcount, %rp			!\
74 	 ldo	1b - 2b(%arg1), %arg1		!\
75 	ldo	-HPPA_FRAME_SIZE(%sp), %sp	!\
76 	ldw	HPPA_FRAME_ARG(3)(%sp), %arg3	!\
77 	ldw	HPPA_FRAME_ARG(2)(%sp), %arg2	!\
78 	ldw	HPPA_FRAME_ARG(1)(%sp), %arg1	!\
79 	ldw	HPPA_FRAME_ARG(0)(%sp), %arg0	!\
80 	ldw	HPPA_FRAME_CRP(%sp), %rp	!\
81 
82 #define LEAF_ENTRY(x) 				!\
83 	ENTRY_NOPROFILE(x,HPPA_FRAME_SIZE)	!\
84 	_PROF_PROLOGUE
85 
86 #else /* GPROF */
87 
88 #define _PROF_PROLOGUE
89 
90 #define LEAF_ENTRY(x) 				!\
91 	LEAF_ENTRY_NOPROFILE(x)
92 
93 #endif /* GPROF */
94 
95 #define ENTRY(x,n) 				!\
96 	ENTRY_NOPROFILE(x,n)			!\
97 	_PROF_PROLOGUE
98 
99 #define ALTENTRY(x) ! .export x, entry ! .label x
100 #define EXIT(x) ! .exit ! .procend ! .size x, .-x
101 
102 #ifdef _NETBSD_REVISIONID
103 #define RCSID(x)	.pushsection ".ident","MS",@progbits,1;		\
104 			.asciz x;					\
105 			.ascii "$"; .ascii "NetBSD: "; .ascii __FILE__;	\
106 			.ascii " "; .ascii _NETBSD_REVISIONID;		\
107 			.asciz " $";					\
108 			.popsection
109 #else
110 #define RCSID(x)	.pushsection ".ident","MS",@progbits,1;		\
111 			.asciz x;					\
112 			.popsection
113 #endif
114 
115 #define WEAK_ALIAS(alias,sym)				\
116 	.weak alias !					\
117 	alias = sym
118 
119 /*
120  * STRONG_ALIAS: create a strong alias.
121  */
122 #define STRONG_ALIAS(alias,sym)				\
123 	.globl alias !					\
124 	alias = sym
125 
126 #define CALL(func,tmp)					!\
127 	ldil	L%func, tmp				!\
128 	ldo	R%func(tmp), tmp			!\
129 	.call						!\
130 	blr	%r0, %rp				!\
131 	bv,n	%r0(tmp)				!\
132 	nop
133 
134 #ifdef __PIC__
135 #define PIC_CALL(func)					!\
136 	addil	LT%func, %r19				!\
137 	ldw	RT%func(%r1), %r1			!\
138 	.call						!\
139 	blr	%r0, %rp				!\
140 	bv,n	%r0(%r1)				!\
141 	nop
142 #else
143 #define PIC_CALL(func)					!\
144 	CALL(func,%r1)
145 #endif
146 
147 #ifdef __STDC__
148 #define	WARN_REFERENCES(sym,msg)					\
149 	.pushsection .gnu.warning. ## sym;				\
150 	.ascii msg;							\
151 	.popsection
152 #else
153 #define	WARN_REFERENCES(sym,msg)					\
154 	.pushsection .gnu.warning./**/sym;				\
155 	.ascii msg;							\
156 	.popsection
157 #endif /* __STDC__ */
158 
159 #define	BSS(n,s)	.comm n, s
160 #define	SZREG	4
161 
162 #endif /* _HPPA_ASM_H_ */
163