Skip to main content

Apheleia Verification Library - AMBA Advanced Peripheral Bus verification component.

Project description

AVL-APB - Apheleia Verification Library AMBA APB Verification Component

License: MIT Python

AVL-APB has been developed by experienced, industry professional verification engineers to provide a simple,
extensible verification component for the AMBA APB Bus
developed in Python and the AVL library.

AVL is built on the CocoTB framework, but aims to combine the best elements of
UVM in a more engineer friendly and efficient way.

Protocol Features

Version Signal Name Description Driven By
APB2 PCLK APB clock signal; all APB transfers are synchronized to this clock. Requester
APB2 PRESETn Asynchronous active-low reset for the APB interface. Requester
APB2 PADDR Address bus; specifies the register address for the transfer. Requester
APB2 PSELx Slave select; one per slave. High when the slave is selected. Requester
APB2 PENABLE Indicates the second and subsequent cycles of an APB transfer. Requester
APB2 PWRITE Write control signal; high for write, low for read. Requester
APB2 PWDATA Write data bus from master to slave. Requester
APB2 PRDATA Read data bus from slave to master. Completer
APB3 PREADY Optional signal; indicates the slave is ready to complete the transfer. Completer
APB3 PSLVERR Optional signal; indicates an error condition on the transfer. Completer
APB4 PPROT Optional protection control signals for privilege, security, and instruction/data access. Requester
APB4 PSTRB Optional byte lane strobe signals for write operations. Requester
APB5 PNSE Optional signal; indicates whether the transfer is secure or non-secure. Requester
APB5 PWAKEUP Optional wakeup signal from slave to master for low-power operation. Completer
APB5 PAUSER Optional signal; specifies the user ID associated with the transfer for secure systems. Requester
APB5 PRUSER Optional user-defined read data channel sideband signals. Completer
APB5 PWUSER Optional user-defined write data channel sideband signals. Requester
APB5 PBUSER Optional user-defined byte strobe channel sideband signals. Requester

Component Features

  • All protocol features supported
  • Simple RTL interface to interact with HDL and define parameter and configuration options
  • Requester sequence, sequencer and driver with easy to control rate limiter and wakeup control
  • Completer driver with vanilla, random and memory response patterns
  • Monitor
  • Bandwidth monitor generating bus activity plots over user defined windows during simulation
  • Functional coverage including performance measurements
  • Searchable trace file generation

📦 Installation

Using pip

# Standard build
pip install avl-core

# Development build
pip install avl-core[dev]

Install from Source

git clone https://github.com/projectapheleia/avl.git
cd avl

# Standard build
pip install .

# Development build
pip install .[dev]

Alternatively if you want to create a virtual environment rather than install globally a script is provided. This will install, with edit privileges to local virtual environment.

This script assumes you have Graphviz and appropriate simulator installed, so all examples and documentation will build out of the box.

git clone https://github.com/projectapheleia/avl-apb.git
cd avl-apb
source avl-apb.sh

📖 Documentation

In order to build the documentation you must have installed the development build.

Build from Source

cd docs
make html
<browser> build/html/index.html

🏃 Examples

In order to run all the examples you must have installed the development build.

To run all examples:

cd examples

# To run
make -j 8 sim

# To clean
make -j 8 clean

To run an individual example:

cd examples/THE EXAMPLE YOU WANT

# To run
make sim

# To clean
make clean

The examples use the CocoTB Makefile and default to Verilator with all waveforms generated. This can be modified using the standard CocoTB build system.


🧹 Code Style & Linting

This project uses Ruff for linting and formatting.

Check code for issues:

ruff check .

Automatically fix common issues:

ruff check . --fix

📧 Contact

Project details


Download files

Download the file for your platform. If you're not sure which to choose, learn more about installing packages.

Source Distribution

avl_apb-0.1.0.tar.gz (15.7 kB view details)

Uploaded Source

Built Distribution

If you're not sure about the file name format, learn more about wheel file names.

avl_apb-0.1.0-py3-none-any.whl (21.7 kB view details)

Uploaded Python 3

File details

Details for the file avl_apb-0.1.0.tar.gz.

File metadata

  • Download URL: avl_apb-0.1.0.tar.gz
  • Upload date:
  • Size: 15.7 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for avl_apb-0.1.0.tar.gz
Algorithm Hash digest
SHA256 06c11b4a72ac6a85e6dd8330af6f5170cd160856c4582b462ccc2382a0b1fa04
MD5 dd7c10baf19886ad82436da220e4d156
BLAKE2b-256 e889002549c2ade9cb4291ab05b4a026b7235003a8670061e2d43fd261d5ca97

See more details on using hashes here.

File details

Details for the file avl_apb-0.1.0-py3-none-any.whl.

File metadata

  • Download URL: avl_apb-0.1.0-py3-none-any.whl
  • Upload date:
  • Size: 21.7 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/6.1.0 CPython/3.12.3

File hashes

Hashes for avl_apb-0.1.0-py3-none-any.whl
Algorithm Hash digest
SHA256 ad6ebefdda87acedc96daded9d31a651f3f392bad062028ab20d700def744a39
MD5 92a9a64431b149fe469bf4fbe6813d64
BLAKE2b-256 ae3d4d49ad325529ead8e0e762f5d9bddfdfcb9d5dcef520b40ea938e481a874

See more details on using hashes here.

Supported by

AWS Cloud computing and Security Sponsor Datadog Monitoring Depot Continuous Integration Fastly CDN Google Download Analytics Pingdom Monitoring Sentry Error logging StatusPage Status page