summaryrefslogtreecommitdiffstats
path: root/sys/alpha/include/inst.h
blob: 27011848b17571683a8a9175e9e19df3ecd536a5 (plain)
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
25
26
27
28
29
30
31
32
33
34
35
36
37
38
39
40
41
42
43
44
45
46
47
48
49
50
51
52
53
54
55
56
57
58
59
60
61
62
63
64
65
66
67
68
69
70
71
72
73
74
75
76
77
78
79
80
81
82
83
84
85
86
87
88
89
90
91
92
93
94
95
96
97
98
99
100
101
102
103
104
105
106
107
108
109
110
111
112
113
114
115
116
117
118
119
120
121
122
123
124
125
126
127
128
129
130
131
132
133
134
135
136
137
138
139
140
141
142
143
144
145
146
147
148
149
150
151
152
153
154
155
156
157
158
159
160
161
162
163
164
165
166
167
168
169
170
171
172
173
174
175
176
177
178
179
180
181
182
183
184
185
186
187
188
189
190
191
192
193
194
195
196
197
198
199
200
201
202
203
204
205
206
207
208
209
210
211
212
213
214
215
216
217
218
219
220
221
222
223
224
225
226
227
228
229
230
231
232
233
234
235
236
237
238
239
240
241
242
243
244
245
246
247
248
249
250
251
252
253
254
255
256
257
258
259
260
261
262
263
264
265
266
267
268
269
270
271
272
273
274
275
276
277
278
279
280
281
282
283
284
285
286
287
288
289
290
291
292
293
294
295
296
297
298
299
300
301
302
303
304
305
306
307
308
309
310
311
312
313
314
315
316
317
318
319
320
321
322
323
324
325
326
327
328
329
330
331
332
333
334
335
336
337
338
339
340
341
342
343
344
345
346
347
348
349
350
351
352
353
354
355
356
357
358
359
360
361
362
363
364
365
366
367
368
369
370
371
372
373
374
375
376
377
378
379
380
381
382
383
384
385
386
387
388
389
390
391
392
393
394
395
396
397
398
399
400
401
402
403
404
405
406
407
408
409
410
411
412
413
414
415
416
417
418
419
420
421
422
423
424
425
426
427
428
429
430
431
432
433
434
435
436
437
438
439
440
441
442
443
444
445
446
447
448
449
450
451
452
453
454
455
456
457
458
459
460
461
462
/*-
 * Copyright (c) 1998 Doug Rabson
 * All rights reserved.
 *
 * Redistribution and use in source and binary forms, with or without
 * modification, are permitted provided that the following conditions
 * are met:
 * 1. Redistributions of source code must retain the above copyright
 *    notice, this list of conditions and the following disclaimer.
 * 2. Redistributions in binary form must reproduce the above copyright
 *    notice, this list of conditions and the following disclaimer in the
 *    documentation and/or other materials provided with the distribution.
 *
 * THIS SOFTWARE IS PROVIDED BY THE AUTHOR AND CONTRIBUTORS ``AS IS'' AND
 * ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
 * IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
 * ARE DISCLAIMED.  IN NO EVENT SHALL THE AUTHOR OR CONTRIBUTORS BE LIABLE
 * FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL
 * DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS
 * OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION)
 * HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT
 * LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY
 * OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF
 * SUCH DAMAGE.
 *
 *	$Id$
 */

#ifndef _MACHINE_INST_H_
#define _MACHINE_INST_H_

