|  | /* | 
|  | *  CRISv10 insn decoding macros. | 
|  | * | 
|  | *  Copyright (c) 2010 AXIS Communications AB | 
|  | *  Written by Edgar E. Iglesias. | 
|  | * | 
|  | * This library is free software; you can redistribute it and/or | 
|  | * modify it under the terms of the GNU Lesser General Public | 
|  | * License as published by the Free Software Foundation; either | 
|  | * version 2 of the License, or (at your option) any later version. | 
|  | * | 
|  | * This library is distributed in the hope that it will be useful, | 
|  | * but WITHOUT ANY WARRANTY; without even the implied warranty of | 
|  | * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU | 
|  | * Lesser General Public License for more details. | 
|  | * | 
|  | * You should have received a copy of the GNU Lesser General Public | 
|  | * License along with this library; if not, see <http://www.gnu.org/licenses/>. | 
|  | */ | 
|  |  | 
|  | #define CRISV10_MODE_QIMMEDIATE  0 | 
|  | #define CRISV10_MODE_REG         1 | 
|  | #define CRISV10_MODE_INDIRECT    2 | 
|  | #define CRISV10_MODE_AUTOINC     3 | 
|  |  | 
|  | /* Quick Immediate.  */ | 
|  | #define CRISV10_QIMM_BCC_R0      0 | 
|  | #define CRISV10_QIMM_BCC_R1      1 | 
|  | #define CRISV10_QIMM_BCC_R2      2 | 
|  | #define CRISV10_QIMM_BCC_R3      3 | 
|  |  | 
|  | #define CRISV10_QIMM_BDAP_R0     4 | 
|  | #define CRISV10_QIMM_BDAP_R1     5 | 
|  | #define CRISV10_QIMM_BDAP_R2     6 | 
|  | #define CRISV10_QIMM_BDAP_R3     7 | 
|  |  | 
|  | #define CRISV10_QIMM_ADDQ        8 | 
|  | #define CRISV10_QIMM_MOVEQ       9 | 
|  | #define CRISV10_QIMM_SUBQ       10 | 
|  | #define CRISV10_QIMM_CMPQ       11 | 
|  | #define CRISV10_QIMM_ANDQ       12 | 
|  | #define CRISV10_QIMM_ORQ        13 | 
|  | #define CRISV10_QIMM_ASHQ       14 | 
|  | #define CRISV10_QIMM_LSHQ       15 | 
|  |  | 
|  |  | 
|  | #define CRISV10_REG_ADDX         0 | 
|  | #define CRISV10_REG_MOVX         1 | 
|  | #define CRISV10_REG_SUBX         2 | 
|  | #define CRISV10_REG_LSL          3 | 
|  | #define CRISV10_REG_ADDI         4 | 
|  | #define CRISV10_REG_BIAP         5 | 
|  | #define CRISV10_REG_NEG          6 | 
|  | #define CRISV10_REG_BOUND        7 | 
|  | #define CRISV10_REG_ADD          8 | 
|  | #define CRISV10_REG_MOVE_R       9 | 
|  | #define CRISV10_REG_MOVE_SPR_R   9 | 
|  | #define CRISV10_REG_MOVE_R_SPR   8 | 
|  | #define CRISV10_REG_SUB         10 | 
|  | #define CRISV10_REG_CMP         11 | 
|  | #define CRISV10_REG_AND         12 | 
|  | #define CRISV10_REG_OR          13 | 
|  | #define CRISV10_REG_ASR         14 | 
|  | #define CRISV10_REG_LSR         15 | 
|  |  | 
|  | #define CRISV10_REG_BTST         3 | 
|  | #define CRISV10_REG_SCC          4 | 
|  | #define CRISV10_REG_SETF         6 | 
|  | #define CRISV10_REG_CLEARF       7 | 
|  | #define CRISV10_REG_BIAP         5 | 
|  | #define CRISV10_REG_ABS         10 | 
|  | #define CRISV10_REG_DSTEP       11 | 
|  | #define CRISV10_REG_LZ          12 | 
|  | #define CRISV10_REG_NOT         13 | 
|  | #define CRISV10_REG_SWAP        13 | 
|  | #define CRISV10_REG_XOR         14 | 
|  | #define CRISV10_REG_MSTEP       15 | 
|  |  | 
|  | /* Indirect, var size.  */ | 
|  | #define CRISV10_IND_TEST        14 | 
|  | #define CRISV10_IND_MUL          4 | 
|  | #define CRISV10_IND_BDAP_M       5 | 
|  | #define CRISV10_IND_ADD          8 | 
|  | #define CRISV10_IND_MOVE_M_R     9 | 
|  |  | 
|  |  | 
|  | /* indirect fixed size.  */ | 
|  | #define CRISV10_IND_ADDX         0 | 
|  | #define CRISV10_IND_MOVX         1 | 
|  | #define CRISV10_IND_SUBX         2 | 
|  | #define CRISV10_IND_CMPX         3 | 
|  | #define CRISV10_IND_JUMP_M       4 | 
|  | #define CRISV10_IND_DIP          5 | 
|  | #define CRISV10_IND_JUMP_R       6 | 
|  | #define CRISV10_IND_BOUND        7 | 
|  | #define CRISV10_IND_BCC_M        7 | 
|  | #define CRISV10_IND_MOVE_M_SPR   8 | 
|  | #define CRISV10_IND_MOVE_SPR_M   9 | 
|  | #define CRISV10_IND_SUB         10 | 
|  | #define CRISV10_IND_CMP         11 | 
|  | #define CRISV10_IND_AND         12 | 
|  | #define CRISV10_IND_OR          13 | 
|  | #define CRISV10_IND_MOVE_R_M    15 | 
|  |  | 
|  | #define CRISV10_IND_MOVEM_M_R    14 | 
|  | #define CRISV10_IND_MOVEM_R_M    15 | 
|  |  |