xref: /netbsd-src/sys/arch/vax/vax/db_disasm.h (revision ee918b29e1ca494b866845d941c9d30ab6dca848)
1 /*	$NetBSD: db_disasm.h,v 1.8 2017/05/22 16:39:41 ragge Exp $ */
2 /*
3  * Copyright (c) 1996 Ludd, University of Lule}, Sweden.
4  * All rights reserved.
5  *
6  * This code is derived from software contributed to Ludd by
7  * Bertram Barth.
8  *
9  * Redistribution and use in source and binary forms, with or without
10  * modification, are permitted provided that the following conditions
11  * are met:
12  * 1. Redistributions of source code must retain the above copyright
13  *    notice, this list of conditions and the following disclaimer.
14  * 2. Redistributions in binary form must reproduce the above copyright
15  *    notice, this list of conditions and the following disclaimer in the
16  *    documentation and/or other materials provided with the distribution.
17  *
18  * THIS SOFTWARE IS PROVIDED BY THE AUTHOR ``AS IS'' AND ANY EXPRESS OR
19  * IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED WARRANTIES
20  * OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE DISCLAIMED.
21  * IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY DIRECT, INDIRECT,
22  * INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT
23  * NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE,
24  * DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY
25  * THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
26  * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF
27  * THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
28  */
29 
30 
31 
32 #define SIZE_BYTE	 1		/* Byte */
33 #define SIZE_WORD	 2		/* Word */
34 #define SIZE_LONG 	 4		/* Longword */
35 #define SIZE_QWORD	 8		/* Quadword */
36 #define SIZE_OWORD	16		/* Octaword */
37 
38 /*
39  * The VAX instruction set has a variable length instruction format which
40  * may be as short as one byte and as long as needed depending on the type
41  * of instruction. [...] Each instruction consists of an opcode followed
42  * by zero to six operand specifiers whose number and type depend on the
43  * opcode. All operand specidiers are, themselves, of the same format --
44  * i.e. an address mode plus additional information.
45  *
46  * [VAX Architecture Handbook, p.52:  Instruction Format]
47  */
48 
49 typedef const struct {
50 	const char *mnemonic;
51 	const char *argdesc;
52 } vax_instr_t;
53 
54 extern vax_instr_t vax_inst[256];
55 extern vax_instr_t vax_inst2[0x56];
56 
57 long skip_opcode(long);
58 
59 /*
60  * reasonably simple macro to gather all the reserved two-byte opcodes
61  * into only a few table entries...
62  */
63 #define	INDEX_OPCODE(x)	\
64 	(((x) & 0xff00) == 0xfe00) ? 0 : \
65 	((x) < 0xfd30) ? 0 : \
66 	((x) < 0xfd80) ? (x) - 0xfd30 : \
67 	((x) == 0xfd98) ? 0x50 : \
68 	((x) == 0xfd99) ? 0x51 : \
69 	((x) == 0xfdf6) ? 0x52 : \
70 	((x) == 0xfdf7) ? 0x53 : \
71 	((x) == 0xfffd) ? 0x54 : \
72 	((x) == 0xfffe) ? 0x55 : 0
73