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