aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib
diff options
context:
space:
mode:
Diffstat (limited to 'fpga/usrp3/lib')
-rw-r--r--fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rfnoc_block_radio.v78
1 files changed, 62 insertions, 16 deletions
diff --git a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rfnoc_block_radio.v b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rfnoc_block_radio.v
index c3a9efa7d..2fc8c5768 100644
--- a/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rfnoc_block_radio.v
+++ b/fpga/usrp3/lib/rfnoc/blocks/rfnoc_block_radio/rfnoc_block_radio.v
@@ -262,8 +262,8 @@ module rfnoc_block_radio #(
wire [ 3:0] ctrlport_shared_req_byte_en;
wire ctrlport_shared_req_has_time;
wire [63:0] ctrlport_shared_req_time;
- reg ctrlport_shared_resp_ack = 1'b0;
- reg [31:0] ctrlport_shared_resp_data = 0;
+ wire ctrlport_shared_resp_ack;
+ wire [31:0] ctrlport_shared_resp_data;
wire ctrlport_core_req_wr;
wire ctrlport_core_req_rd;
@@ -422,6 +422,54 @@ module rfnoc_block_radio #(
//---------------------------------------------------------------------------
+ // Control Port Timer for Shared Registers
+ //---------------------------------------------------------------------------
+ //
+ // Makes sure shared register access waits for the time if one is provided.
+ // This allows timed command packets to be tested by reading the time using
+ // command packets with a time supplied.
+ //
+ //---------------------------------------------------------------------------
+
+ wire ctrlport_timer_req_rd;
+ wire [19:0] ctrlport_timer_req_addr;
+ reg ctrlport_timer_resp_ack = 1'b0;
+ reg [31:0] ctrlport_timer_resp_data = 0;
+
+ ctrlport_timer ctrlport_timer_i (
+ // Clocks and Resets
+ .clk(radio_clk),
+ .rst(radio_rst),
+ // Timestamp (synchronous to radio_clk)
+ .time_now(radio_time),
+ .time_now_stb(1'b1),
+ .time_ignore_bits($clog2(NIPC)),
+ // Control Port Master (Request)
+ .s_ctrlport_req_wr(ctrlport_shared_req_wr),
+ .s_ctrlport_req_rd(ctrlport_shared_req_rd),
+ .s_ctrlport_req_addr(ctrlport_shared_req_addr),
+ .s_ctrlport_req_data(ctrlport_shared_req_data),
+ .s_ctrlport_req_byte_en(ctrlport_shared_req_byte_en),
+ .s_ctrlport_req_has_time(ctrlport_shared_req_has_time),
+ .s_ctrlport_req_time(ctrlport_shared_req_time),
+ // Control Port Slave (Response)
+ .s_ctrlport_resp_ack(ctrlport_shared_resp_ack),
+ .s_ctrlport_resp_status(),
+ .s_ctrlport_resp_data(ctrlport_shared_resp_data),
+ // Control Port Master (Request)
+ .m_ctrlport_req_wr(),
+ .m_ctrlport_req_rd(ctrlport_timer_req_rd),
+ .m_ctrlport_req_addr(ctrlport_timer_req_addr),
+ .m_ctrlport_req_data(),
+ .m_ctrlport_req_byte_en(),
+ // Control Port Master (Response)
+ .m_ctrlport_resp_ack(ctrlport_timer_resp_ack),
+ .m_ctrlport_resp_status(2'b00),
+ .m_ctrlport_resp_data(ctrlport_timer_resp_data)
+ );
+
+
+ //---------------------------------------------------------------------------
// Shared Registers
//---------------------------------------------------------------------------
//
@@ -436,29 +484,27 @@ module rfnoc_block_radio #(
always @(posedge radio_clk) begin
if (radio_rst) begin
- ctrlport_shared_resp_ack <= 0;
- ctrlport_shared_resp_data <= 0;
- radio_time_hi <= 32'h0;
+ ctrlport_timer_resp_ack <= 0;
+ ctrlport_timer_resp_data <= 0;
+ radio_time_hi <= 32'h0;
end else begin
// Default assignments
- ctrlport_shared_resp_ack <= 0;
- ctrlport_shared_resp_data <= 0;
+ ctrlport_timer_resp_ack <= 0;
+ ctrlport_timer_resp_data <= 0;
// Handle register reads
- if (ctrlport_shared_req_rd) begin
- case (ctrlport_shared_req_addr)
+ if (ctrlport_timer_req_rd) begin
+ ctrlport_timer_resp_ack <= 1;
+ case (ctrlport_timer_req_addr)
REG_COMPAT_NUM: begin
- ctrlport_shared_resp_ack <= 1;
- ctrlport_shared_resp_data <= { compat_major, compat_minor };
+ ctrlport_timer_resp_data <= { compat_major, compat_minor };
end
REG_TIME_LO: begin
- ctrlport_shared_resp_ack <= 1;
- ctrlport_shared_resp_data <= radio_time[31:0];
- radio_time_hi <= radio_time[63:32];
+ ctrlport_timer_resp_data <= radio_time[31:0];
+ radio_time_hi <= radio_time[63:32];
end
REG_TIME_HI: begin
- ctrlport_shared_resp_ack <= 1;
- ctrlport_shared_resp_data <= radio_time_hi;
+ ctrlport_timer_resp_data <= radio_time_hi;
end
endcase
end