2002-08-19 Dick Porter <dick@ximian.com>
[mono.git] / mono / arch / sparc / sparc-codegen.h
1 #ifndef __SPARC_CODEGEN_H__
2 #define __SPARC_CODEGEN_H__
3
4 typedef enum {
5         sparc_r0 = 0,
6         sparc_r1 = 1,
7         sparc_r2 = 2,
8         sparc_r3 = 3,
9         sparc_r4 = 4,
10         sparc_r5 = 5,
11         sparc_r6 = 6,
12         sparc_r7 = 7,
13         sparc_r8 = 8,
14         sparc_r9 = 9,
15         sparc_r10 = 10,
16         sparc_r11 = 11,
17         sparc_r12 = 12,
18         sparc_r13 = 13,
19         sparc_r14 = 14,
20         sparc_r15 = 15,
21         sparc_r16 = 16,
22         sparc_r17 = 17,
23         sparc_r18 = 18,
24         sparc_r19 = 19,
25         sparc_r20 = 20,
26         sparc_r21 = 21,
27         sparc_r22 = 22,
28         sparc_r23 = 23,
29         sparc_r24 = 24,
30         sparc_r25 = 25,
31         sparc_r26 = 26,
32         sparc_r27 = 27,
33         sparc_r28 = 28,
34         sparc_r29 = 29,
35         sparc_r30 = 30,
36         sparc_r31 = 31,
37         /* aliases */
38         /* global registers */
39         sparc_g0 = 0, sparc_zero = 0,
40         sparc_g1 = 1,
41         sparc_g2 = 2,
42         sparc_g3 = 3,
43         sparc_g4 = 4,
44         sparc_g5 = 5,
45         sparc_g6 = 6,
46         sparc_g7 = 7,
47         /* out registers */
48         sparc_o0 = 8,
49         sparc_o1 = 9,
50         sparc_o2 = 10,
51         sparc_o3 = 11,
52         sparc_o4 = 12,
53         sparc_o5 = 13,
54         sparc_o6 = 14, sparc_sp = 14,
55         sparc_o7 = 15, sparc_callsite = 15,
56         /* local registers */
57         sparc_l0 = 16,
58         sparc_l1 = 17,
59         sparc_l2 = 18,
60         sparc_l3 = 19,
61         sparc_l4 = 20,
62         sparc_l5 = 21,
63         sparc_l6 = 22,
64         sparc_l7 = 23,
65         /* in registers */
66         sparc_i0 = 24,
67         sparc_i1 = 25,
68         sparc_i2 = 26,
69         sparc_i3 = 27,
70         sparc_i4 = 28,
71         sparc_i5 = 29,
72         sparc_i6 = 30, sparc_fp = 30,
73         sparc_i7 = 31,
74         sparc_nreg = 32,
75         /* floating point registers */
76         sparc_f0 = 0,
77         sparc_f1 = 1,
78         sparc_f2 = 2,
79         sparc_f3 = 3,
80         sparc_f4 = 4,
81         sparc_f5 = 5,
82         sparc_f6 = 6,
83         sparc_f7 = 7,
84         sparc_f8 = 8,
85         sparc_f9 = 9,
86         sparc_f10 = 10,
87         sparc_f11 = 11,
88         sparc_f12 = 12,
89         sparc_f13 = 13,
90         sparc_f14 = 14,
91         sparc_f15 = 15,
92         sparc_f16 = 16,
93         sparc_f17 = 17,
94         sparc_f18 = 18,
95         sparc_f19 = 19,
96         sparc_f20 = 20,
97         sparc_f21 = 21,
98         sparc_f22 = 22,
99         sparc_f23 = 23,
100         sparc_f24 = 24,
101         sparc_f25 = 25,
102         sparc_f26 = 26,
103         sparc_f27 = 27,
104         sparc_f28 = 28,
105         sparc_f29 = 29,
106         sparc_f30 = 30,
107         sparc_f31 = 31,
108 } SparcRegister;
109
110 typedef enum {
111         sparc_bn   = 0, sparc_bnever = 0,
112         sparc_be   = 1,
113         sparc_ble  = 2,
114         sparc_bl   = 3,
115         sparc_bleu = 4,
116         sparc_bcs  = 5, sparc_blu = 5,
117         sparc_bneg = 6,
118         sparc_bvs  = 7, sparc_boverflow = 7,
119         sparc_ba   = 8, sparc_balways = 8,
120         sparc_bne  = 9,
121         sparc_bg   = 10,
122         sparc_bge  = 11,
123         sparc_bgu  = 12,
124         sparc_bcc  = 13, sparc_beu = 13,
125         sparc_bpos = 14,
126         sparc_bvc  = 15
127 } SparcCond;
128
129 typedef enum {
130         /* with fcmp */
131         sparc_feq = 0,
132         sparc_fl  = 1,
133         sparc_fg  = 2,
134         sparc_unordered = 3,
135         /* branch ops */
136         sparc_fba   = 8,
137         sparc_fbn   = 0,
138         sparc_fbu   = 7,
139         sparc_fbg   = 6,
140         sparc_fbug  = 5,
141         sparc_fbl   = 4,
142         sparc_fbul  = 3,
143         sparc_fblg  = 2,
144         sparc_fbne  = 1,
145         sparc_fbe   = 9,
146         sparc_fbue  = 10,
147         sparc_fbge  = 11,
148         sparc_fbuge = 12,
149         sparc_fble  = 13,
150         sparc_fbule = 14,
151         sparc_fbo   = 15
152 } SparcFCond;
153
154 typedef enum {
155         /* fop1 format */
156         sparc_fitos = 196,
157         sparc_fitod = 200,
158         sparc_fstoi = 209,
159         sparc_fdtoi = 210,
160         sparc_fstod = 201,
161         sparc_fdtos = 198,
162         sparc_fmov  = 1,
163         sparc_fneg  = 5,
164         sparc_fabs  = 9,
165         sparc_fsqrts = 41,
166         sparc_fsqrtd = 42,
167         sparc_fadds  = 65,
168         sparc_faddd  = 66,
169         sparc_fsubs  = 69,
170         sparc_fsubd  = 70,
171         sparc_fmuls  = 73,
172         sparc_fmuld  = 74,
173         sparc_fdivs  = 77,
174         sparc_fdivd  = 78,
175         /* fop2 format */
176         sparc_fcmps  = 81,
177         sparc_fcmpd  = 82
178 } SparcFOp;
179
180 typedef struct {
181         unsigned int op   : 2; /* always 1 */
182         unsigned int disp : 30;
183 } sparc_format1;
184
185 typedef struct {
186         unsigned int op   : 2; /* always 0 */
187         unsigned int rd   : 5;
188         unsigned int op2  : 3;
189         unsigned int disp : 22;
190 } sparc_format2a;
191
192 typedef struct {
193         unsigned int op   : 2; /* always 0 */
194         unsigned int a    : 1;
195         unsigned int cond : 4;
196         unsigned int op2  : 3;
197         unsigned int disp : 22;
198 } sparc_format2b;
199
200 typedef struct {
201         unsigned int op   : 2; /* 2 or 3 */
202         unsigned int rd   : 5;
203         unsigned int op3  : 6;
204         unsigned int rs1  : 5;
205         unsigned int i    : 1;
206         unsigned int asi  : 8;
207         unsigned int rs2  : 5;
208 } sparc_format3a;
209
210 typedef struct {
211         unsigned int op   : 2; /* 2 or 3 */
212         unsigned int rd   : 5;
213         unsigned int op3  : 6;
214         unsigned int rs1  : 5;
215         unsigned int i    : 1;
216         unsigned int imm  : 13;
217 } sparc_format3b;
218
219 typedef struct {
220         unsigned int op   : 2; /* 2 or 3 */
221         unsigned int rd   : 5;
222         unsigned int op3  : 6;
223         unsigned int rs1  : 5;
224         unsigned int opf  : 9;
225         unsigned int rs2  : 5;
226 } sparc_format3c;
227
228 /* for use in logical ops, use 0 to not set flags */
229 #define sparc_cc 16
230
231 #define sparc_encode_call(ins,addr) \
232         do {    \
233                 sparc_format1 *__f = (sparc_format1*)(ins);     \
234                 __f->op = 1;    \
235                 __f->disp = ((unsigned int)(addr) >> 2);        \
236                 (ins) = (unsigned int*)__f + 1; \
237         } while (0)
238
239 #define sparc_encode_format2a(ins,val,oper,dest) \
240         do {    \
241                 sparc_format2a *__f = (sparc_format2a*)(ins);   \
242                 __f->op = 0;    \
243                 __f->rd = (dest);       \
244                 __f->op2 = (oper);      \
245                 __f->disp = (val) & 0x3fffff;   \
246                 (ins) = (unsigned int*)__f + 1; \
247         } while (0)
248
249 #define sparc_encode_format2b(ins,aval,bcond,oper,disp22) \
250         do {    \
251                 sparc_format2b *__f = (sparc_format2b*)(ins);   \
252                 __f->op = 0;    \
253                 __f->a = (aval);        \
254                 __f->cond = (bcond);    \
255                 __f->op2 = (oper);      \
256                 __f->disp = (disp22);   \
257                 (ins) = (unsigned int*)__f + 1; \
258         } while (0)
259
260 #define sparc_encode_format3a(ins,opval,asival,r1,r2,oper,dest) \
261         do {    \
262                 sparc_format3a *__f = (sparc_format3a*)(ins);   \
263                 __f->op = (opval);      \
264                 __f->asi = (asival);    \
265                 __f->i = 0;     \
266                 __f->rd = (dest);       \
267                 __f->rs1 = (r1);        \
268                 __f->rs2 = (r2);        \
269                 __f->op3 = (oper);      \
270                 (ins) = (unsigned int*)__f + 1; \
271         } while (0)
272
273 #define sparc_encode_format3b(ins,opval,r1,val,oper,dest) \
274         do {    \
275                 sparc_format3b *__f = (sparc_format3b*)(ins);   \
276                 __f->op = (opval);      \
277                 __f->imm = (val);       \
278                 __f->i = 1;     \
279                 __f->rd = (dest);       \
280                 __f->rs1 = (r1);        \
281                 __f->op3 = (oper);      \
282                 (ins) = (unsigned int*)__f + 1; \
283         } while (0)
284
285 #define sparc_encode_format3c(ins,opval,opfval,r1,oper,r2,dest) \
286         do {    \
287                 sparc_format3c *__f = (sparc_format3c*)(ins);   \
288                 __f->op = (opval);      \
289                 __f->opf = (opfval);    \
290                 __f->rd = (dest);       \
291                 __f->rs1 = (r1);        \
292                 __f->rs2 = (r2);        \
293                 __f->op3 = (oper);      \
294                 (ins) = (unsigned int*)__f + 1; \
295         } while (0)
296
297 /* is it useful to provide a non-default value? */
298 #define sparc_asi 0x0
299
300 /* load */
301 #define sparc_ldsb(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),9,(dest))
302 #define sparc_ldsb_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),9,(dest))
303
304 #define sparc_ldsh(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),10,(dest))
305 #define sparc_ldsh_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),10,(dest))
306
307 #define sparc_ldub(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),1,(dest))
308 #define sparc_ldub_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),1,(dest))
309
310 #define sparc_lduh(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),2,(dest))
311 #define sparc_lduh_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),2,(dest))
312
313 #define sparc_ld(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),0,(dest))
314 #define sparc_ld_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),0,(dest))
315
316 #define sparc_ldd(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),3,(dest))
317 #define sparc_ldd_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),3,(dest))
318
319 #define sparc_ldf(ins,base,disp,dest) sparc_encode_format3a((ins),3,0,(base),(disp),32,(dest))
320 #define sparc_ldf_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),32,(dest))
321
322 #define sparc_lddf(ins,base,disp,dest) sparc_encode_format3a((ins),3,0,(base),(disp),35,(dest))
323 #define sparc_lddf_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),35,(dest))
324
325 /* store */
326 #define sparc_stb(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),5,(src))
327 #define sparc_stb_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),5,(src))
328
329 #define sparc_sth(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),6,(src))
330 #define sparc_sth_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),6,(src))
331
332 #define sparc_st(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),4,(src))
333 #define sparc_st_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),4,(src))
334
335 #define sparc_std(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),7,(src))
336 #define sparc_std_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),7,(src))
337
338 #define sparc_stf(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),36,(src))
339 #define sparc_stf_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),36,(src))
340
341 #define sparc_stdf(ins,src,base,disp) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),39,(src))
342 #define sparc_stdf_imm(ins,src,base,disp) sparc_encode_format3b((ins),3,(base),(disp),39,(src))
343
344 /* swap */
345 #define sparc_ldstub(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),13,(dest))
346 #define sparc_ldstub_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),13,(dest))
347
348 #define sparc_swap(ins,base,disp,dest) sparc_encode_format3a((ins),3,sparc_asi,(base),(disp),15,(dest))
349 #define sparc_swap_imm(ins,base,disp,dest) sparc_encode_format3b((ins),3,(base),(disp),15,(dest))
350
351 /* misc */
352 /* note: with sethi val is the full 32 bit value (think of it as %hi(val)) */
353 #define sparc_sethi(ins,val,dest) sparc_encode_format2a((ins),((val)>>10),4,(dest))
354
355 #define sparc_nop(ins) sparc_sethi((ins),0,sparc_zero)
356
357 #define sparc_save(ins,src,disp,dest) sparc_encode_format3a((ins),2,0,(src),(disp),60,(dest))
358 #define sparc_save_imm(ins,src,disp,dest) sparc_encode_format3b((ins),2,(src),(disp),60,(dest))
359
360 #define sparc_restore(ins,src,disp,dest) sparc_encode_format3a((ins),2,0,(src),(disp),61,(dest))
361 #define sparc_restore_imm(ins,src,disp,dest) sparc_encode_format3b((ins),2,(src),(disp),61,(dest))
362
363 #define sparc_jmpl(ins,base,disp,dest) sparc_encode_format3a((ins),2,0,(base),(disp),56,(dest))
364 #define sparc_jmpl_imm(ins,base,disp,dest) sparc_encode_format3b((ins),2,(base),(disp),56,(dest))
365
366 #define sparc_call_simple(ins,addr) sparc_encode_call((ins),((unsigned int)(addr)>>2))
367
368 #define sparc_rdy(ins,dest) sparc_encode_format3a((ins),2,0,0,0,40,(dest))
369
370 #define sparc_wry(ins,base,disp) sparc_encode_format3a((ins),2,0,(base),(disp),48,0)
371 #define sparc_wry_imm(ins,base,disp) sparc_encode_format3b((ins),2,(base),(disp),48,0)
372
373 /* stbar, unimp, flush */
374 #define sparc_stbar(ins) sparc_encode_format3a((ins),2,0,15,0,40,0)
375 #define sparc_unimp(ins,val) sparc_encode_format2b((ins),0,0,0,(val))
376
377 #define sparc_flush(ins,base,disp) sparc_encode_format3a((ins),2,0,(base),(disp),59,0)
378 #define sparc_flush_imm(ins,base,disp) sparc_encode_format3b((ins),2,(base),(disp),59,0)
379
380 /* trap */
381
382 /* alu fop */
383 /* provide wrappers for: fitos, fitod, fstoi, fdtoi, fstod, fdtos, fmov, fneg, fabs */
384
385 #define sparc_fop(ins,r1,op,r2,dest) sparc_encode_format3c((ins),2,(op),(r1),52,(r2),(dest))
386 #define sparc_fcmp(ins,r1,op,r2) sparc_encode_format3c((ins),2,(op),(r1),53,(r2),0)
387
388 /* logical */
389 #define sparc_and(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|1,(dest))
390 #define sparc_and_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|1,(dest))
391
392 #define sparc_andn(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|5,(dest))
393 #define sparc_andn_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|5,(dest))
394
395 #define sparc_or(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|2,(dest))
396 #define sparc_or_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|2,(dest))
397
398 #define sparc_orn(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|6,(dest))
399 #define sparc_orn_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|6,(dest))
400
401 #define sparc_xor(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|3,(dest))
402 #define sparc_xor_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(r2),(imm)|3,(dest))
403
404 #define sparc_xnor(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|7,(dest))
405 #define sparc_xnor_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|7,(dest))
406
407 /* shift */
408 #define sparc_sll(ins,src,disp,dest) sparc_encode_format3a((ins),2,0,(src),(disp),37,(dest))
409 #define sparc_sll_imm(ins,src,disp,dest) sparc_encode_format3b((ins),2,(src),(disp),37,(dest))
410
411 #define sparc_srl(ins,src,disp,dest) sparc_encode_format3a((ins),2,0,(src),(disp),38,(dest))
412 #define sparc_srl_imm(ins,src,disp,dest) sparc_encode_format3b((ins),2,(src),(disp),38,(dest))
413
414 #define sparc_sra(ins,src,disp,dest) sparc_encode_format3a((ins),2,0,(src),(disp),39,(dest))
415 #define sparc_sra_imm(ins,src,disp,dest) sparc_encode_format3b((ins),2,(src),(disp),39,(dest))
416
417 /* alu */
418 #define sparc_add(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|0,(dest))
419 #define sparc_add_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|0,(dest))
420
421 #define sparc_addx(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|8,(dest))
422 #define sparc_addx_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|8,(dest))
423
424 #define sparc_sub(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|4,(dest))
425 #define sparc_sub_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|4,(dest))
426
427 #define sparc_subx(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|12,(dest))
428 #define sparc_subx_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|12,(dest))
429
430 #define sparc_muls(ins,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),36,(dest))
431 #define sparc_muls_imm(ins,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),36,(dest))
432
433 #define sparc_umul(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|10,(dest))
434 #define sparc_umul_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|10,(dest))
435
436 #define sparc_smul(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|11,(dest))
437 #define sparc_smul_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|11,(dest))
438
439 #define sparc_udiv(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|14,(dest))
440 #define sparc_udiv_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|14,(dest))
441
442 #define sparc_sdiv(ins,setcc,r1,r2,dest) sparc_encode_format3a((ins),2,0,(r1),(r2),(setcc)|15,(dest))
443 #define sparc_sdiv_imm(ins,setcc,r1,imm,dest) sparc_encode_format3b((ins),2,(r1),(imm),(setcc)|15,(dest))
444
445
446 /* branch */
447 #define sparc_branch(ins,aval,condval,displ) sparc_encode_format2b((ins),(aval),(condval),2,(displ))
448 /* FIXME: float condition codes are different: unify. */
449 #define sparc_fbranch(ins,aval,condval,displ) sparc_encode_format2b((ins),(aval),(condval),6,(displ))
450
451 /* synthetic instructions */
452 #define sparc_cmp(ins,r1,r2) sparc_sub((ins),sparc_cc,(r1),(r2),sparc_g0)
453 #define sparc_cmp_imm(ins,r1,imm) sparc_sub_imm((ins),sparc_cc,(r1),(imm),sparc_g0)
454
455 #define sparc_jmp(ins,base,disp) sparc_jmpl((ins),(base),(disp),sparc_g0)
456 #define sparc_jmp_imm(ins,base,disp) sparc_jmpl_imm((ins),(base),(disp),sparc_g0)
457 #define sparc_call(ins,base,disp) sparc_jmpl((ins),(base),(disp),sparc_o7)
458 #define sparc_call_imm(ins,base,disp) sparc_jmpl_imm((ins),(base),(disp),sparc_o7)
459
460 #define sparc_test(ins,reg) sparc_or ((ins),sparc_cc,sparc_g0,(reg),sparc_g0)
461
462 #define sparc_ret(ins) sparc_jmpl_imm((ins),sparc_i7,8,sparc_g0)
463 #define sparc_retl(ins) sparc_jmpl_imm((ins),sparc_o7,8,sparc_g0)
464 #define sparc_restore_simple(ins) sparc_restore((ins),sparc_g0,sparc_g0,sparc_g0)
465
466 #define sparc_set(ins,val,reg)  \
467         do {    \
468                 if (((val) & 0x1fff) == 0)      \
469                         sparc_sethi((ins),(val),(reg)); \
470                 else if (((val) >= -4096) && ((val) <= 4095))   \
471                         sparc_or_imm((ins),FALSE,sparc_g0,(val),(reg)); \
472                 else {  \
473                         sparc_sethi((ins),(val),(reg)); \
474                         sparc_or_imm((ins),FALSE,(reg),(val)&0x3ff,(reg));      \
475                 }       \
476         } while (0)
477
478 #define sparc_not(ins,reg) sparc_xnor((ins),FALSE,(reg),sparc_g0,(reg))
479 #define sparc_neg(ins,reg) sparc_sub((ins),FALSE,sparc_g0,(reg),(reg))
480 #define sparc_clr_reg(ins,reg) sparc_or((ins),FALSE,sparc_g0,sparc_g0,(reg))
481
482 #define sparc_mov_reg_reg(ins,src,dest) sparc_or_imm((ins),FALSE,(src),0,(dest))
483
484
485 #endif /* __SPARC_CODEGEN_H__ */
486