diff options
author | Andrew Moch <Andrew.Moch@ni.com> | 2020-06-25 22:21:52 +0100 |
---|---|---|
committer | Wade Fife <wade.fife@ettus.com> | 2020-06-26 10:36:37 -0500 |
commit | c718faf3387a07a9a1b86ab473f6ed7ac4cb493a (patch) | |
tree | 19ffdae3080f4b83df26a575c96d7a48d697e376 /fpga/usrp3/lib/axi4lite_sv | |
parent | c3bca6c87700054c96320de119a58f6a688dbd5a (diff) | |
download | uhd-c718faf3387a07a9a1b86ab473f6ed7ac4cb493a.tar.gz uhd-c718faf3387a07a9a1b86ab473f6ed7ac4cb493a.tar.bz2 uhd-c718faf3387a07a9a1b86ab473f6ed7ac4cb493a.zip |
fpga: lib: Add features to axi_lite.vh
Contains a fix for the AXI4LITE_ASSIGN macro, and adds
AXI4LITE_PORT_ASSIGN, AXI4LITE_PORT_ASSIGN_NR, and
AXI4LITE_DEBUG_ASSIGN macros.
Diffstat (limited to 'fpga/usrp3/lib/axi4lite_sv')
-rw-r--r-- | fpga/usrp3/lib/axi4lite_sv/axi_lite.vh | 85 |
1 files changed, 62 insertions, 23 deletions
diff --git a/fpga/usrp3/lib/axi4lite_sv/axi_lite.vh b/fpga/usrp3/lib/axi4lite_sv/axi_lite.vh index b260a1b24..a1773d4b0 100644 --- a/fpga/usrp3/lib/axi4lite_sv/axi_lite.vh +++ b/fpga/usrp3/lib/axi4lite_sv/axi_lite.vh @@ -3,41 +3,80 @@ // // SPDX-License-Identifier: LGPL-3.0-or-later // -// Header File: axi_lite.vh -// Description: Macros for use with AXI4S +// Header File: axi_lite.vh +// Description: Macros for use with AXI4-Lite // //----------------------------------------------------------------------------- -// Unidirectional AXI4-Stream interface +// AXI4-Lite //----------------------------------------------------------------------------- -// Macro that drives o from i for all fields. Of course, ready runs in the +// Macro that drives o from i for all fields. Of course ready runs in the // counter direction. - `define AXI4LITE_ASSIGN(O,I) \ - /* write address channel */ + /* write address channel */\ ``O.awaddr = ``I.awaddr;\ ``O.awvalid = ``I.awvalid;\ ``I.awready = ``O.awready;\ - /* write data channel */ + /* write data channel */\ ``O.wdata = ``I.wdata;\ ``O.wstrb = ``I.wstrb;\ ``O.wvalid = ``I.wvalid;\ ``I.wready = ``O.wready;\ - /* write resp channel */ + /* write resp channel */\ ``I.bresp = ``O.bresp;\ ``I.bvalid = ``O.bvalid;\ ``O.bready = ``I.bready;\ - /* read address channel */ + /* read address channel */\ ``O.araddr = ``I.araddr;\ ``O.arvalid = ``I.arvalid;\ ``I.arready = ``O.arready;\ - /* read resp channel */ + /* read resp channel */\ ``I.rdata = ``O.rdata;\ ``I.rresp = ``O.rresp;\ ``I.rvalid = ``O.rvalid;\ ``O.rready = ``I.rready; +`define AXI4LITE_PORT_ASSIGN(FORMAL,ACTUAL) \ + .``FORMAL``_aclk(``ACTUAL``.clk),\ + .``FORMAL``_sreset(``ACTUAL``.rst),\ + .``FORMAL``_araddr(``ACTUAL``.araddr),\ + .``FORMAL``_arready(``ACTUAL``.arready),\ + .``FORMAL``_arvalid(``ACTUAL``.arvalid),\ + .``FORMAL``_awaddr(``ACTUAL``.awaddr),\ + .``FORMAL``_awready(``ACTUAL``.awready),\ + .``FORMAL``_awvalid(``ACTUAL``.awvalid),\ + .``FORMAL``_bready(``ACTUAL``.bready),\ + .``FORMAL``_bresp(``ACTUAL``.bresp[1:0]),\ + .``FORMAL``_bvalid(``ACTUAL``.bvalid),\ + .``FORMAL``_rdata(``ACTUAL``.rdata),\ + .``FORMAL``_rready(``ACTUAL``.rready),\ + .``FORMAL``_rresp(``ACTUAL``.rresp[1:0]),\ + .``FORMAL``_rvalid(``ACTUAL``.rvalid),\ + .``FORMAL``_wdata(``ACTUAL``.wdata),\ + .``FORMAL``_wready(``ACTUAL``.wready),\ + .``FORMAL``_wstrb(``ACTUAL``.wstrb),\ + .``FORMAL``_wvalid(``ACTUAL``.wvalid), + +`define AXI4LITE_PORT_ASSIGN_NR(FORMAL,ACTUAL) \ + .``FORMAL``_araddr(``ACTUAL``.araddr),\ + .``FORMAL``_arready(``ACTUAL``.arready),\ + .``FORMAL``_arvalid(``ACTUAL``.arvalid),\ + .``FORMAL``_awaddr(``ACTUAL``.awaddr),\ + .``FORMAL``_awready(``ACTUAL``.awready),\ + .``FORMAL``_awvalid(``ACTUAL``.awvalid),\ + .``FORMAL``_bready(``ACTUAL``.bready),\ + .``FORMAL``_bresp(``ACTUAL``.bresp[1:0]),\ + .``FORMAL``_bvalid(``ACTUAL``.bvalid),\ + .``FORMAL``_rdata(``ACTUAL``.rdata),\ + .``FORMAL``_rready(``ACTUAL``.rready),\ + .``FORMAL``_rresp(``ACTUAL``.rresp[1:0]),\ + .``FORMAL``_rvalid(``ACTUAL``.rvalid),\ + .``FORMAL``_wdata(``ACTUAL``.wdata),\ + .``FORMAL``_wready(``ACTUAL``.wready),\ + .``FORMAL``_wstrb(``ACTUAL``.wstrb),\ + .``FORMAL``_wvalid(``ACTUAL``.wvalid), + `define AXI4LITE_DEBUG_ASSIGN(O,I) \ (* mark_debug = "true" *) logic [``I.ADDR_WIDTH-1:0] ``I``_debug_awaddr;\ (* mark_debug = "true" *) logic ``I``_debug_awvalid;\ @@ -57,50 +96,50 @@ (* mark_debug = "true" *) logic ``I``_debug_rvalid;\ (* mark_debug = "true" *) logic ``I``_debug_rready;\ always_comb begin\ - /* write address channel */ + /* write address channel */\ ``I``_debug_awaddr = ``I.awaddr;\ ``I``_debug_awvalid = ``I.awvalid;\ ``I.awready = ``I``_debug_awready;\ - /* write data channel */ + /* write data channel */\ ``I``_debug_wdata = ``I.wdata;\ ``I``_debug_wstrb = ``I.wstrb;\ ``I``_debug_wvalid = ``I.wvalid;\ ``I.wready = ``I``_debug_wready;\ - /* write resp channel */ + /* write resp channel */\ ``I.bresp = ``I``_debug_bresp;\ ``I.bvalid = ``I``_debug_bvalid;\ ``I``_debug_bready = ``I.bready;\ - /* read address channel */ + /* read address channel */\ ``I``_debug_araddr = ``I.araddr;\ ``I``_debug_arvalid = ``I.arvalid;\ ``I.arready = ``I``_debug_arready;\ - /* read resp channel */ + /* read resp channel */\ ``I.rdata = ``I``_debug_rdata;\ ``I.rresp = ``I``_debug_rresp;\ ``I.rvalid = ``I``_debug_rvalid;\ - ``I``_debug_rready = ``I.rready; + ``I``_debug_rready = ``I.rready;\ end\ always_comb begin\ - /* write address channel */ + /* write address channel */\ ``O.awaddr = ``I``_debug_awaddr;\ ``O.awvalid = ``I``_debug_awvalid;\ ``I``_debug_awready = ``O.awready;\ - /* write data channel */ + /* write data channel */\ ``O.wdata = ``I``_debug_wdata;\ ``O.wstrb = ``I``_debug_wstrb;\ ``O.wvalid = ``I``_debug_wvalid;\ ``I``_debug_wready = ``O.wready;\ - /* write resp channel */ + /* write resp channel */\ ``I``_debug_bresp = ``O.bresp;\ ``I``_debug_bvalid = ``O.bvalid;\ ``O.bready = ``I``_debug_bready;\ - /* read address channel */ + /* read address channel */\ ``O.araddr = ``I``_debug_araddr;\ ``O.arvalid = ``I``_debug_arvalid;\ ``I``_debug_arready = ``O.arready;\ - /* read resp channel */ + /* read resp channel */\ ``I``_debug_rdata = ``O.rdata;\ ``I``_debug_rresp = ``O.rresp;\ ``I``_debug_rvalid = ``O.rvalid;\ - ``O.rready = ``I``_debug_rready; - end
\ No newline at end of file + ``O.rready = ``I``_debug_rready;\ + end |