2023-10-26 07:36:32 +00:00
|
|
|
module memory (input clock, reset,
|
|
|
|
input we,
|
|
|
|
input [1:0] func_in,
|
|
|
|
input [2:0] func_out,
|
|
|
|
input [31:0] address,
|
|
|
|
input [31:0] data_in,
|
|
|
|
output reg [31:0] data_out);
|
|
|
|
|
|
|
|
`include "mem_func.vh"
|
2023-10-20 09:48:18 +00:00
|
|
|
|
2023-10-25 02:07:19 +00:00
|
|
|
reg [7:0] memory [127:0];
|
2023-10-20 09:48:18 +00:00
|
|
|
|
2023-10-22 13:41:39 +00:00
|
|
|
always @(posedge clock, posedge reset) begin
|
2023-10-20 09:48:18 +00:00
|
|
|
if (reset == 1)
|
2023-10-24 12:52:07 +00:00
|
|
|
memory[0] <= 8'b0;
|
2023-10-26 07:36:32 +00:00
|
|
|
else if (we == 1) begin
|
|
|
|
case (func_in)
|
|
|
|
SB : begin
|
|
|
|
memory[address] <= data_in[7:0];
|
|
|
|
end
|
|
|
|
SH : begin
|
|
|
|
memory[address] <= data_in[7:0];
|
|
|
|
memory[address + 1] <= data_in[15:8];
|
|
|
|
end
|
|
|
|
SW : begin
|
|
|
|
memory[address] <= data_in[7:0];
|
|
|
|
memory[address + 1] <= data_in[15:8];
|
|
|
|
memory[address + 2] <= data_in[23:16];
|
|
|
|
memory[address + 3] <= data_in[31:24];
|
|
|
|
end
|
|
|
|
endcase
|
|
|
|
end
|
2023-10-20 09:48:18 +00:00
|
|
|
end
|
|
|
|
|
2023-10-26 07:36:32 +00:00
|
|
|
always @(*) begin
|
|
|
|
case (func_out)
|
|
|
|
LB : data_out <= {(memory[address][7] == 1'b1 ? 24'b111111111111111111111111 : 24'b000000000000000000000000), memory[address]};
|
|
|
|
LH : data_out <= {(memory[address][15] == 1'b1 ? 16'b1111111111111111 : 16'b0000000000000000), memory[address], memory[address]};
|
|
|
|
LW : data_out <= {memory[address + 3], memory[address + 2], memory[address + 1], memory[address]};
|
|
|
|
LBU : data_out <= {24'b000000000000000000000000, memory[address]};
|
|
|
|
LHU : data_out <= {16'b0000000000000000, memory[address]};
|
|
|
|
default : data_out <= 32'b00000000000000000000000000000000;
|
|
|
|
endcase
|
|
|
|
end
|
2023-10-20 09:48:18 +00:00
|
|
|
|
|
|
|
endmodule
|