]> Joshua Wise's Git repositories - firearm.git/blame - RegFile.v
Memory: Move all bus control logic to its own always block.
[firearm.git] / RegFile.v
CommitLineData
23c6da6c
JW
1module RegFile(
2 input clk,
a4f724e6 3 input Nrst,
821617bb 4 input [3:0] read_0,
f5f16509 5 output wire [31:0] rdata_0,
23c6da6c 6 input [3:0] read_1,
f5f16509 7 output wire [31:0] rdata_1,
23c6da6c 8 input [3:0] read_2,
f5f16509 9 output wire [31:0] rdata_2,
b3bb2fb8 10 input [3:0] read_3,
f5f16509
JW
11 output wire [31:0] rdata_3,
12 output wire [31:0] spsr,
ab7ee9fc
JW
13 input write,
14 input [3:0] write_reg,
23c6da6c
JW
15 input [31:0] write_data
16 );
17
18 reg [31:0] regfile [0:15];
a4f724e6 19 integer i;
23c6da6c
JW
20
21 initial begin
a4f724e6
JW
22 for (i = 0; i < 16; i = i + 1)
23 regfile[i] = 0;
23c6da6c
JW
24 end
25
f5f16509
JW
26 assign rdata_0 = ((read_0 == write_reg) && write) ? write_data : regfile[read_0];
27 assign rdata_1 = ((read_1 == write_reg) && write) ? write_data : regfile[read_1];
28 assign rdata_2 = ((read_2 == write_reg) && write) ? write_data : regfile[read_2];
29 assign rdata_3 = ((read_3 == write_reg) && write) ? write_data : regfile[read_3];
30 assign spsr = regfile[4'hF];
23c6da6c 31
a4f724e6
JW
32 always @(posedge clk or negedge Nrst)
33 if (!Nrst) begin
34 for (i = 0; i < 16; i = i + 1)
35 regfile[i] <= 0;
36 end else if (write)
ab7ee9fc 37 regfile[write_reg] <= write_data;
23c6da6c 38endmodule
This page took 0.045326 seconds and 4 git commands to generate.