1ed0d50c3Schristos /* mc9xgate-opc.c -- Freescale XGATE opcode list
2*b88e3e88Schristos    Copyright (C) 1999-2020 Free Software Foundation, Inc.
3ed0d50c3Schristos    Written by Sean Keys (skeys@ipdatasys.com)
4ed0d50c3Schristos 
5ed0d50c3Schristos    This file is part of the GNU opcodes library.
6ed0d50c3Schristos 
7ed0d50c3Schristos    This library is free software; you can redistribute it and/or modify
8ed0d50c3Schristos    it under the terms of the GNU General Public License as published by
9ed0d50c3Schristos    the Free Software Foundation; either version 3, or (at your option)
10ed0d50c3Schristos    any later version.
11ed0d50c3Schristos 
12ed0d50c3Schristos    It is distributed in the hope that it will be useful, but WITHOUT
13ed0d50c3Schristos    ANY WARRANTY; without even the implied warranty of MERCHANTABILITY
14ed0d50c3Schristos    or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU General Public
15ed0d50c3Schristos    License for more details.
16ed0d50c3Schristos 
17ed0d50c3Schristos    You should have received a copy of the GNU General Public License
18ed0d50c3Schristos    along with this file; see the file COPYING.  If not, write to the
19ed0d50c3Schristos    Free Software Foundation, 51 Franklin Street - Fifth Floor, Boston,
20ed0d50c3Schristos    MA 02110-1301, USA.
21ed0d50c3Schristos */
22ed0d50c3Schristos 
23ed0d50c3Schristos #include <stdio.h>
24ed0d50c3Schristos #include "ansidecl.h"
25ed0d50c3Schristos #include "opcode/xgate.h"
26ed0d50c3Schristos 
27ed0d50c3Schristos #define TABLE_SIZE(X)       (sizeof(X) / sizeof(X[0]))
28ed0d50c3Schristos 
29ed0d50c3Schristos /* Combination of CCR flags.  */
30ed0d50c3Schristos /* ORDER HI TO LOW NZVC */
31ed0d50c3Schristos #define XGATE_NZ_BIT	XGATE_N_BIT|XGATE_Z_BIT
32ed0d50c3Schristos #define XGATE_NV_BIT	XGATE_N_BIT|XGATE_V_BIT
33ed0d50c3Schristos #define XGATE_NC_BIT	XGATE_N_BIT|XGATE_C_BIT
34ed0d50c3Schristos #define XGATE_ZV_BIT	XGATE_Z_BIT|XGATE_V_BIT
35ed0d50c3Schristos #define XGATE_ZC_BIT	XGATE_Z_BIT|XGATE_C_BIT
36ed0d50c3Schristos #define XGATE_VC_BIT	XGATE_V_BIT|XGATE_C_BIT
37ed0d50c3Schristos #define XGATE_NVC_BIT	XGATE_NV_BIT|XGATE_C_BIT
38ed0d50c3Schristos #define XGATE_NZC_BIT	XGATE_NZ_BIT|XGATE_C_BIT
39ed0d50c3Schristos #define XGATE_NZV_BIT	XGATE_N_BIT|XGATE_Z_BIT|XGATE_V_BIT
40ed0d50c3Schristos #define XGATE_ZVC_BIT	XGATE_VC_BIT|XGATE_Z_BIT
41ed0d50c3Schristos #define XGATE_NZVC_BIT	XGATE_NZV_BIT|XGATE_C_BIT
42ed0d50c3Schristos 
43ed0d50c3Schristos /* Flags when the insn only changes some CCR flags.  */
44ed0d50c3Schristos #define CHG_NONE        0,0,0
45ed0d50c3Schristos #define CHG_Z           0,0,XGATE_Z_BIT
46ed0d50c3Schristos #define CHG_C           0,0,XGATE_C_BIT
47ed0d50c3Schristos #define CHG_ZVC         0,0,XGATE_ZVC_BIT
48ed0d50c3Schristos #define CHG_NZC         0,0,XGATE_NZC_BIT
49ed0d50c3Schristos #define CHG_NZV         0,0,XGATE_NZV_BIT
50ed0d50c3Schristos #define CHG_NZVC        0,0,(XGATE_NZVC_BIT)
51ed0d50c3Schristos #define CHG_HNZVC       0,0,XGATE_HNZVC_BIT  // TODO DELETE
52ed0d50c3Schristos #define CHG_ALL         0,0,0xff
53ed0d50c3Schristos 
54ed0d50c3Schristos /* The insn clears and changes some flags.  */
55ed0d50c3Schristos #define CLR_I           0,XG_I_BIT,0
56ed0d50c3Schristos #define CLR_C           0,XGATE_C_BIT,0
57ed0d50c3Schristos #define CLR_V           0,XGATE_V_BIT,0
58ed0d50c3Schristos #define CLR_V_CHG_ZC    0,XGATE_V_BIT,XGATE_ZC_BIT
59ed0d50c3Schristos #define CLR_V_CHG_NZ    0,XGATE_V_BIT,XGATE_NZ_BIT
60ed0d50c3Schristos #define CLR_V_CHG_ZVC   0,XGATE_V_BIT,XGATE_ZVC_BIT
61ed0d50c3Schristos #define CLR_N_CHG_ZVC   0,XGATE_N_BIT,XGATE_ZVC_BIT /* Used by lsr */
62ed0d50c3Schristos #define CLR_VC_CHG_NZ   0,XGATE_VC_BIT,XGATE_NZ_BIT
63ed0d50c3Schristos 
64ed0d50c3Schristos /* The insn sets some flags.  */
65ed0d50c3Schristos #define SET_I                   XGATE_I_BIT,0,0
66ed0d50c3Schristos #define SET_C                   XGATE_C_BIT,0,0
67ed0d50c3Schristos #define SET_V                   XGATE_V_BIT,0,0
68ed0d50c3Schristos #define SET_Z_CLR_NVC           XGATE_Z_BIT,XGATE_NVC_BIT,0
69ed0d50c3Schristos #define SET_C_CLR_V_CHG_NZ      XGATE_C_BIT,XGATE_V_BIT,XGATE_NZ_BIT
70ed0d50c3Schristos #define SET_Z_CHG_HNVC          XGATE_Z_BIT,0,XGATE_HNVC_BIT
71ed0d50c3Schristos 
72ed0d50c3Schristos /* operand modes */
73ed0d50c3Schristos #define OP_NONE         XGATE_OP_NONE
74ed0d50c3Schristos #define OP_INH		XGATE_OP_INH
75ed0d50c3Schristos #define OP_TRI		XGATE_OP_TRI
76ed0d50c3Schristos #define OP_DYA		XGATE_OP_DYA
77ed0d50c3Schristos #define OP_IMM3		XGATE_OP_IMM3
78ed0d50c3Schristos #define OP_IMM4		XGATE_OP_IMM4
79ed0d50c3Schristos #define OP_IMM8		XGATE_OP_IMM8
80ed0d50c3Schristos #define OP_IMM16	XGATE_OP_IMM16
81ed0d50c3Schristos #define OP_MON		XGATE_OP_MON
82ed0d50c3Schristos #define OP_MON_R_C	XGATE_OP_MON_R_C
83ed0d50c3Schristos #define OP_MON_C_R	XGATE_OP_MON_C_R
84ed0d50c3Schristos #define OP_MON_R_P	XGATE_OP_MON_R_P
85ed0d50c3Schristos #define OP_IDR	        XGATE_OP_IDR
86ed0d50c3Schristos #define OP_IDO5		XGATE_OP_IDO5
87ed0d50c3Schristos #define OP_REL9		XGATE_OP_REL9
88ed0d50c3Schristos #define OP_REL10    	XGATE_OP_REL10
89ed0d50c3Schristos #define OP_DM           XGATE_OP_DYA_MON
90ed0d50c3Schristos /* macro operand modes */
91ed0d50c3Schristos #define OP_mADD         XGATE_OP_IMM16mADD
92ed0d50c3Schristos #define OP_mAND         XGATE_OP_IMM16mAND
93ed0d50c3Schristos #define OP_mCPC         XGATE_OP_IMM16mCPC
94ed0d50c3Schristos #define OP_mLDW         XGATE_OP_IMM16mLDW
95ed0d50c3Schristos #define OP_mSUB         XGATE_OP_IMM16mSUB
96ed0d50c3Schristos 
97ed0d50c3Schristos #define ALL       XGATE_V1|XGATE_V2|XGATE_V3
98ed0d50c3Schristos 
99ed0d50c3Schristos const struct xgate_opcode xgate_opcodes[] = {
100ed0d50c3Schristos /* Name -+                                                              +--- CPU
101ed0d50c3Schristos    Constraints --+                                              +----------- CCR changes
102ed0d50c3Schristos    Format -------+                                         +---------------- Max # cycles
103ed0d50c3Schristos                                                         +------------------- Min # cycles
104ed0d50c3Schristos    Size -------------------------------------+   +-------------------------- Opcode */
105ed0d50c3Schristos     {   "adc",   OP_TRI, "00011rrrrrrrrr11", 2, 0x1803, 1, 1, CHG_NZVC, ALL},
106ed0d50c3Schristos     {   "add",   OP_TRI, "00011rrrrrrrrr10", 2, 0x1802, 1, 1, CHG_NZVC, ALL},
107ed0d50c3Schristos     {  "addh",  OP_IMM8, "11101rrriiiiiiii", 2, 0xE800, 1, 1, CHG_NZVC, ALL},
108ed0d50c3Schristos     {  "addl",  OP_IMM8, "11100rrriiiiiiii", 2, 0xE000, 1, 1, CHG_NZVC, ALL},
109ed0d50c3Schristos     {   "and",   OP_TRI, "00010rrrrrrrrr00", 2, 0x1000, 1, 1,  CHG_NZV, ALL},
110ed0d50c3Schristos     {  "andh",  OP_IMM8, "10001rrriiiiiiii", 2, 0x8800, 1, 1,  CHG_NZV, ALL},
111ed0d50c3Schristos     {  "andl",  OP_IMM8, "10000rrriiiiiiii", 2, 0x8000, 1, 1,  CHG_NZV, ALL},
112ed0d50c3Schristos     {   "asr",  OP_IMM4, "00001rrriiii1001", 2, 0x0809, 1, 1, CHG_NZVC, ALL},
113ed0d50c3Schristos     {   "asr",   OP_DYA, "00001rrrrrr10001", 2, 0x0811, 1, 1, CHG_NZVC, ALL},
114ed0d50c3Schristos     {   "bcc",  OP_REL9, "0010000iiiiiiiii", 2, 0x2000, 1, 2, CHG_NONE, ALL},
115ed0d50c3Schristos     {   "bcs",  OP_REL9, "0010001iiiiiiiii", 2, 0x2200, 1, 2, CHG_NONE, ALL},
116ed0d50c3Schristos     {   "beq",  OP_REL9, "0010011iiiiiiiii", 2, 0x2600, 1, 2, CHG_NONE, ALL},
117ed0d50c3Schristos     { "bfext",   OP_TRI, "01100rrrrrrrrr11", 2, 0x6003, 1, 1,  CHG_NZV, ALL},
118ed0d50c3Schristos     {  "bffo",   OP_DYA, "00001rrrrrr10000", 2, 0x0810, 1, 1, CHG_NZVC, ALL},
119ed0d50c3Schristos     { "bfins",   OP_TRI, "01101rrrrrrrrr11", 2, 0x6803, 1, 1,  CHG_NZV, ALL},
120ed0d50c3Schristos     {"bfinsi",   OP_TRI, "01110rrrrrrrrr11", 2, 0x7003, 1, 1,  CHG_NZV, ALL},
121ed0d50c3Schristos     {"bfinsx",   OP_TRI, "01111rrrrrrrrr11", 2, 0x7803, 1, 1,  CHG_NZV, ALL},
122ed0d50c3Schristos     {   "bge",  OP_REL9, "0011010iiiiiiiii", 2, 0x3400, 1, 2, CHG_NONE, ALL},
123ed0d50c3Schristos     {   "bgt",  OP_REL9, "0011100iiiiiiiii", 2, 0x3800, 1, 2, CHG_NONE, ALL},
124ed0d50c3Schristos     {   "bhi",  OP_REL9, "0011000iiiiiiiii", 2, 0x3000, 1, 2, CHG_NONE, ALL},
125ed0d50c3Schristos     {  "bith",  OP_IMM8, "10011rrriiiiiiii", 2, 0x9800, 1, 1,  CHG_NZV, ALL},
126ed0d50c3Schristos     {  "bitl",  OP_IMM8, "10010rrriiiiiiii", 2, 0x9000, 1, 1,  CHG_NZV, ALL},
127ed0d50c3Schristos     {   "ble",  OP_REL9, "0011101iiiiiiiii", 2, 0x3A00, 1, 2, CHG_NONE, ALL},
128ed0d50c3Schristos     {   "bls",  OP_REL9, "0011001iiiiiiiii", 2, 0x3200, 1, 2, CHG_NONE, ALL},
129ed0d50c3Schristos     {   "blt",  OP_REL9, "0011011iiiiiiiii", 2, 0x3600, 1, 2, CHG_NONE, ALL},
130ed0d50c3Schristos     {   "bmi",  OP_REL9, "0010101iiiiiiiii", 2, 0x2A00, 1, 2, CHG_NONE, ALL},
131ed0d50c3Schristos     {   "bne",  OP_REL9, "0010010iiiiiiiii", 2, 0x2400, 1, 2, CHG_NONE, ALL},
132ed0d50c3Schristos     {   "bpl",  OP_REL9, "0010100iiiiiiiii", 2, 0x2800, 1, 2, CHG_NONE, ALL},
133ed0d50c3Schristos     {   "bra", OP_REL10, "001111iiiiiiiiii", 2, 0x3C00, 2, 2, CHG_NONE, ALL},
134ed0d50c3Schristos     {   "brk",   OP_INH, "0000000000000000", 2, 0x0000, 1, 1, CHG_NONE, ALL},
135ed0d50c3Schristos     {   "bvc",  OP_REL9, "0010110iiiiiiiii", 2, 0x2C00, 1, 2, CHG_NONE, ALL},
136ed0d50c3Schristos     {   "bvs",  OP_REL9, "0010111iiiiiiiii", 2, 0x2E00, 1, 2, CHG_NONE, ALL},
137ed0d50c3Schristos     {  "cmpl",  OP_IMM8, "11010rrriiiiiiii", 2, 0xD000, 1, 1, CHG_NZVC, ALL},
138ed0d50c3Schristos     {  "cpch",  OP_IMM8, "11011rrriiiiiiii", 2, 0xD800, 1, 1, CHG_NZVC, ALL},
139ed0d50c3Schristos     {  "csem",  OP_IMM3, "00000iii11110000", 2, 0x00F0, 1, 1, CHG_NONE, ALL},
140ed0d50c3Schristos     {  "csem",   OP_MON, "00000rrr11110001", 2, 0x00F1, 1, 1, CHG_NONE, ALL},
141ed0d50c3Schristos     {   "csl",  OP_IMM4, "00001rrriiii1010", 2, 0x080A, 1, 1, CHG_NZVC, ALL},
142ed0d50c3Schristos     {   "csl",   OP_DYA, "00001rrrrrr10010", 2, 0x0812, 1, 1, CHG_NZVC, ALL},
143ed0d50c3Schristos     {   "csr",  OP_IMM4, "00001rrriiii1011", 2, 0x080B, 1, 1, CHG_NZVC, ALL},
144ed0d50c3Schristos     {   "csr",   OP_DYA, "00001rrrrrr10011", 2, 0x0813, 1, 1, CHG_NZVC, ALL},
145ed0d50c3Schristos     {   "jal",   OP_MON, "00000rrr11110110", 2, 0x00F6, 2, 2, CHG_NONE, ALL},
146ed0d50c3Schristos     {   "ldb",  OP_IDO5, "01000rrrrrriiiii", 2, 0x4000, 2, 2, CHG_NONE, ALL},
147ed0d50c3Schristos     {   "ldb",   OP_IDR, "01100rrrrrrrrrrr", 2, 0x6000, 2, 2, CHG_NONE, ALL},
148ed0d50c3Schristos     {   "ldh",  OP_IMM8, "11111rrriiiiiiii", 2, 0xF800, 1, 1, CHG_NONE, ALL},
149ed0d50c3Schristos     {   "ldl",  OP_IMM8, "11110rrriiiiiiii", 2, 0xF000, 1, 1, CHG_NONE, ALL},
150ed0d50c3Schristos     {   "ldw",  OP_IDO5, "01001rrrrrriiiii", 2, 0x4800, 2, 2, CHG_NONE, ALL},
151ed0d50c3Schristos     {   "ldw",   OP_IDR, "01101rrrrrrrrrrr", 2, 0x6800, 2, 2, CHG_NONE, ALL},
152ed0d50c3Schristos     {   "lsl",  OP_IMM4, "00001rrriiii1100", 2, 0x080C, 1, 1, CHG_NZVC, ALL},
153ed0d50c3Schristos     {   "lsl",   OP_DYA, "00001rrrrrr10100", 2, 0x0814, 1, 1, CHG_NZVC, ALL},
154ed0d50c3Schristos     {   "lsr",  OP_IMM4, "00001rrriiii1101", 2, 0x080D, 1, 1, CHG_NZVC, ALL},
155ed0d50c3Schristos     {   "lsr",   OP_DYA, "00001rrrrrr10101", 2, 0x0815, 1, 1, CHG_NZVC, ALL},
156ed0d50c3Schristos     {   "nop",   OP_INH, "0000000100000000", 2, 0x0100, 1, 1, CHG_NONE, ALL},
157ed0d50c3Schristos     {    "or",   OP_TRI, "00010rrrrrrrrr10", 2, 0x1002, 1, 1,  CHG_NZV, ALL},
158ed0d50c3Schristos     {   "orh",  OP_IMM8, "10101rrriiiiiiii", 2, 0xA800, 1, 1,  CHG_NZV, ALL},
159ed0d50c3Schristos     {   "orl",  OP_IMM8, "10100rrriiiiiiii", 2, 0xA000, 1, 1,  CHG_NZV, ALL},
160ed0d50c3Schristos     {   "par",   OP_MON, "00000rrr11110101", 2, 0x00F5, 1, 1,  CHG_NZV, ALL},
161ed0d50c3Schristos     {   "rol",  OP_IMM4, "00001rrriiii1110", 2, 0x080E, 1, 1,  CHG_NZV, ALL},
162ed0d50c3Schristos     {   "rol",   OP_DYA, "00001rrrrrr10110", 2, 0x0816, 1, 1,  CHG_NZV, ALL},
163ed0d50c3Schristos     {   "ror",  OP_IMM4, "00001rrriiii1111", 2, 0x080F, 1, 1,  CHG_NZV, ALL},
164ed0d50c3Schristos     {   "ror",   OP_DYA, "00001rrrrrr10111", 2, 0x0817, 1, 1,  CHG_NZV, ALL},
165ed0d50c3Schristos     {   "rts",   OP_INH, "0000001000000000", 2, 0x0200, 2, 2, CHG_NONE, ALL},
166ed0d50c3Schristos     {   "sbc",   OP_TRI, "00011rrrrrrrrr01", 2, 0x1801, 1, 1,  CHG_NZV, ALL},
167ed0d50c3Schristos     {  "ssem",  OP_IMM3, "00000iii11110010", 2, 0x00F2, 2, 2,    CHG_C, ALL},
168ed0d50c3Schristos     {  "ssem",   OP_MON, "00000rrr11110011", 2, 0x00F3, 2, 2,    CHG_C, ALL},
169ed0d50c3Schristos     {   "sex",   OP_MON, "00000rrr11110100", 2, 0x00F4, 1, 1,  CHG_NZV, ALL},
170ed0d50c3Schristos     {   "sif",   OP_INH, "0000001100000000", 2, 0x0300, 2, 2, CHG_NONE, ALL},
171ed0d50c3Schristos     {   "sif",   OP_MON, "00000rrr11110111", 2, 0x00F7, 2, 2, CHG_NONE, ALL},
172ed0d50c3Schristos     {   "stb",  OP_IDO5, "01010rrrrrriiiii", 2, 0x5000, 2, 2, CHG_NONE, ALL},
173ed0d50c3Schristos     {   "stb",   OP_IDR, "01110rrrrrrrrrrr", 2, 0x7000, 2, 2, CHG_NONE, ALL},
174ed0d50c3Schristos     {   "stw",  OP_IDO5, "01011rrrrrriiiii", 2, 0x5800, 2, 2, CHG_NONE, ALL},
175ed0d50c3Schristos     {   "stw",   OP_IDR, "01111rrrrrrrrrrr", 2, 0x7800, 2, 2, CHG_NONE, ALL},
176ed0d50c3Schristos     {   "sub",   OP_TRI, "00011rrrrrrrrr00", 2, 0x1800, 1, 1, CHG_NZVC, ALL},
177ed0d50c3Schristos     {  "subh",  OP_IMM8, "11001rrriiiiiiii", 2, 0xC800, 1, 1, CHG_NZVC, ALL},
178ed0d50c3Schristos     {  "subl",  OP_IMM8, "11000rrriiiiiiii", 2, 0xC000, 1, 1, CHG_NZVC, ALL},
179ed0d50c3Schristos     {   "tfr",  OP_MON_R_C, "00000rrr11111000", 2, 0x00F8, 1, 1, CHG_NONE, ALL},
180ed0d50c3Schristos     {   "tfr",  OP_MON_C_R, "00000rrr11111001", 2, 0x00F9, 1, 1, CHG_NONE, ALL},
181ed0d50c3Schristos     {   "tfr",  OP_MON_R_P, "00000rrr11111010", 2, 0x00FA, 1, 1, CHG_NONE, ALL},
182ed0d50c3Schristos     {  "xnor",   OP_TRI, "00010rrrrrrrrr11", 2, 0x1003, 1, 1,  CHG_NZV, ALL},
183ed0d50c3Schristos     { "xnorh",  OP_IMM8, "10111rrriiiiiiii", 2, 0xB800, 1, 1,  CHG_NZV, ALL},
184ed0d50c3Schristos     { "xnorl",  OP_IMM8, "10110rrriiiiiiii", 2, 0xB000, 1, 1,  CHG_NZV, ALL},
185ed0d50c3Schristos     /*  macro and alias codes  */
186ed0d50c3Schristos     {   "add", OP_mADD,  "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
187ed0d50c3Schristos     {   "and", OP_mAND,  "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
188ed0d50c3Schristos     {   "bhs",  OP_REL9, "0010000iiiiiiiii", 2, 0x2000, 0, 0, CHG_NONE, ALL},
189ed0d50c3Schristos     {   "blo",  OP_REL9, "0010001iiiiiiiii", 2, 0x2200, 0, 0, CHG_NONE, ALL},
190ed0d50c3Schristos     {   "cmp",  OP_mCPC, "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
191ed0d50c3Schristos     {   "cmp",   OP_DYA, "00011sssrrrrrr00", 2, 0x1800, 0, 0, CHG_NZVC, ALL},
192ed0d50c3Schristos     {   "com",   OP_DM,  "00010rrrsssrrr11", 2, 0x1003, 0, 0, CHG_NZVC, ALL},
193ed0d50c3Schristos     {   "com",   OP_DYA, "00010rrrsssrrr11", 2, 0x1003, 0, 0,  CHG_NZV, ALL},
194ed0d50c3Schristos     {   "cpc",   OP_DYA, "00011sssrrrrrr01", 2, 0x1801, 0, 0, CHG_NZVC, ALL},
195ed0d50c3Schristos     {   "ldd",  OP_mLDW, "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
196ed0d50c3Schristos     {   "ldw",  OP_mLDW, "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
197ed0d50c3Schristos     {   "mov",   OP_DYA, "00010rrrsssrrr10", 2, 0x1002, 0, 0, CHG_NZVC, ALL},
198ed0d50c3Schristos     {   "neg",   OP_DYA, "00011rrrsssrrr00", 2, 0x1800, 0, 0, CHG_NZVC, ALL},
199ed0d50c3Schristos     {   "sub",  OP_mSUB, "----------------", 4,      0, 0, 0, CHG_NONE, ALL},
200ed0d50c3Schristos     {   "tst",   OP_MON, "00011sssrrrsss00", 2, 0x1800, 0, 0,  CHG_NZV, ALL}
201ed0d50c3Schristos };
202ed0d50c3Schristos 
203ed0d50c3Schristos const int xgate_num_opcodes = TABLE_SIZE (xgate_opcodes);
204