Skip to content

Commit

Permalink
hw: Disable AXI splitting checks in AXI-RT (#84)
Browse files Browse the repository at this point in the history
  • Loading branch information
thommythomaso authored Oct 17, 2023
1 parent 2011a9c commit d4b73a8
Show file tree
Hide file tree
Showing 5 changed files with 33 additions and 27 deletions.
4 changes: 2 additions & 2 deletions Bender.lock
Original file line number Diff line number Diff line change
Expand Up @@ -44,8 +44,8 @@ packages:
- common_cells
- common_verification
axi_rt:
revision: a9a5b3e91fe017da70c33b7e750b1a9eb35f31ee
version: 0.0.0-alpha.3
revision: 2be9d4028cd3fd6617a0302a53212495a4c4e3fa
version: 0.0.0-alpha.4
source:
Git: https://github.com/pulp-platform/axi_rt.git
dependencies:
Expand Down
2 changes: 1 addition & 1 deletion Bender.yml
Original file line number Diff line number Diff line change
Expand Up @@ -16,7 +16,7 @@ dependencies:
axi: { git: "https://github.com/pulp-platform/axi.git", version: 0.39.0 }
axi_llc: { git: "https://github.com/pulp-platform/axi_llc.git", version: 0.2.1 }
axi_riscv_atomics: { git: "https://github.com/pulp-platform/axi_riscv_atomics.git", version: 0.8.1 }
axi_rt: { git: "https://github.com/pulp-platform/axi_rt.git", version: 0.0.0-alpha.3 }
axi_rt: { git: "https://github.com/pulp-platform/axi_rt.git", version: 0.0.0-alpha.4 }
axi_vga: { git: "https://github.com/pulp-platform/axi_vga.git", version: 0.1.1 }
clic: { git: "https://github.com/pulp-platform/clic.git", version: 2.0.0 }
clint: { git: "https://github.com/pulp-platform/clint.git", version: 0.2.0 }
Expand Down
6 changes: 5 additions & 1 deletion docs/um/arch.md
Original file line number Diff line number Diff line change
Expand Up @@ -154,7 +154,11 @@ The internal interconnect exposes the following parameters:
| `(Axi|Reg)ExtNum(Mst|Slv)` | `0..15` | AXI4 and Regbus number of external Mgrs. or Subs. |
| `(Axi|Reg)ExtNumRules` | `0..15` | AXI4 and Regbus number of external address rules |
| `(Axi|Reg)ExtRegion*` | `doub_bt` | AXI4 and Regbus external address regions |
| `AxiRt*` | `word_bt` | AXI4 real-time traffic regulation parameters |
| `AxiRtNumPending` | `aw_bt` | Number of outstanding transactions in RT units |
| `AxiRtWBufferDepth` | `dw_bt` | The depth of the AXI-RT write buffer |
| `AxiRtNumAddrRegions` | `aw_bt` | Number of address regions for every AXI manager |
| `AxiRtCutPaths` | `bit` | Enable internal cuts in the RT units |
| `AxiRtEnableChecks` | `bit` | Enable transaction checks within the RT units |

Both the AXI4 and Regbus interconnects support exposing a limited number of external manager and subordinate ports; this is the intended mechanism through which Cheshire can be integrated with wrapping SoCs' memory systems.

Expand Down
1 change: 1 addition & 0 deletions hw/cheshire_pkg.sv
Original file line number Diff line number Diff line change
Expand Up @@ -186,6 +186,7 @@ package cheshire_pkg;
dw_bt AxiRtWBufferDepth;
aw_bt AxiRtNumAddrRegions;
bit AxiRtCutPaths;
bit AxiRtEnableChecks;
} cheshire_cfg_t;

//////////////////
Expand Down
47 changes: 24 additions & 23 deletions hw/cheshire_soc.sv
Original file line number Diff line number Diff line change
Expand Up @@ -1096,29 +1096,30 @@ module cheshire_soc import cheshire_pkg::*; #(
if (Cfg.AxiRt) begin : gen_axi_rt

axi_rt_unit_top #(
.NumManagers ( AxiIn.num_in ),
.AddrWidth ( Cfg.AddrWidth ),
.DataWidth ( Cfg.AxiDataWidth ),
.IdWidth ( Cfg.AxiMstIdWidth ),
.UserWidth ( Cfg.AxiUserWidth ),
.NumPending ( Cfg.AxiRtNumPending ),
.WBufferDepth ( Cfg.AxiRtWBufferDepth ),
.NumAddrRegions ( Cfg.AxiRtNumAddrRegions ),
.PeriodWidth ( 32'd32 ),
.BudgetWidth ( 32'd32 ),
.RegIdWidth ( AxiSlvIdWidth ),
.CutSplitterPaths ( Cfg.AxiRtCutPaths ),
.CutDecErrors ( 1'b0 ),
.aw_chan_t ( axi_mst_aw_chan_t ),
.w_chan_t ( axi_mst_w_chan_t ),
.b_chan_t ( axi_mst_b_chan_t ),
.ar_chan_t ( axi_mst_ar_chan_t ),
.r_chan_t ( axi_mst_r_chan_t ),
.axi_req_t ( axi_mst_req_t ),
.axi_resp_t ( axi_mst_rsp_t ),
.req_req_t ( reg_req_t ),
.req_rsp_t ( reg_rsp_t )
) i_axi_rt_unit_top (
.NumManagers ( AxiIn.num_in ),
.AddrWidth ( Cfg.AddrWidth ),
.DataWidth ( Cfg.AxiDataWidth ),
.IdWidth ( Cfg.AxiMstIdWidth ),
.UserWidth ( Cfg.AxiUserWidth ),
.NumPending ( Cfg.AxiRtNumPending ),
.WBufferDepth ( Cfg.AxiRtWBufferDepth ),
.NumAddrRegions ( Cfg.AxiRtNumAddrRegions ),
.PeriodWidth ( 32'd32 ),
.BudgetWidth ( 32'd32 ),
.RegIdWidth ( AxiSlvIdWidth ),
.CutSplitterPaths ( Cfg.AxiRtCutPaths ),
.DisableSplitChecks ( !Cfg.AxiRtEnableChecks ),
.CutDecErrors ( 1'b0 ),
.aw_chan_t ( axi_mst_aw_chan_t ),
.w_chan_t ( axi_mst_w_chan_t ),
.b_chan_t ( axi_mst_b_chan_t ),
.ar_chan_t ( axi_mst_ar_chan_t ),
.r_chan_t ( axi_mst_r_chan_t ),
.axi_req_t ( axi_mst_req_t ),
.axi_resp_t ( axi_mst_rsp_t ),
.req_req_t ( reg_req_t ),
.req_rsp_t ( reg_rsp_t )
) i_axi_rt_unit_top (
.clk_i,
.rst_ni,
.slv_req_i ( axi_in_req ),
Expand Down

0 comments on commit d4b73a8

Please sign in to comment.