mirror of
git://projects.qi-hardware.com/nn-usb-fpga.git
synced 2025-01-10 05:00:14 +02:00
95 lines
2.2 KiB
Verilog
95 lines
2.2 KiB
Verilog
`timescale 1ns / 1ps
|
|
|
|
module reg_bank(clk, reset, en, we, wdBus, rdBus, address, reg0, reg1, reg2, reg3, reg4, regMT, error, status, max_lev, max_com, control);
|
|
|
|
input clk, reset, en, we;
|
|
|
|
input [7:0] wdBus;
|
|
output [7:0] rdBus;
|
|
input [4:0] address;
|
|
|
|
input [31:0] reg0;
|
|
input [31:0] reg1;
|
|
input [31:0] reg2;
|
|
input [31:0] reg3;
|
|
input [31:0] reg4;
|
|
input [31:0] regMT;
|
|
input [16:0] error;
|
|
input [7:0] status;
|
|
output [15:0] max_com;
|
|
output [7:0] max_lev;
|
|
output [7:0] control;
|
|
|
|
|
|
reg [7:0] reg_bank [31:0];
|
|
reg [7:0] rdBus;
|
|
|
|
|
|
|
|
// Read control
|
|
always @(posedge clk)
|
|
if(reset)
|
|
rdBus = 8'h00;
|
|
else begin
|
|
rdBus = reg_bank[address];
|
|
end
|
|
|
|
// Store Inputs
|
|
always @(posedge clk)
|
|
begin
|
|
if(en) begin
|
|
reg_bank[0] = reg0[7:0];
|
|
reg_bank[1] = reg0[15:8];
|
|
reg_bank[2] = reg0[23:16];
|
|
reg_bank[3] = reg0[31:24];
|
|
|
|
reg_bank[4] = reg1[7:0];
|
|
reg_bank[5] = reg1[15:8];
|
|
reg_bank[6] = reg1[23:16];
|
|
reg_bank[7] = reg1[31:24];
|
|
|
|
reg_bank[8] = reg2[7:0];
|
|
reg_bank[9] = reg2[15:8];
|
|
reg_bank[10] = reg2[23:16];
|
|
reg_bank[11] = reg2[31:24];
|
|
|
|
reg_bank[12] = reg3[7:0];
|
|
reg_bank[13] = reg3[15:8];
|
|
reg_bank[14] = reg3[23:16];
|
|
reg_bank[15] = reg3[31:24];
|
|
|
|
reg_bank[16] = reg4[7:0];
|
|
reg_bank[17] = reg4[15:8];
|
|
reg_bank[18] = reg4[23:16];
|
|
reg_bank[19] = reg4[31:24];
|
|
|
|
reg_bank[20] = error[7:0];
|
|
reg_bank[21] = error[15:8];
|
|
|
|
reg_bank[22] = {4'b0, status};
|
|
|
|
// reg_bank[23] = regMT[7:0];
|
|
// reg_bank[24] = regMT[15:8];
|
|
// reg_bank[25] = regMT[23:16];
|
|
// reg_bank[26] = regMT[31:24];
|
|
end
|
|
end
|
|
|
|
assign max_com[7:0] = reg_bank[26];
|
|
assign max_com[15:8] = reg_bank[27];
|
|
assign max_lev = reg_bank[28];
|
|
assign control = reg_bank[29];
|
|
|
|
// Write control
|
|
always @(negedge clk)
|
|
if(we & en) begin
|
|
case (address)
|
|
27: reg_bank[26] = wdBus;
|
|
28: reg_bank[27] = wdBus;
|
|
29: reg_bank[28] = wdBus;
|
|
30: reg_bank[29] = wdBus;
|
|
endcase
|
|
end
|
|
|
|
endmodule
|