Skip to content

iRumesh/System_Bus_Design

 
 

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

System Bus Design

Bus Architecture

Overview

This is our version of a system bus architecture, custom built with a selection of custom protocols.
The design has been inspired by the design and functionality of the AMBA Spec 2.0, AHB/APB buses. Hence it consists of a blend of characteristics native to those bus arcitectures, albeit with significant performance and functionality limitations.

A more detailed report on the performance is available here.

Features & Limitations

Features Design Limitations
Priority requests Data transfers limited to 32-bit WORD sized packets
Write / read transactions No burst transfer capability
Split transactions Split transactions only possible on READ operations
Designed around a specfied static clock frequency

Address Mapping


Arbiter Module Design

I/O Definitions


Arbitration


Master, Slave Module Design

I/O Definitions


State Transitions

Master | Slave States

Top Level Integration

Write, Split, Read Operation


The figures above show a brief glimpse of a SPLIT transaction taking place between Master 1 and Slave 1. Bus access is handed off to Master 2 and Slave 2 to perform a WRITE operation in the intermittent time duration. More details included in report.

Software

The entire codebase was written and synthesized in Xilinx ISE Design Suite 14.7.
All waveform simulations were performed in the integrated ISim platform.

References

ARM Developer Documentation : AMBA Specification (Rev 2.0)

About

EN5102 - Digital System Design - Group Project

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published

Languages

  • Verilog 100.0%