Skip to content

https://github.com/krevanth/FreeAHB : The official GIT repo of FreeAHB, a FOSS AHB 2.0 manager. (C) 2016-2024 Revanth Kamaraj (krevanth). Note that https://github.com/krevanth/FreeAHB was accidentally deleted but has now been fully restored to the same URL from backups on 22/05/2024. Fork list, issues, stars, watchers couldn't be restored.

License

Notifications You must be signed in to change notification settings

krevanth/FreeAHB

Folders and files

NameName
Last commit message
Last commit date

Latest commit

 
 
 
 
 
 
 
 
 
 
 
 
 
 
 

Repository files navigation

FreeAHB : An AHB 2.0 Manager (https://github.com/krevanth/FreeAHB/)

Copyright (C) 2016-2024 Revanth Kamaraj (krevanth) <[email protected]>

IMPORTANT:

REPO CREATION AND FIRST COMMIT DATE: Nov 18 2016. View First Commit ( Author=REVANTH KAMARAJ (KREVANTH) Hash=20682c989cdf5b7a5986d16f147323cdf7703c67 Date = Nov 18 2016 )

License

Copyright (C) 2016-2024 Revanth Kamaraj (krevanth) <[email protected]>

Permission is hereby granted, free of charge, to any person obtaining a copy of this software and associated documentation files (the "Software"), to deal in the Software without restriction, including without limitation the rights to use, copy, modify, merge, publish, distribute, sublicense, and/or sell copies of the Software, and to permit persons to whom the Software is furnished to do so, subject to the following conditions:

The above copyright notice and this permission notice shall be included in all copies or substantial portions of the Software.

THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY, FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM, OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE SOFTWARE.

Authors

RTL Design

All of the FreeAHB RTL is Copyright (C) 2016-2024 by Revanth Kamaraj (krevanth) <[email protected]>

Verification

All of the FreeAHB test code is Copyright (C) 2016-2024 by Revanth Kamaraj (krevanth) <[email protected]>

Notice

The repo https://github.com/krevanth/FreeAHB is the official, definitive and authoritative FreeAHB repo. The repository provides an AHB 2.0 Manager.

What happened to the repo's forks, issue history, stars and watcher lists ?

The repo https://github.com/krevanth/FreeAHB was detached from its forks (as an unintended consequence) when the repo was made private and was then deleted from GitHub. The repo has now been restored from a combination of local backups and downstream forks (i.e., online backups) and is now at the same URL as before i.e., https://github.com/krevanth/FreeAHB and those who have forked the repo before are encouraged to make a new fork based on https://github.com/krevanth/FreeAHB. Apologies for the inconvenience caused.

Unfortunately, the issue history, stars, watcher lists and the list of the repo's forks could not be restored.

System Integration

The file src/rtl/ahb_manager.sv is the AHB manager module. The port description below provides instructions on how to use the AHB manager.

Parameters

DATA_WDT specifies the width of the data busses. This is 32 by default. You can specify upto 1024 here. Valid values are 8, 16, 32, 64, 128, 256, 512 and 1024.

Ports

AHB Interface

Port IO Width Description
i_hclk I 1 Standard AHB 2.0 signal.
i_hreset_n I 1 Standard AHB 2.0 signal.
o_haddr I 32 Standard AHB 2.0 signal.
o_hburst O 3 Standard AHB 2.0 signal.
o_htrans O 2 Standard AHB 2.0 signal.
o_hwdata O DATA_WDT Standard AHB 2.0 signal.
o_hwrite O 1 Standard AHB 2.0 signal.
o_hsize O 3 Standard AHB 2.0 signal.
i_hrdata I DATA_WDT Standard AHB 2.0 signal.
i_hready I 1 Standard AHB 2.0 signal.
i_hresp I 2 Standard AHB 2.0 signal.
i_hgrant I 1 Standard AHB 2.0 signal.
o_hbusreq O 1 Standard AHB 2.0 signal.

User Interface

  • Do not change any of the UI inputs throughout a burst command sequence except i_first_xfer and i_wr_data - that too only when o_stall = 0.
  • Use i_first_xfer=1 to signal start of a new burst. Again, note that this can be done only when o_stall = 0.
  • Do not make i_idle=1 in between an ongoing burst command sequence. Only make it 1 after the entire burst command sequence has been completely given to the unit.
  • Out of reset, keep i_idle=1 i_rd=0 i_wr=0 i_first_xfer=0 for atleast 1 cycle.
  • When i_first_xter=1, you should have either i_rd=1 or i_wr=1 (along with i_idle=0).
  • Note that i_idle=1 causes the design to IGNORE i_rd, i_wr and i_first_xfer. Nevertheless, it is recommended to make i_rd=0 i_wr=0 i_first_xfer=0 when setting i_idle=1.
Port IO Width Description
o_err O 1 Internal failure. Please reset system to resolve.
o_stall O 1 No UI signals (i_*) are allowed to change when this is 1.
i_idle I 1 Use this to the signal to the UI that no burst is going on. Do not assert during an ongoing burst command sequence. Expected to be 1 after entire burst command sequence has been sent to the AHB manager. Out of reset, keep i_idle=1 for atleast 1 cycle.
i_wr_data I DATA_WDT Data to be written. May change every cycle during the burst command sequence. The i_size determines the valid bits of this. For example, if i_size = 0, only 7:0 will be considered. If i_size=1, only 15:0 of this will be considered.
i_addr I 32 Supply base address of the burst here. Should be held constant throughout the burst command sequence (recommended) although you could get away with just supplying valid address when i_first_xfer=1.
i_size I 3 Should be held constant through the burst command sequence. Throughout a burst, some fixed byte lanes are considered on the UI data (i_wr_data, o_rd_data) while other fixed byte lanes are IGNORED. If i_size = 0, only 7:0 is considered; if i_size = 1, only 15:0 is considered; if i_size = 2, only 31:0 is considered; if i_size = 3, only 63:0 is considered; if i_size = 4, only 127:0 is considered; if i_size=5, only 255:0 is considered; if i_size=6, only 511:0 is considered; if i_size=7, only 1023:0 is considered.
i_wrap I 1 Enable wrapping mode. Hold throughout the burst.
i_wr I 1 Indicates a write burst command sequnce. Can be gapped in the middle of the write burst command sequence to throttle i_wr_data getting into the AHB manager.
i_rd I 1 Indicates a read burst command sequence. Can be gapped in the middle of the read burst command sequence to pause read data coming out the AHB manager.
i_min_len I 16 Specify the minimum number of beats in the burst command sequence, each beat's width being represented by i_size. The actual burst command sequence can be longer (upto 64KB) but cannot be shorter than this. Hold throughout the burst command sequence (recommended) although you could get away with just supplying valid value when i_first_xfer=1. Specifying 0 here i.e., zero length is illegal. For wrapping mode, this number should accurately represent the length of the burst, and not the minimum. Note that the total size of the transfer in bytes should not exceed 65536 bytes.
i_first_xfer I 1 When new UI signals are setup for a new burst, make this 1 for the first beat. Make it 0 for the rest of the burst command sequence. When 1, ensure i_rd=1 or i_wr=1.
o_rd_data O DATA_WDT Requested read data is present out in an in-order sequence decoupled from the command i.e., it can come after the read command sequence has been fed into the AHB manager completely and i_idle=1 after the sequence. Based on the i_size provided with the read command sequence, only certain bits should be considered as valid. For example, i_size = 0 should consider only 7:0 of this bus to be valid read data. If i_size=1, only 15:0 of this bus should be considered valid read data.
o_rd_data_addr O 32 Associated address corresponding to the read data presented on the above port.
o_rd_data_dav O 1 Qualifies the above two signals when 1.

Project Environment

Installing Tools

The project environment assumes a Linux based machine and additionally requires Docker to be installed at your site. Click here for instructions on how to install Docker. The steps here assume that the user is a part of the docker group.

Make Targets

Enter the project's root directory and enter one of the following commands:

make sim will run the included test and generate a VCD file in the obj/ folder.

make clean will remove the obj folder.

make lint will run linting on the RTL using Verilator and SVLint.

About

https://github.com/krevanth/FreeAHB : The official GIT repo of FreeAHB, a FOSS AHB 2.0 manager. (C) 2016-2024 Revanth Kamaraj (krevanth). Note that https://github.com/krevanth/FreeAHB was accidentally deleted but has now been fully restored to the same URL from backups on 22/05/2024. Fork list, issues, stars, watchers couldn't be restored.

Topics

Resources

License

Stars

Watchers

Forks

Releases

No releases published

Packages

No packages published