Skip to content

Commit

Permalink
library:axi_ad7616: Updates for a functional testbench
Browse files Browse the repository at this point in the history
Signed-off-by: Pop Ioan Daniel <pop.ioan-daniel@analog.com>
  • Loading branch information
PIoandan committed Oct 4, 2024
1 parent 0b52caa commit 365cdd3
Show file tree
Hide file tree
Showing 2 changed files with 51 additions and 30 deletions.
4 changes: 2 additions & 2 deletions library/axi_ad7616/axi_ad7616.v
Original file line number Diff line number Diff line change
Expand Up @@ -169,7 +169,7 @@ module axi_ad7616 #(
wire up_wreq_s;
wire [13:0] up_waddr_s;
wire [31:0] up_wdata_s;
wire [31:0] up_rdata_s[0:16]; // 8 || 16 ?????
wire [31:0] up_rdata_s[0:16];
wire [16:0] up_rack_s;
wire [16:0] up_wack_s;

Expand Down Expand Up @@ -226,7 +226,7 @@ module axi_ad7616 #(
up_rdata_r = 'h00;
up_rack_r = 'h00;
up_wack_r = 'h00;
for (j = 0; j <= 16; j=j+1) begin // ??? <= 16 ?????
for (j = 0; j <= 16; j=j+1) begin
up_rack_r = up_rack_r | up_rack_s[j];
up_wack_r = up_wack_r | up_wack_s[j];
up_rdata_r = up_rdata_r | up_rdata_s[j];
Expand Down
77 changes: 49 additions & 28 deletions library/axi_ad7616/axi_ad7616_pif.v
Original file line number Diff line number Diff line change
@@ -1,6 +1,6 @@
// ***************************************************************************
// ***************************************************************************
// Copyright (C) 2014-2023 Analog Devices, Inc. All rights reserved.
// Copyright (C) 2014-2024 Analog Devices, Inc. All rights reserved.
//
// In this HDL repository, there are many different and unique modules, consisting
// of various HDL (Verilog or VHDL) components. The individual modules are
Expand Down Expand Up @@ -51,22 +51,22 @@ module axi_ad7616_pif #(

// FIFO interface

output reg [15:0] adc_data_0,
output reg [15:0] adc_data_1,
output reg [15:0] adc_data_2,
output reg [15:0] adc_data_3,
output reg [15:0] adc_data_4,
output reg [15:0] adc_data_5,
output reg [15:0] adc_data_6,
output reg [15:0] adc_data_7,
output reg [15:0] adc_data_8,
output reg [15:0] adc_data_9,
output reg [15:0] adc_data_10,
output reg [15:0] adc_data_11,
output reg [15:0] adc_data_12,
output reg [15:0] adc_data_13,
output reg [15:0] adc_data_14,
output reg [15:0] adc_data_15,
output reg [15:0] adc_data_0 = 16'b0,
output reg [15:0] adc_data_1 = 16'b0,
output reg [15:0] adc_data_2 = 16'b0,
output reg [15:0] adc_data_3 = 16'b0,
output reg [15:0] adc_data_4 = 16'b0,
output reg [15:0] adc_data_5 = 16'b0,
output reg [15:0] adc_data_6 = 16'b0,
output reg [15:0] adc_data_7 = 16'b0,
output reg [15:0] adc_data_8 = 16'b0,
output reg [15:0] adc_data_9 = 16'b0,
output reg [15:0] adc_data_10 = 16'b0,
output reg [15:0] adc_data_11 = 16'b0,
output reg [15:0] adc_data_12 = 16'b0,
output reg [15:0] adc_data_13 = 16'b0,
output reg [15:0] adc_data_14 = 16'b0,
output reg [15:0] adc_data_15 = 16'b0,

output adc_valid,

Expand All @@ -82,7 +82,7 @@ module axi_ad7616_pif #(
input rd_req,
input wr_req,
input [15:0] wr_data,
output reg [15:0] rd_data = 'hf,
output reg [15:0] rd_data = 'ha1b2,
output reg rd_valid
);

