### **VciAvalonBus** ## 1) Functional Description This hardware component is a generic Avalon switch fabric allowing the interconnection of *Nb\_Master* Avalon masters and *Nb\_Slave* Avalon slaves. The master-to-slave relationship can be one-to-one, one-to-many, many-to-one, or many-to-many. Masters and slaves have the same data and address widths and operate in the same clock domain. VCI-Avalon wrappers do not require to support full Avalon features, so not all Avalon slave and master ports are supported (AvalonSwitchMaster?, AvalonSwitchSlave?). #### Implemented functionnalities: - fundamental read, fundamental write with variable wait-state - burst transfer - flow control (dataavailable) - round robin arbitration #### Unimplemented functionnalities: - wait state insertion - pipelined read transfers - tristate transfert - setup and hold time - dynamic bus sizing - interrupt requests An AVALON bus instanciates the three following components: Address decoding logic (ADL) (AvalonAddressDecodingLogic) in the system interconnect fabric distributes an appropriate address and produces a chipselect signal for each slave. Datapath multiplexing (MUX) (AvalonMux) in the system interconnect fabric drives the *writedata* signal from the granted master to the selected slave, and the *readdata* signal from the selected slave back to the requesting master. Multiple Avalon masters can simultaneously perform transfers with independent slaves. The system interconnect fabric provides shared access to slaves using a technique called slave-side arbitration. Slave-side arbitration moves the arbitration logic (Arbiter) (AvalonArbiter) close to the slave, such that the algorithm that determines which master gains access to a specific slave in the event that multiple masters attempt to access the same slave at the same time. The arbiter grants shares in a round-robin order. AvalonSwitchConfig describes the implemented switch fabric. ## 2) Component definition & usage # 3) CABA Implementation VciAvalonBus 1 #### **CABA** sources • interface: source:trunk/soclib/soclib/module/network component/avalon switch fabric/caba/source/include/avalon switch fab • implementation : source:trunk/soclib/soclib/module/network component/avalon switch fabric/caba/source/src/avalon switch fabric.c ### **CABA Constructor parameters** ``` AvalonSwitchFabric (sc_module_name insname, // instance name AvalonSwitchConfig<Nb_Master, Nb_slave> config) // configuration ``` #### **CABA Ports** - $\bullet$ sc\_in<br/>bool> **p\_resetn** : Global system reset - sc\_in<bool> p\_clk : Global system clock - AvalonSwitch\_Master \*p\_avalon\_master: Nb\_Master ports from Avalon masters - AvalonSwitch\_Slave \*p\_avalon\_slave: Nb\_Slave ports to Avalon slaves ### **CABA Implementation Notes** # 4) TLM-T implementation There is no TLM-T implementation for this component. CABA sources 2