-
Notifications
You must be signed in to change notification settings - Fork 2
/
Copy pathMemory.v.bak
24 lines (24 loc) · 911 Bytes
/
Memory.v.bak
1
2
3
4
5
6
7
8
9
10
11
12
13
14
15
16
17
18
19
20
21
22
23
24
module Memory(
input Mem_Wr_en,
input [31:0]Instr_Addr, Data_Addr,
input [31:0]Din,
output [31:0]Inst, Dout
);
reg [7:0] ram[32:0];
integer i;
initial
begin
for (i=0;i<32;i=i+1)
ram[i]=8'b0;
//add R3=R1(7ffffffe)+R2(2) 溢出 R3应该保持不变
{ram[3],ram[2],ram[1],ram[0]}=32'b00000000001000100001100000100000;
//addi R3=R1(7ffffffe)+4 溢出 R3应该保持不变
{ram[7],ram[6],ram[5],ram[4]}=32'b00100000001000110000000000000100;
//addiu R3=R1+4 R3应等于80000002 无溢出,存入R3
{ram[11],ram[10],ram[9],ram[8]}=32'b00100100001000110000000000000100;
end
assign {ram[Data_Addr+3],ram[Data_Addr+2],ram[Data_Addr+1],ram[Data_Addr]}=
(Mem_Wr_en==1)?Din:{ram[Data_Addr+3],ram[Data_Addr+2],ram[Data_Addr+1],ram[Data_Addr]};
assign Inst={ram[Instr_Addr+3],ram[Instr_Addr+2],ram[Instr_Addr+1],ram[Instr_Addr]};
assign Dout={ram[Data_Addr+3],ram[Data_Addr+2],ram[Data_Addr+1],ram[Data_Addr]};
endmodule