2019-03-02 19:40:31 +01:00
|
|
|
`ifndef _DEF_ALU
|
|
|
|
`define _DEF_ALU
|
|
|
|
|
|
|
|
// stuff (where should that go ?)
|
|
|
|
`define T_SET 0
|
|
|
|
`define T_TEST 1
|
|
|
|
|
|
|
|
`define T_DIR_OUT 0
|
|
|
|
`define T_DIR_IN 1
|
|
|
|
|
|
|
|
`define T_PTR_0 0
|
|
|
|
`define T_PTR_1 1
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Opcodes for the ALU
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
// copy / exchange
|
|
|
|
`define ALU_OP_ZERO 0
|
|
|
|
`define ALU_OP_COPY 1
|
|
|
|
`define ALU_OP_EXCH 2
|
|
|
|
// shifts
|
|
|
|
`define ALU_OP_SHL 3
|
|
|
|
`define ALU_OP_SHR 4
|
|
|
|
// logic
|
|
|
|
`define ALU_OP_AND 5
|
|
|
|
`define ALU_OP_OR 6
|
|
|
|
// bit set/reset
|
|
|
|
`define ALU_OP_RST_BIT 7
|
|
|
|
`define ALU_OP_SET_BIT 8
|
|
|
|
// arithmetic
|
|
|
|
`define ALU_OP_2CMPL 9
|
|
|
|
`define ALU_OP_1CMPL 10
|
|
|
|
`define ALU_OP_INC 11
|
|
|
|
`define ALU_OP_DEC 12
|
|
|
|
`define ALU_OP_ADD 13
|
|
|
|
`define ALU_OP_SUB 14
|
|
|
|
// tests
|
|
|
|
`define ALU_OP_TEST_EQ 15
|
|
|
|
`define ALU_OP_TEST_NEQ 16
|
|
|
|
// relative jump
|
|
|
|
`define ALU_OP_JMP_REL2 17
|
|
|
|
`define ALU_OP_JMP_REL3 18
|
|
|
|
`define ALU_OP_JMP_REL4 19
|
|
|
|
`define ALU_OP_JMP_ABS5 20
|
|
|
|
`define ALU_OP_CLR_MASK 21
|
|
|
|
|
|
|
|
`define ALU_OP_TEST_GO 30
|
|
|
|
`define ALU_OP_NOP 31
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* Registers
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
|
|
|
`define ALU_REG_A 0
|
|
|
|
`define ALU_REG_B 1
|
|
|
|
`define ALU_REG_C 2
|
|
|
|
`define ALU_REG_D 3
|
|
|
|
`define ALU_REG_D0 4
|
|
|
|
`define ALU_REG_D1 5
|
|
|
|
`define ALU_REG_PC 6
|
|
|
|
`define ALU_REG_RSTK 7
|
|
|
|
`define ALU_REG_R0 8
|
|
|
|
`define ALU_REG_R1 9
|
|
|
|
`define ALU_REG_R2 10
|
|
|
|
`define ALU_REG_R3 11
|
|
|
|
`define ALU_REG_R4 12
|
|
|
|
//13
|
|
|
|
//14
|
|
|
|
//15
|
|
|
|
`define ALU_REG_DAT0 16
|
|
|
|
`define ALU_REG_DAT1 17
|
|
|
|
`define ALU_REG_HST 18
|
|
|
|
`define ALU_REG_ST 19
|
|
|
|
`define ALU_REG_P 20
|
|
|
|
`define ALU_REG_M 21
|
|
|
|
`define ALU_REG_IMM 22
|
|
|
|
`define ALU_REG_ADDR 23
|
|
|
|
|
|
|
|
`define ALU_REG_ZERO 30
|
|
|
|
`define ALU_REG_NONE 31
|
|
|
|
|
|
|
|
// specific bits
|
|
|
|
`define ALU_HST_XM 0
|
|
|
|
`define ALU_HST_SB 1
|
|
|
|
`define ALU_HST_SR 2
|
|
|
|
`define ALU_HST_MP 3
|
|
|
|
|
|
|
|
/*
|
|
|
|
*
|
|
|
|
* instruction types
|
|
|
|
*
|
|
|
|
*/
|
|
|
|
|
2019-03-03 22:38:56 +01:00
|
|
|
|
2019-03-04 10:53:37 +01:00
|
|
|
`define INSTR_TYPE_NOP 0
|
|
|
|
`define INSTR_TYPE_ALU 1
|
|
|
|
`define INSTR_TYPE_SET_MODE 2
|
|
|
|
`define INSTR_TYPE_JUMP 3
|
2019-03-04 13:28:08 +01:00
|
|
|
`define INSTR_TYPE_LOAD 4
|
|
|
|
`define INSTR_TYPE_RESET 5
|
2019-03-02 19:40:31 +01:00
|
|
|
|
2019-03-04 10:53:37 +01:00
|
|
|
`define INSTR_TYPE_NONE 15
|
2019-03-02 21:45:38 +01:00
|
|
|
|
2019-03-02 19:40:31 +01:00
|
|
|
`endif
|