You can not select more than 25 topics
Topics must start with a letter or number, can include dashes ('-') and can be up to 35 characters long.
110 lines
2.8 KiB
110 lines
2.8 KiB
5 years ago
|
//global
|
||
|
`define RstEnable 1'b1
|
||
|
`define RstDisable 1'b0
|
||
|
`define ZeroWord 32'h00000000
|
||
|
`define WriteEnable 1'b1
|
||
|
`define WriteDisable 1'b0
|
||
|
`define ReadEnable 1'b1
|
||
|
`define ReadDisable 1'b0
|
||
|
`define AluOpBus 7:0
|
||
|
`define AluSelBus 2:0
|
||
|
`define InstValid 1'b0
|
||
|
`define InstInvalid 1'b1
|
||
|
`define Stop 1'b1
|
||
|
`define NoStop 1'b0
|
||
|
`define InDelaySlot 1'b1
|
||
|
`define NotInDelaySlot 1'b0
|
||
|
`define Branch 1'b1
|
||
|
`define NotBranch 1'b0
|
||
|
`define InterruptAssert 1'b1
|
||
|
`define InterruptNotAssert 1'b0
|
||
|
`define TrapAssert 1'b1
|
||
|
`define TrapNotAssert 1'b0
|
||
|
`define True_v 1'b1
|
||
|
`define False_v 1'b0
|
||
|
`define ChipEnable 1'b1
|
||
|
`define ChipDisable 1'b0
|
||
|
|
||
|
|
||
|
//instruction
|
||
|
`define EXE_ORI 6'b001101 // ORI
|
||
|
`define EXE_AND 6'b100100 // AND
|
||
|
`define EXE_OR 6'b100101 // OR
|
||
|
`define EXE_XOR 6'b100110 // XOR
|
||
|
`define EXE_NOR 6'b100111 // NOR
|
||
|
`define EXE_ANDI 6'b001100 // ANDI
|
||
|
`define EXE_ORI 6'b001101 // ORI
|
||
|
`define EXE_XORI 6'b001110 // XORI
|
||
|
`define EXE_LUI 6'b001111 // LUI
|
||
|
|
||
|
`define EXE_SLL 6'b000000 // SLL
|
||
|
`define EXE_SLLV 6'b000100 // SLLV
|
||
|
`define EXE_SRL 6'b000010 // SRL
|
||
|
`define EXE_SRLV 6'b000110 // SRLV
|
||
|
`define EXE_SRA 6'b000011 // SRA
|
||
|
`define EXE_SRAV 6'b000111 // SRAV
|
||
|
`define EXE_SYNC 6'b001111 // SYNC
|
||
|
`define EXE_PREF 6'b110011 // PREF
|
||
|
|
||
|
`define EXE_NOP 6'b000000 // NOP
|
||
|
`define EXE_SPECIAL_INST 6'b000000 // SPECIAL 类
|
||
|
|
||
|
`define EXE_MOVZ 6'b001010
|
||
|
`define EXE_MOVN 6'b001011
|
||
|
`define EXE_MFHI 6'b010000
|
||
|
`define EXE_MTHI 6'b010001
|
||
|
`define EXE_MFLO 6'b010010
|
||
|
`define EXE_MTLO 6'b010011
|
||
|
|
||
|
//AluOp
|
||
|
`define EXE_AND_OP 8'b00100100
|
||
|
`define EXE_OR_OP 8'b00100101
|
||
|
`define EXE_XOR_OP 8'b00100110
|
||
|
`define EXE_NOR_OP 8'b00100111
|
||
|
`define EXE_ANDI_OP 8'b01011001
|
||
|
`define EXE_ORI_OP 8'b01011010
|
||
|
`define EXE_XORI_OP 8'b01011011
|
||
|
`define EXE_LUI_OP 8'b01011100
|
||
|
|
||
|
`define EXE_SLL_OP 8'b01111100
|
||
|
`define EXE_SLLV_OP 8'b00000100
|
||
|
`define EXE_SRL_OP 8'b00000010
|
||
|
`define EXE_SRLV_OP 8'b00000110
|
||
|
`define EXE_SRA_OP 8'b00000011
|
||
|
`define EXE_SRAV_OP 8'b00000111
|
||
|
|
||
|
`define EXE_NOP_OP 8'b00000000
|
||
|
|
||
|
`define EXE_MOVZ_OP 8'b00001010
|
||
|
`define EXE_MOVN_OP 8'b00001011
|
||
|
`define EXE_MFHI_OP 8'b00010000
|
||
|
`define EXE_MTHI_OP 8'b00010001
|
||
|
`define EXE_MFLO_OP 8'b00010010
|
||
|
`define EXE_MTLO_OP 8'b00010011
|
||
|
|
||
|
//AluSel
|
||
|
`define EXE_RES_LOGIC 3'b001
|
||
|
`define EXE_RES_SHIFT 3'b010
|
||
|
`define EXE_RES_MOVE 3'b011
|
||
|
|
||
|
`define EXE_RES_NOP 3'b000
|
||
|
|
||
|
|
||
|
//inst_rom
|
||
|
`define InstAddrBus 31:0
|
||
|
`define InstBus 31:0
|
||
|
`define InstMemNum 131071
|
||
|
`define InstMemNumLog2 17
|
||
|
|
||
|
|
||
|
//regfile
|
||
|
`define RegAddrBus 4:0
|
||
|
`define RegBus 31:0
|
||
|
`define RegWidth 32
|
||
|
`define DoubleRegWidth 64
|
||
|
`define DoubleRegBus 63:0
|
||
|
`define RegNum 32
|
||
|
`define RegNumLog2 5
|
||
|
`define NOPRegAddr 5'b00000
|
||
|
|