clean
[linux-2.4.21-pre4.git] / include / asm-ppc / ppc_asm.h
1 /*
2  * BK Id: SCCS/s.ppc_asm.h 1.37 09/04/02 13:17:34 galak
3  */
4 /*
5  * include/asm-ppc/ppc_asm.h
6  *
7  * Definitions used by various bits of low-level assembly code on PowerPC.
8  *
9  * Copyright (C) 1995-1999 Gary Thomas, Paul Mackerras, Cort Dougan.
10  *
11  *  This program is free software; you can redistribute it and/or
12  *  modify it under the terms of the GNU General Public License
13  *  as published by the Free Software Foundation; either version
14  *  2 of the License, or (at your option) any later version.
15  */
16
17 #include <linux/config.h>
18
19 /*
20  * Macros for storing registers into and loading registers from
21  * exception frames.
22  */
23 #define SAVE_GPR(n, base)       stw     n,GPR0+4*(n)(base)
24 #define SAVE_2GPRS(n, base)     SAVE_GPR(n, base); SAVE_GPR(n+1, base)
25 #define SAVE_4GPRS(n, base)     SAVE_2GPRS(n, base); SAVE_2GPRS(n+2, base)
26 #define SAVE_8GPRS(n, base)     SAVE_4GPRS(n, base); SAVE_4GPRS(n+4, base)
27 #define SAVE_10GPRS(n, base)    SAVE_8GPRS(n, base); SAVE_2GPRS(n+8, base)
28 #define REST_GPR(n, base)       lwz     n,GPR0+4*(n)(base)
29 #define REST_2GPRS(n, base)     REST_GPR(n, base); REST_GPR(n+1, base)
30 #define REST_4GPRS(n, base)     REST_2GPRS(n, base); REST_2GPRS(n+2, base)
31 #define REST_8GPRS(n, base)     REST_4GPRS(n, base); REST_4GPRS(n+4, base)
32 #define REST_10GPRS(n, base)    REST_8GPRS(n, base); REST_2GPRS(n+8, base)
33
34 #define SAVE_FPR(n, base)       stfd    n,THREAD_FPR0+8*(n)(base)
35 #define SAVE_2FPRS(n, base)     SAVE_FPR(n, base); SAVE_FPR(n+1, base)
36 #define SAVE_4FPRS(n, base)     SAVE_2FPRS(n, base); SAVE_2FPRS(n+2, base)
37 #define SAVE_8FPRS(n, base)     SAVE_4FPRS(n, base); SAVE_4FPRS(n+4, base)
38 #define SAVE_16FPRS(n, base)    SAVE_8FPRS(n, base); SAVE_8FPRS(n+8, base)
39 #define SAVE_32FPRS(n, base)    SAVE_16FPRS(n, base); SAVE_16FPRS(n+16, base)
40 #define REST_FPR(n, base)       lfd     n,THREAD_FPR0+8*(n)(base)
41 #define REST_2FPRS(n, base)     REST_FPR(n, base); REST_FPR(n+1, base)
42 #define REST_4FPRS(n, base)     REST_2FPRS(n, base); REST_2FPRS(n+2, base)
43 #define REST_8FPRS(n, base)     REST_4FPRS(n, base); REST_4FPRS(n+4, base)
44 #define REST_16FPRS(n, base)    REST_8FPRS(n, base); REST_8FPRS(n+8, base)
45 #define REST_32FPRS(n, base)    REST_16FPRS(n, base); REST_16FPRS(n+16, base)
46
47 /*
48  * Once a version of gas that understands the AltiVec instructions
49  * is freely available, we can do this the normal way...  - paulus
50  */
51 #define LVX(r,a,b)      .long   (31<<26)+((r)<<21)+((a)<<16)+((b)<<11)+(103<<1)
52 #define STVX(r,a,b)     .long   (31<<26)+((r)<<21)+((a)<<16)+((b)<<11)+(231<<1)
53 #define MFVSCR(r)       .long   (4<<26)+((r)<<21)+(770<<1)
54 #define MTVSCR(r)       .long   (4<<26)+((r)<<11)+(802<<1)
55 #define DSSALL          .long   (0x1f<<26)+(0x10<<21)+(0x336<<1)
56
57 #define SAVE_VR(n,b,base)       li b,THREAD_VR0+(16*(n)); STVX(n,b,base)
58 #define SAVE_2VR(n,b,base)      SAVE_VR(n,b,base); SAVE_VR(n+1,b,base) 
59 #define SAVE_4VR(n,b,base)      SAVE_2VR(n,b,base); SAVE_2VR(n+2,b,base) 
60 #define SAVE_8VR(n,b,base)      SAVE_4VR(n,b,base); SAVE_4VR(n+4,b,base) 
61 #define SAVE_16VR(n,b,base)     SAVE_8VR(n,b,base); SAVE_8VR(n+8,b,base)
62 #define SAVE_32VR(n,b,base)     SAVE_16VR(n,b,base); SAVE_16VR(n+16,b,base)
63 #define REST_VR(n,b,base)       li b,THREAD_VR0+(16*(n)); LVX(n,b,base)
64 #define REST_2VR(n,b,base)      REST_VR(n,b,base); REST_VR(n+1,b,base) 
65 #define REST_4VR(n,b,base)      REST_2VR(n,b,base); REST_2VR(n+2,b,base) 
66 #define REST_8VR(n,b,base)      REST_4VR(n,b,base); REST_4VR(n+4,b,base) 
67 #define REST_16VR(n,b,base)     REST_8VR(n,b,base); REST_8VR(n+8,b,base) 
68 #define REST_32VR(n,b,base)     REST_16VR(n,b,base); REST_16VR(n+16,b,base)
69
70 #ifdef CONFIG_PPC601_SYNC_FIX
71 #define SYNC                            \
72 BEGIN_FTR_SECTION                       \
73         sync;                           \
74         isync;                          \
75 END_FTR_SECTION_IFSET(CPU_FTR_601)
76 #define SYNC_601                        \
77 BEGIN_FTR_SECTION                       \
78         sync;                           \
79 END_FTR_SECTION_IFSET(CPU_FTR_601)
80 #define ISYNC_601                       \
81 BEGIN_FTR_SECTION                       \
82         isync;                          \
83 END_FTR_SECTION_IFSET(CPU_FTR_601)
84 #else
85 #define SYNC
86 #define SYNC_601
87 #define ISYNC_601
88 #endif
89
90 #ifndef CONFIG_SMP
91 #define TLBSYNC
92 #else /* CONFIG_SMP */
93 /* tlbsync is not implemented on 601 */
94 #define TLBSYNC                         \
95 BEGIN_FTR_SECTION                       \
96         tlbsync;                        \
97         sync;                           \
98 END_FTR_SECTION_IFCLR(CPU_FTR_601)
99 #endif
100
101 /*
102  * This instruction is not implemented on the PPC 603 or 601; however, on
103  * the 403GCX and 405GP tlbia IS defined and tlbie is not.
104  * All of these instructions exist in the 8xx, they have magical powers,
105  * and they must be used.
106  */
107
108 #if !defined(CONFIG_4xx) && !defined(CONFIG_8xx)
109 #define tlbia                                   \
110         li      r4,1024;                        \
111         mtctr   r4;                             \
112         lis     r4,KERNELBASE@h;                \
113 0:      tlbie   r4;                             \
114         addi    r4,r4,0x1000;                   \
115         bdnz    0b
116 #endif
117
118 #ifndef CONFIG_PPC_ISERIES
119 /*
120  * On APUS (Amiga PowerPC cpu upgrade board), we don't know the
121  * physical base address of RAM at compile time.
122  */
123 #ifndef CONFIG_BOOKE
124 #define tophys(rd,rs)                           \
125 0:      addis   rd,rs,-KERNELBASE@h;            \
126         .section ".vtop_fixup","aw";            \
127         .align  1;                              \
128         .long   0b;                             \
129         .previous
130
131 #define tovirt(rd,rs)                           \
132 0:      addis   rd,rs,KERNELBASE@h;             \
133         .section ".ptov_fixup","aw";            \
134         .align  1;                              \
135         .long   0b;                             \
136         .previous
137 #else /* CONFIG_BOOKE */
138 #define tophys(rd,rs)                           \
139         mr      rd,rs
140 #define tovirt(rd,rs)                           \
141         mr      rd,rs
142 #endif /* CONFIG_BOOKE */
143 #else  /* CONFIG_PPC_ISERIES */
144
145 #define tophys(rd,rs)                           \
146         mr      rd,rs
147
148 #define tovirt(rd,rs)                           \
149         mr      rd,rs
150
151 /* Macros to adjust thread priority for iSeries hardware multi-threading */
152 #define HMT_LOW         or 1,1,1
153 #define HMT_MEDIUM      or 2,2,2
154 #define HMT_HIGH        or 3,3,3
155
156 #endif /* CONFIG_PPC_ISERIES */
157
158 /*
159  * On 64-bit cpus, we use the rfid instruction instead of rfi, but
160  * we then have to make sure we preserve the top 32 bits except for
161  * the 64-bit mode bit, which we clear.
162  */
163 #ifdef CONFIG_PPC64BRIDGE
164 #define FIX_SRR1(ra, rb)        \
165         mr      rb,ra;          \
166         mfmsr   ra;             \
167         clrldi  ra,ra,1;                /* turn off 64-bit mode */ \
168         rldimi  ra,rb,0,32
169 #define RFI             .long   0x4c000024      /* rfid instruction */
170 #define MTMSRD(r)       .long   (0x7c000164 + ((r) << 21))      /* mtmsrd */
171 #define CLR_TOP32(r)    rlwinm  (r),(r),0,0,31  /* clear top 32 bits */
172
173 #else
174 #define FIX_SRR1(ra, rb)
175 #ifndef CONFIG_4xx
176 #define RFI             rfi
177 #else
178 #define RFI             rfi; b .        /* prevent prefetch past rfi */
179 #endif
180 #define MTMSRD(r)       mtmsr   r
181 #define CLR_TOP32(r)
182 #endif /* CONFIG_PPC64BRIDGE */
183
184 #ifdef CONFIG_PPC_ISERIES
185 #define HMT_LOW         or      1,1,1
186 #define HMT_MEDIUM      or      2,2,2
187 #define HMT_HIGH        or      3,3,3
188 #else /* CONFIG_PPC_ISERIES */
189 #define HMT_LOW         /* nothing */
190 #define HMT_MEDIUM      /* nothing */
191 #define HMT_HIGH        /* nothing */
192
193 #endif /* CONFIG_PPC_ISERIES */
194
195 #ifdef CONFIG_IBM405_ERR77
196 #define PPC405_ERR77(ra,rb)     dcbt    ra, rb;
197 #define PPC405_ERR77_SYNC       sync;
198 #else
199 #define PPC405_ERR77(ra,rb)
200 #define PPC405_ERR77_SYNC
201 #endif
202
203 /* The boring bits... */
204
205 /* Condition Register Bit Fields */
206
207 #define cr0     0
208 #define cr1     1
209 #define cr2     2
210 #define cr3     3
211 #define cr4     4
212 #define cr5     5
213 #define cr6     6
214 #define cr7     7
215
216
217 /* General Purpose Registers (GPRs) */
218
219 #define r0      0
220 #define r1      1
221 #define r2      2
222 #define r3      3
223 #define r4      4
224 #define r5      5
225 #define r6      6
226 #define r7      7
227 #define r8      8
228 #define r9      9
229 #define r10     10
230 #define r11     11
231 #define r12     12
232 #define r13     13
233 #define r14     14
234 #define r15     15
235 #define r16     16
236 #define r17     17
237 #define r18     18
238 #define r19     19
239 #define r20     20
240 #define r21     21
241 #define r22     22
242 #define r23     23
243 #define r24     24
244 #define r25     25
245 #define r26     26
246 #define r27     27
247 #define r28     28
248 #define r29     29
249 #define r30     30
250 #define r31     31
251
252
253 /* Floating Point Registers (FPRs) */
254
255 #define fr0     0
256 #define fr1     1
257 #define fr2     2
258 #define fr3     3
259 #define fr4     4
260 #define fr5     5
261 #define fr6     6
262 #define fr7     7
263 #define fr8     8
264 #define fr9     9
265 #define fr10    10
266 #define fr11    11
267 #define fr12    12
268 #define fr13    13
269 #define fr14    14
270 #define fr15    15
271 #define fr16    16
272 #define fr17    17
273 #define fr18    18
274 #define fr19    19
275 #define fr20    20
276 #define fr21    21
277 #define fr22    22
278 #define fr23    23
279 #define fr24    24
280 #define fr25    25
281 #define fr26    26
282 #define fr27    27
283 #define fr28    28
284 #define fr29    29
285 #define fr30    30
286 #define fr31    31
287
288 #define vr0     0
289 #define vr1     1
290 #define vr2     2
291 #define vr3     3
292 #define vr4     4
293 #define vr5     5
294 #define vr6     6
295 #define vr7     7
296 #define vr8     8
297 #define vr9     9
298 #define vr10    10
299 #define vr11    11
300 #define vr12    12
301 #define vr13    13
302 #define vr14    14
303 #define vr15    15
304 #define vr16    16
305 #define vr17    17
306 #define vr18    18
307 #define vr19    19
308 #define vr20    20
309 #define vr21    21
310 #define vr22    22
311 #define vr23    23
312 #define vr24    24
313 #define vr25    25
314 #define vr26    26
315 #define vr27    27
316 #define vr28    28
317 #define vr29    29
318 #define vr30    30
319 #define vr31    31
320
321 /* some stab codes */
322 #define N_FUN   36
323 #define N_RSYM  64
324 #define N_SLINE 68
325 #define N_SO    100