Expand Down Expand Up @@ -113,12 +113,18 @@ module axi_ad7616_pif #(

reg [ 4:0] channel_counter = 5'h0;
reg [ 4:0] nr_rd_burst = 5'd16;
reg wr_req_edge = 1'h0;
reg wr_req_edge_d = 1'h0;
reg rd_req_edge = 1'h0;
reg rd_req_edge_d = 1'h0;

// internal wires

wire rd_new_data_s;
wire start_transfer_s;
wire rd_valid_s;
wire adc_valid_d;
reg adc_valid_s = 1'h0;

// FSM state register

Expand Down Expand Up @@ -157,14 +163,23 @@ module axi_ad7616_pif #(
end
end

always @(negedge clk) begin
if (transfer_state == IDLE) begin
always @(posedge clk) begin
wr_req_d <= wr_req;
wr_req_edge <= (wr_req && !wr_req_d);
rd_req_d <= rd_req;
rd_req_edge <= (rd_req && !rd_req_d);
if (transfer_state == IDLE) begin
rd_conv_d <= end_of_conv;
end
end

//delay with 1 clk

always @(posedge clk) begin
wr_req_edge_d <= wr_req_edge;
rd_req_edge_d <= rd_req_edge;
end

//channel_counter

always @(posedge clk) begin
Expand Down Expand Up @@ -249,7 +264,7 @@ module axi_ad7616_pif #(
end
CNTRL0_HIGH : begin
transfer_state_next <= (width_counter != 2'b11) ? CNTRL0_HIGH :
((wr_req_d == 1'b1) || (rd_req_d == 1'b1)) ? CS_HIGH : CNTRL1_LOW;
((wr_req_edge_d == 1'b1) || (rd_req_edge_d == 1'b1)) ? CS_HIGH : CNTRL1_LOW;
end
CNTRL1_LOW : begin
transfer_state_next <= (width_counter != 2'b11) ? CNTRL1_LOW : CNTRL1_HIGH;
Expand All @@ -269,7 +284,7 @@ module axi_ad7616_pif #(
// data valid for the register access and m_axis interface

assign rd_valid_s = (((transfer_state == CNTRL0_HIGH) || (transfer_state == CNTRL1_HIGH)) &&
((rd_req_d == 1'b1) || (rd_conv_d == 1'b1))) ? 1'b1 : 1'b0;
((rd_req_edge_d == 1'b1) || (rd_conv_d == 1'b1))) ? 1'b1 : 1'b0;

// FSM output logic

Expand All @@ -283,13 +298,19 @@ module axi_ad7616_pif #(
rd_valid <= rd_valid_s & ~rd_valid_d;
end

//assign adc_valid = rd_valid;
assign adc_valid = (channel_counter == 5'd16) ? rd_valid : 1'b0;
assign adc_valid_d = (channel_counter == 5'd16) ? rd_valid : 1'b0;

//delay with 1 clk

always @(posedge clk) begin
adc_valid_s <= adc_valid_d;
end

assign cs_n = (transfer_state == IDLE) ? 1'b1 : 1'b0;
assign db_t = ~wr_req_d;
assign rd_n = (((transfer_state == CNTRL0_LOW) && ((rd_conv_d == 1'b1) || rd_req_d == 1'b1)) ||
assign adc_valid = adc_valid_s;
assign cs_n = (transfer_state == IDLE) || (rd_n == 1'b1) ? 1'b1 : 1'b0;
assign db_t = ~wr_req_edge_d;
assign rd_n = (((transfer_state == CNTRL0_LOW) && ((rd_conv_d == 1'b1) || rd_req_edge_d == 1'b1)) ||
(transfer_state == CNTRL1_LOW)) ? 1'b0 : 1'b1;
assign wr_n = ((transfer_state == CNTRL0_LOW) && (wr_req_d == 1'b1)) ? 1'b0 : 1'b1;
assign wr_n = ((transfer_state == CNTRL0_LOW) && (wr_req_edge_d == 1'b1)) ? 1'b0 : 1'b1;

endmodule

0 comments on commit 365cdd3

Please sign in to comment.