union alpha_instruction {
    u_int32_t word;
    struct {
	u_int32_t argument	: 26;
	u_int32_t opcode	: 6;
#define op_call_pal		0x00
#define op_lda			0x08
#define	op_ldah			0x09
#define op_ldbu			0x0a
#define op_unop			0x0b
#define op_ldq_u		0x0b
#define op_ldwu			0x0c
#define op_stw			0x0d
#define op_stb			0x0e
#define op_stq_u		0x0f
#define op_inta			0x10
#define		inta_addl	0x00
#define		inta_s4addl	0x02
#define		inta_subl	0x09
#define		inta_s4subl	0x0b
#define		inta_cmpbge	0x0f
#define		inta_s8addl	0x12
#define		inta_s8subl	0x1b
#define		inta_cmpult	0x1d
#define		inta_addq	0x20
#define		inta_s4addq	0x22
#define		inta_subq	0x29
#define		inta_s4subq	0x2b
#define		inta_cmpeq	0x2d
#define		inta_s8addq	0x32
#define		inta_s8subq	0x3b
#define		inta_cmpule	0x3d
#define		inta_addlv	0x40
#define		inta_sublv	0x49
#define		inta_cmplt	0x4d
#define		inta_addqv	0x60
#define		inta_subqv	0x69
#define		inta_cmple	0x6d
#define op_intl			0x11
#define		intl_and	0x00
#define		intl_andnot	0x08
#define		intl_bic	0x08
#define		intl_cmovlbs	0x14
#define		intl_cmovlbc	0x16
#define		intl_or		0x20
#define		intl_bis	0x20
#define		intl_cmoveq	0x24
#define		intl_cmovne	0x26
#define		intl_ornot	0x28
#define		intl_xor	0x40
#define		intl_cmovlt	0x44
#define		intl_cmovge	0x46
#define		intl_eqv	0x48
#define		intl_amask	0x61
#define		intl_cmovle	0x64
#define		intl_cmovgt	0x66
#define		intl_implver	0x6c
#define op_ints			0x12
#define		ints_mskbl	0x02
#define		ints_extbl	0x06
#define		ints_insbl	0x0b
#define		ints_mskwl	0x12
#define		ints_extwl	0x16
#define		ints_inswl	0x1b
#define		ints_mskll	0x22
#define		ints_extll	0x26
#define		ints_insll	0x2b
#define		ints_zap	0x30
#define		ints_zapnot	0x31
#define		ints_mskql	0x32
#define		ints_srl	0x34
#define		ints_extql	0x36
#define		ints_sll	0x39
#define		ints_insql	0x3b
#define		ints_sra	0x3c
#define		ints_mskwh	0x52
#define		ints_inswh	0x57
#define		ints_extwh	0x5a
#define		ints_msklh	0x62
#define		ints_inslh	0x67
#define		ints_extlh	0x6a
#define		ints_mskqh	0x72
#define		ints_insqh	0x77
#define		ints_extqh	0x7a
#define op_intm			0x13
#define		intm_mull	0x00
#define		intm_mulq	0x20
#define		intm_umulh	0x30
#define		intm_mullv	0x40
#define		intm_mulqv	0x60
#define op_opc14		0x14
#define op_fltv			0x15
#define op_flti			0x16
#define		flti_addsc	0x000
#define		flti_subsc	0x001
#define		flti_mulsc	0x002
#define		flti_divsc	0x003
#define		flti_addtc	0x020
#define		flti_subtc	0x021
#define		flti_multc	0x022
#define		flti_divtc	0x023
#define		flti_cvttsc	0x02c
#define		flti_cvttqc	0x02f
#define		flti_cvtqsc	0x03c
#define		flti_cvtqtc	0x03e

#define		flti_addsm	0x040
#define		flti_subsm	0x041
#define		flti_mulsm	0x042
#define		flti_divsm	0x043
#define		flti_addtm	0x060
#define		flti_subtm	0x061
#define		flti_multm	0x062
#define		flti_divtm	0x063
#define		flti_cvttsm	0x06c
#define		flti_cvttqm	0x06f
#define		flti_cvtqsm	0x07c
#define		flti_cvtqtm	0x07e

#define		flti_adds	0x080
#define		flti_subs	0x081
#define		flti_muls	0x082
#define		flti_divs	0x083

#define		flti_addt	0x0a0
#define		flti_subt	0x0a1
#define		flti_mult	0x0a2
#define		flti_divt	0x0a3
#define		flti_cmptun	0x0a4
#define		flti_cmpteq	0x0a5
#define		flti_cmptlt	0x0a6
#define		flti_cmptle	0x0a7
#define		flti_cvtts	0x0ac
#define		flti_cvttq	0x0af
#define		flti_cvtqs	0x0bc
#define		flti_cvtqt	0x0be

#define		flti_addsd	0x0c0
#define		flti_subsd	0x0c1
#define		flti_mulsd	0x0c2
#define		flti_divsd	0x0c3
#define		flti_addtd	0x0e0
#define		flti_subtd	0x0e1
#define		flti_multd	0x0e2
#define		flti_divtd	0x0e3
#define		flti_cvttsd	0x0ec
#define		flti_cvttqd	0x0ef
#define		flti_cvtqsd	0x0fc
#define		flti_cvtqtd	0x0fe

#define		flti_addsuc	0x100
#define		flti_subsuc	0x101
#define		flti_mulsuc	0x102
#define		flti_divsuc	0x103
#define		flti_addtuc	0x120
#define		flti_subtuc	0x121
#define		flti_multuc	0x122
#define		flti_divtuc	0x123
#define		flti_cvttsuc	0x12c
#define		flti_cvttqvc	0x12f

#define		flti_addsum	0x140
#define		flti_subsum	0x141
#define		flti_mulsum	0x142
#define		flti_divsum	0x143
#define		flti_addtum	0x160
#define		flti_subtum	0x161
#define		flti_multum	0x162
#define		flti_divtum	0x163
#define		flti_cvttsum	0x16c
#define		flti_cvttqvm	0x16f

#define		flti_addsu	0x180
#define		flti_subsu	0x181
#define		flti_mulsu	0x182
#define		flti_divsu	0x183
#define		flti_addtu	0x1a0
#define		flti_subtu	0x1a1
#define		flti_multu	0x1a2
#define		flti_divtu	0x1a3
#define		flti_cvttsu	0x1ac
#define		flti_cvttqv	0x1af

#define		flti_addsud	0x1c0
#define		flti_subsud	0x1c1
#define		flti_mulsud	0x1c2
#define		flti_divsud	0x1c3
#define		flti_addtud	0x1e0
#define		flti_subtud	0x1e1
#define		flti_multud	0x1e2
#define		flti_divtud	0x1e3
#define		flti_cvttsud	0x1ec
#define		flti_cvttqvd	0x1ef

#define		flti_cvtst	0x2ac

#define		flti_addssuc	0x500
#define		flti_subssuc	0x501
#define		flti_mulssuc	0x502
#define		flti_divssuc	0x503
#define		flti_addtsuc	0x520
#define		flti_subtsuc	0x521
#define		flti_multsuc	0x522
#define		flti_divtsuc	0x523
#define		flti_cvttssuc	0x52c
#define		flti_cvttqsvc	0x52f

#define		flti_addssum	0x540
#define		flti_subssum	0x541
#define		flti_mulssum	0x542
#define		flti_divssum	0x543
#define		flti_addtsum	0x560
#define		flti_subtsum	0x561
#define		flti_multsum	0x562
#define		flti_divtsum	0x563
#define		flti_cvttssum	0x56c
#define		flti_cvttqsvm	0x56f

#define		flti_addssu	0x580
#define		flti_subssu	0x581
#define		flti_mulssu	0x582
#define		flti_divssu	0x583
#define		flti_addtsu	0x5a0
#define		flti_subtsu	0x5a1
#define		flti_multsu	0x5a2
#define		flti_divtsu	0x5a3
#define		flti_cmptunsu	0x5a4
#define		flti_cmpteqsu	0x5a5
#define		flti_cmptltsu	0x5a6
#define		flti_cmptlesu	0x5a7
#define		flti_cvttssu	0x5ac
#define		flti_cvttqsv	0x5af

#define		flti_addssud	0x5c0
#define		flti_subssud	0x5c1
#define		flti_mulssud	0x5c2
#define		flti_divssud	0x5c3
#define		flti_addtsud	0x5e0
#define		flti_subtsud	0x5e1
#define		flti_multsud	0x5e2
#define		flti_divtsud	0x5e3
#define		flti_cvttssud	0x5ec
#define		flti_cvttqsvd	0x5ef

#define		flti_cvtsts	0x6ac

#define		flti_addssuic	0x700
#define		flti_subssuic	0x701
#define		flti_mulssuic	0x702
#define		flti_divssuic	0x703
#define		flti_addtsuic	0x720
#define		flti_subtsuic	0x721
#define		flti_multsuic	0x722
#define		flti_divtsuic	0x723
#define		flti_cvttssuic	0x72c
#define		flti_cvttqsvic	0x72f
#define		flti_cvtqssuic	0x73c
#define		flti_cvtqtsuic	0x73e

#define		flti_addssuim	0x740
#define		flti_subssuim	0x741
#define		flti_mulssuim	0x742
#define		flti_divssuim	0x743
#define		flti_addtsuim	0x760
#define		flti_subtsuim	0x761
#define		flti_multsuim	0x762
#define		flti_divtsuim	0x763
#define		flti_cvttssuim	0x76c
#define		flti_cvttqsvim	0x76f
#define		flti_cvtqssuim	0x77c
#define		flti_cvtqtsuim	0x77e

#define		flti_addssui	0x780
#define		flti_subssui	0x781
#define		flti_mulssui	0x782
#define		flti_divssui	0x783
#define		flti_addtsui	0x7a0
#define		flti_subtsui	0x7a1
#define		flti_multsui	0x7a2
#define		flti_divtsui	0x7a3
#define		flti_cmptunsui	0x7a4
#define		flti_cmpteqsui	0x7a5
#define		flti_cmptltsui	0x7a6
#define		flti_cmptlesui	0x7a7
#define		flti_cvttssui	0x7ac
#define		flti_cvttqsvi	0x7af
#define		flti_cvtqssui	0x7bc
#define		flti_cvtqtsui	0x7bc

#define		flti_addssuid	0x7c0
#define		flti_subssuid	0x7c1
#define		flti_mulssuid	0x7c2
#define		flti_divssuid	0x7c3
#define		flti_addtsuid	0x7e0
#define		flti_subtsuid	0x7e1
#define		flti_multsuid	0x7e2
#define		flti_divtsuid	0x7e3
#define		flti_cvttssuid	0x7ec
#define		flti_cvttqsvid	0x7ef
#define		flti_cvtqssuid	0x7fc
#define		flti_cvtqtsuid	0x7fc

#define op_fltl			0x17
#define		fltl_cvtlq	0x010
#define		fltl_cpys	0x020
#define		fltl_cpysn	0x021
#define		fltl_cpyse	0x022
#define		fltl_mt_fpcr	0x024
#define		fltl_mf_fpcr	0x025
#define		fltl_fcmoveq	0x02a
#define		fltl_fcmovne	0x02b
#define		fltl_fcmovlt	0x02c
#define		fltl_fcmovge	0x02d
#define		fltl_fcmovle	0x02e
#define		fltl_fcmovgt	0x02f
#define		fltl_cvtql	0x030
#define		fltl_cvtqlv	0x130
#define		fltl_cvtqlsv	0x530

#define op_misc			0x18
#define		misc_trapb	0x0000
#define		misc_excb	0x0400
#define		misc_mb		0x4000
#define		misc_wmb	0x4400
#define		misc_fetch	0x8000
#define		misc_fetch_m	0xa000
#define		misc_rpcc	0xc000
#define		misc_rc		0xe000
#define		misc_ecb	0xe800
#define		misc_rs		0xf000
#define		misc_wh64	0xf800

#define op_pal19		0x19
#define op_jsr			0x1a
#define op_pal1b		0x1b
#define op_pal1c		0x1c
#define op_pal1d		0x1d
#define op_pal1e		0x1e
#define op_pal1f		0x1f
#define op_ldf			0x20
#define op_ldg			0x21
#define op_lds			0x22
#define op_ldt			0x23
#define op_stf			0x24
#define op_stg			0x25
#define op_sts			0x26
#define op_stt			0x27
#define op_ldl			0x28
#define op_ldq			0x29
#define op_ldl_l		0x2a
#define op_ldq_l		0x2b
#define op_stl			0x2c
#define op_stq			0x2d
#define op_stl_c		0x2e
#define op_stq_c		0x2f
#define op_br			0x30
#define op_fbeq			0x31
#define op_fblt			0x32
#define op_fble			0x33
#define op_bsr			0x34
#define op_fbne			0x35
#define op_fbge			0x36
#define op_fbgt			0x37
#define op_blbc			0x38
#define op_beq			0x39
#define op_blt			0x3a
#define op_ble			0x3b
#define op_blbs			0x3c
#define op_bne			0x3d
#define op_bge			0x3e
#define op_bgt			0x3f
    } common;
    struct {
	u_int32_t function	: 16;
	u_int32_t rb		: 5;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } memory_format;
    struct {
	u_int32_t hint		: 14;
	u_int32_t function	: 2;
#define jsr_jmp			0
#define jsr_jsr			1
#define jsr_ret			2
#define jsr_jsr_coroutine	3
	u_int32_t rb		: 5;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } j_format;
    struct {
	int32_t memory_displacement : 16;
	u_int32_t rb		: 5;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } m_format;
    struct {
	u_int32_t rc		: 5;
	u_int32_t function	: 7;
	u_int32_t form		: 1;
	u_int32_t sbz		: 3;
	u_int32_t rb		: 5;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } o_format;
    struct {
	u_int32_t rc		: 5;
	u_int32_t function	: 7;
	u_int32_t form		: 1;
	u_int32_t literal	: 8;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } l_format;
    struct {
	u_int32_t fc		: 5;
	u_int32_t function	: 11;
	u_int32_t fb		: 5;
	u_int32_t fa		: 5;
	u_int32_t opcode	: 6;
    } f_format;
    struct {
	u_int32_t function	: 26;
	u_int32_t opcode	: 6;
    } pal_format;
    struct {
	int32_t branch_displacement : 21;
	u_int32_t ra		: 5;
	u_int32_t opcode	: 6;
    } b_format;
};

#endif /* _MACHINE_INST_H_ */
OpenPOWER on IntegriCloud