aboutsummaryrefslogtreecommitdiffstats
path: root/fpga/usrp3/lib
diff options
context:
space:
mode:
authorMax Köhler <max.koehler@ni.com>2020-03-03 14:28:30 +0100
committerWade Fife <wade.fife@ettus.com>2020-03-09 13:40:17 -0500
commitb92597e1c9b6f09d5e62e55a60e33c04d437a50a (patch)
tree807bfccd4db6fd9846e3328fa6bf47eed233aad7 /fpga/usrp3/lib
parente06ff0f5e08458256bf7ffdd3d9c84c4c1046807 (diff)
downloaduhd-b92597e1c9b6f09d5e62e55a60e33c04d437a50a.tar.gz
uhd-b92597e1c9b6f09d5e62e55a60e33c04d437a50a.tar.bz2
uhd-b92597e1c9b6f09d5e62e55a60e33c04d437a50a.zip
fpga: lib: Modify for loop to Verilog 2001 syntax
This changes the for loop to use the generate keyword, making it compatible with Verilog 2001. This allows tools that only support Verilog 2001 to use this file (e.g., Intel Quartus).
Diffstat (limited to 'fpga/usrp3/lib')
-rw-r--r--fpga/usrp3/lib/rfnoc/utils/ctrlport_decoder_param.v69
1 files changed, 35 insertions, 34 deletions
diff --git a/fpga/usrp3/lib/rfnoc/utils/ctrlport_decoder_param.v b/fpga/usrp3/lib/rfnoc/utils/ctrlport_decoder_param.v
index f2f4a438c..e00c91a40 100644
--- a/fpga/usrp3/lib/rfnoc/utils/ctrlport_decoder_param.v
+++ b/fpga/usrp3/lib/rfnoc/utils/ctrlport_decoder_param.v
@@ -94,45 +94,46 @@ module ctrlport_decoder_param #(
wire [NUM_SLAVES-1:0] dec_mask; // Address decoder mask
- genvar i;
+ generate
+ genvar i;
- for (i = 0; i < NUM_SLAVES; i = i+1) begin : gen_dec_mask
- localparam [19:0] BASE_ADDR = PORT_BASE [i*20 +: 20];
- localparam [31:0] ADDR_W = PORT_ADDR_W[i*32 +: 32];
- assign dec_mask[i] = ~|((s_ctrlport_req_addr ^ BASE_ADDR) & ((~0) << ADDR_W));
- end
+ for (i = 0; i < NUM_SLAVES; i = i+1) begin : gen_dec_mask
+ localparam [19:0] BASE_ADDR = PORT_BASE [i*20 +: 20];
+ localparam [31:0] ADDR_W = PORT_ADDR_W[i*32 +: 32];
+ assign dec_mask[i] = ~|((s_ctrlport_req_addr ^ BASE_ADDR) & ((~0) << ADDR_W));
+ end
- //---------------------------------------------------------------------------
- // Split the requests among the slaves
- //---------------------------------------------------------------------------
-
- for (i = 0; i < NUM_SLAVES; i = i+1) begin : gen_split
- localparam [31:0] ADDR_W = PORT_ADDR_W[i*32 +: 32];
-
- always @(posedge ctrlport_clk) begin
- if (ctrlport_rst) begin
- m_ctrlport_req_wr[i] <= 1'b0;
- m_ctrlport_req_rd[i] <= 1'b0;
- end else begin
- // Mask WR and RD based on address decoding
- m_ctrlport_req_wr[i] <= s_ctrlport_req_wr & dec_mask[i];
- m_ctrlport_req_rd[i] <= s_ctrlport_req_rd & dec_mask[i];
-
- // Other values pass through to all slaves, but should be ignored
- // unless WR or RD is asserted.
- m_ctrlport_req_data [32*i +: 32] <= s_ctrlport_req_data;
- m_ctrlport_req_byte_en [4*i +: 4] <= s_ctrlport_req_byte_en;
- m_ctrlport_req_has_time[i] <= s_ctrlport_req_has_time;
- m_ctrlport_req_time [64*i +: 64] <= s_ctrlport_req_time;
-
- // Mask the address bits to that of the slaves address space.
- m_ctrlport_req_addr[20*i +: 20] <= 20'b0;
- m_ctrlport_req_addr[20*i +: ADDR_W] <= s_ctrlport_req_addr[ADDR_W-1 : 0];
+ //---------------------------------------------------------------------------
+ // Split the requests among the slaves
+ //---------------------------------------------------------------------------
+
+ for (i = 0; i < NUM_SLAVES; i = i+1) begin : gen_split
+ localparam [31:0] ADDR_W = PORT_ADDR_W[i*32 +: 32];
+
+ always @(posedge ctrlport_clk) begin
+ if (ctrlport_rst) begin
+ m_ctrlport_req_wr[i] <= 1'b0;
+ m_ctrlport_req_rd[i] <= 1'b0;
+ end else begin
+ // Mask WR and RD based on address decoding
+ m_ctrlport_req_wr[i] <= s_ctrlport_req_wr & dec_mask[i];
+ m_ctrlport_req_rd[i] <= s_ctrlport_req_rd & dec_mask[i];
+
+ // Other values pass through to all slaves, but should be ignored
+ // unless WR or RD is asserted.
+ m_ctrlport_req_data [32*i +: 32] <= s_ctrlport_req_data;
+ m_ctrlport_req_byte_en [4*i +: 4] <= s_ctrlport_req_byte_en;
+ m_ctrlport_req_has_time[i] <= s_ctrlport_req_has_time;
+ m_ctrlport_req_time [64*i +: 64] <= s_ctrlport_req_time;
+
+ // Mask the address bits to that of the slaves address space.
+ m_ctrlport_req_addr[20*i +: 20] <= 20'b0;
+ m_ctrlport_req_addr[20*i +: ADDR_W] <= s_ctrlport_req_addr[ADDR_W-1 : 0];
+ end
end
end
- end
-
+ endgenerate
//---------------------------------------------------------------------------
// Decode the responses