xref: /freebsd/sys/powerpc/include/asm.h (revision 076ad2f836d5f49dc1375f1677335a48fe0d4b82)
1 /*-
2  * Copyright (C) 1995, 1996 Wolfgang Solfrank.
3  * Copyright (C) 1995, 1996 TooLs GmbH.
4  * 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 TooLs GmbH.
17  * 4. The name of TooLs GmbH may not be used to endorse or promote products
18  *    derived from this software without specific prior written permission.
19  *
20  * THIS SOFTWARE IS PROVIDED BY TOOLS GMBH ``AS IS'' AND ANY EXPRESS OR
21  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
22  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
23  * IN NO EVENT SHALL TOOLS GMBH BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL,
24  * SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
25  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
26  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
27  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
28  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF
29  * ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
30  *
31  *	$NetBSD: asm.h,v 1.6.18.1 2000/07/25 08:37:14 kleink Exp $
32  * $FreeBSD$
33  */
34 
35 #ifndef _MACHINE_ASM_H_
36 #define	_MACHINE_ASM_H_
37 
38 #include <sys/cdefs.h>
39 
40 #if defined(PIC) && !defined(__powerpc64__)
41 #define	PIC_PROLOGUE	XXX
42 #define	PIC_EPILOGUE	XXX
43 #define	PIC_PLT(x)	x@plt
44 #ifdef	__STDC__
45 #define	PIC_GOT(x)	XXX
46 #else	/* not __STDC__ */
47 #define	PIC_GOT(x)	XXX
48 #endif	/* __STDC__ */
49 #else
50 #define	PIC_PROLOGUE
51 #define	PIC_EPILOGUE
52 #define	PIC_PLT(x)	x
53 #define PIC_GOT(x)	x
54 #endif
55 
56 #define	CNAME(csym)		csym
57 #define	ASMNAME(asmsym)		asmsym
58 #ifdef __powerpc64__
59 #define	HIDENAME(asmsym)	__CONCAT(_,asmsym)
60 #else
61 #define	HIDENAME(asmsym)	__CONCAT(.,asmsym)
62 #endif
63 
64 #if !defined(_CALL_ELF) || _CALL_ELF == 1
65 #ifdef _KERNEL
66 /* ELFv1 kernel uses global dot symbols */
67 #define	DOT_LABEL(name)		__CONCAT(.,name)
68 #define	TYPE_ENTRY(name)	.size	name,24; \
69 				.type	DOT_LABEL(name),@function; \
70 				.globl	DOT_LABEL(name);
71 #define	END_SIZE(name)		.size	DOT_LABEL(name),.-DOT_LABEL(name);
72 #else /* !_KERNEL */
73 /* ELFv1 user code uses local function entry points */
74 #define	DOT_LABEL(name)		__CONCAT(.L.,name)
75 #define	TYPE_ENTRY(name)	.type	name,@function;
76 #define	END_SIZE(name)		.size	name,.-DOT_LABEL(name);
77 #endif /* _KERNEL */
78 #else
79 /* ELFv2 doesn't have any of this complication */
80 #define	DOT_LABEL(name)		name
81 #define	TYPE_ENTRY(name)	.type	name,@function;
82 #define	END_SIZE(name)		.size	name,.-DOT_LABEL(name);
83 #endif
84 
85 #define	_GLOBAL(name) \
86 	.data; \
87 	.p2align 2; \
88 	.globl	name; \
89 	name:
90 
91 #ifdef __powerpc64__
92 #define TOC_NAME_FOR_REF(name)	__CONCAT(.L,name)
93 #define	TOC_REF(name)	TOC_NAME_FOR_REF(name)@toc
94 #define TOC_ENTRY(name) \
95 	.section ".toc","aw"; \
96 	TOC_NAME_FOR_REF(name): \
97         .tc name[TC],name
98 #endif
99 
100 #ifdef __powerpc64__
101 
102 #if !defined(_CALL_ELF) || _CALL_ELF == 1
103 #define	_ENTRY(name) \
104 	.section ".text"; \
105 	.p2align 2; \
106 	.globl	name; \
107 	.section ".opd","aw"; \
108 	.p2align 3; \
109 	name: \
110 	.quad	DOT_LABEL(name),.TOC.@tocbase,0; \
111 	.previous; \
112 	.p2align 4; \
113 	TYPE_ENTRY(name) \
114 DOT_LABEL(name):
115 #else
116 #define	_ENTRY(name) \
117 	.text; \
118 	.p2align 4; \
119 	.globl	name; \
120 	.type	name,@function; \
121 name: \
122 	addis	%r2, %r12, (.TOC.-name)@ha; \
123 	addi	%r2, %r2, (.TOC.-name)@l; \
124 	.localentry name, .-name;
125 #endif
126 
127 #define	_END(name) \
128 	.long	0; \
129 	.byte	0,0,0,0,0,0,0,0; \
130 	END_SIZE(name)
131 #else /* !__powerpc64__ */
132 #define	_ENTRY(name) \
133 	.text; \
134 	.p2align 4; \
135 	.globl	name; \
136 	.type	name,@function; \
137 	name:
138 #define	_END(name)
139 #endif /* __powerpc64__ */
140 
141 #if defined(PROF) || (defined(_KERNEL) && defined(GPROF))
142 # ifdef __powerpc64__
143 #   define	_PROF_PROLOGUE	mflr 0;					\
144 				std 3,48(1);				\
145 				std 4,56(1);				\
146 				std 5,64(1);				\
147 				std 0,16(1);				\
148 				stdu 1,-112(1);				\
149 				bl _mcount;				\
150 				nop;					\
151 				ld 0,112+16(1);				\
152 				ld 3,112+48(1);				\
153 				ld 4,112+56(1);				\
154 				ld 5,112+64(1);				\
155 				mtlr 0;					\
156 				addi 1,1,112
157 # else
158 #   define	_PROF_PROLOGUE	mflr 0; stw 0,4(1); bl _mcount
159 # endif
160 #else
161 # define	_PROF_PROLOGUE
162 #endif
163 
164 #define	ASENTRY(y)	_ENTRY(ASMNAME(y)); _PROF_PROLOGUE
165 #define	END(y)		_END(CNAME(y))
166 #define	ENTRY(y)	_ENTRY(CNAME(y)); _PROF_PROLOGUE
167 #define	GLOBAL(y)	_GLOBAL(CNAME(y))
168 
169 #define	ASENTRY_NOPROF(y)	_ENTRY(ASMNAME(y))
170 #define	ENTRY_NOPROF(y)		_ENTRY(CNAME(y))
171 
172 #define	ASMSTR		.asciz
173 
174 #define	RCSID(x)	.text; .asciz x
175 
176 #undef __FBSDID
177 #if !defined(lint) && !defined(STRIP_FBSDID)
178 #define __FBSDID(s)	.ident s
179 #else
180 #define __FBSDID(s)	/* nothing */
181 #endif /* not lint and not STRIP_FBSDID */
182 
183 #define	WEAK_REFERENCE(sym, alias)				\
184 	.weak alias;						\
185 	.equ alias,sym
186 
187 #ifdef __STDC__
188 #define	WARN_REFERENCES(_sym,_msg)				\
189 	.section .gnu.warning. ## _sym ; .ascii _msg ; .text
190 #else
191 #define	WARN_REFERENCES(_sym,_msg)				\
192 	.section .gnu.warning./**/_sym ; .ascii _msg ; .text
193 #endif /* __STDC__ */
194 
195 #endif /* !_MACHINE_ASM_H_ */
196