New RF with Evaluation
This commit is contained in:
33
rtl/byte_enabled_simple_dual_port_ram.v
Normal file
33
rtl/byte_enabled_simple_dual_port_ram.v
Normal file
@@ -0,0 +1,33 @@
|
||||
|
||||
`include "VX_define.v"
|
||||
|
||||
|
||||
module byte_enabled_simple_dual_port_ram
|
||||
(
|
||||
input we, clk,
|
||||
input wire[4:0] waddr, raddr,
|
||||
input wire[`NT_M1:0] be,
|
||||
input wire[`NT_M1:0][31:0] wdata,
|
||||
output reg[`NT_M1:0][31:0] q
|
||||
);
|
||||
|
||||
// Thread Byte Bit
|
||||
logic [`NT_M1:0][3:0][7:0] GPR[31:0];
|
||||
always_ff@(posedge clk) begin
|
||||
if(we) begin
|
||||
integer thread_ind;
|
||||
for (thread_ind = 0; thread_ind <= `NT_M1; thread_ind = thread_ind + 1) begin
|
||||
if(be[thread_ind]) GPR[waddr][thread_ind][0] <= wdata[thread_ind][7:0];
|
||||
if(be[thread_ind]) GPR[waddr][thread_ind][1] <= wdata[thread_ind][15:8];
|
||||
if(be[thread_ind]) GPR[waddr][thread_ind][2] <= wdata[thread_ind][23:16];
|
||||
if(be[thread_ind]) GPR[waddr][thread_ind][3] <= wdata[thread_ind][31:24];
|
||||
end
|
||||
end
|
||||
end
|
||||
|
||||
|
||||
always_ff@(negedge clk) begin
|
||||
q <= GPR[raddr];
|
||||
end
|
||||
|
||||
endmodule
|
||||
Reference in New Issue
Block a user