Skip to content
/ axi Public
forked from pulp-platform/axi

AXI4 and AXI4-Lite interface definitions and testbench utilities

License

Notifications You must be signed in to change notification settings

gongyanhui/axi

 
 

Repository files navigation

AXI

This is the implementation of the AMBA AXI protocol developed as part of the PULP platform as ETH Zurich. We implement AXI4+ATOPs and AXI4-Lite.

Cell Contents

Name Description Doc
axi_atop_filter.sv Filters atomic operations (ATOPs), i.e., write transactions that have a non-zero aw_atop value.
axi_cdc.sv AXI clock domain crossing based on a Gray FIFO implementation.
axi_cut.sv Breaks all combinatorial paths between its input and output.
axi_decerr_slv.sv Always responds with an AXI decode error for transactions which are sent to it.
axi_delayer.sv Synthesizable module which can (randomly) delays AXI channels.
axi_demux.sv Demultiplexes an AXI bus from one slave port to multiple master ports. Doc
axi_id_prepend.sv This module prepends/strips the MSB from the AXI IDs.
axi_intf.sv This file defines the interfaces we support.
axi_join.sv A connector that joins two AXI interfaces.
axi_lite_demux.sv Demultiplexes an AXI4-Lite bus from one slave port to multiple master ports. Doc
axi_lite_join.sv A connector that joins two AXI-Lite interfaces.
axi_lite_mux.sv Multiplexes AXI4-Lite slave ports down to one master port. Doc
axi_lite_to_apb.sv An AXI4-Lite to APB4 adapter.
axi_lite_to_axi.sv An AXI4-Lite to AXI4 adapter.
axi_lite_xbar.sv Fully-connected AXI4-Lite crossbar with an arbitrary number of slave and master ports. Doc
axi_modify_address.sv A connector that allows addresses of AXI requests to be changed.
axi_multicut.sv AXI register which can be used to relax timing pressure on long AXI busses.
axi_mux.sv Multiplexes the AXI4 slave ports down to one master port. Doc
axi_pkg.sv Contains AXI definitions, common structs, and useful helper functions.
axi_test.sv A set of testbench utilities for AXI interfaces.
axi_to_axi_lite.sv An AXI4 to AXI4-Lite adapter.
axi_xbar.sv Fully-connected AXI4+ATOP crossbar with an arbitrary number of slave and master ports. Doc

Atomic Operations

AXI4+ATOPs means the full AXI4 specification plus atomic operations (ATOPs) as defined in Section E2.1 of the AMBA5 specification. This has the following implications for modules that do not implement ATOPs and systems that include such modules:

  • Masters that do not issue ATOPs can simply permanently set aw_atop to 0.
  • Slaves that do not support ATOPs must specify this in their interface documentation and can ignore the aw_atop signal.
  • System designers are responsible for ensuring that slaves that do not support ATOPs are behind an axi_atop_filter if any master could issue an ATOP to such slaves.

Masters and slaves that do support ATOPs must adhere to Section E2.1 of the AMBA5 specification.

About

AXI4 and AXI4-Lite interface definitions and testbench utilities

Resources

License

Stars

Watchers

Forks

Packages

No packages published

Languages

  • SystemVerilog 94.0%
  • Stata 5.2%
  • Shell 0.8%