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.

CocoTB 2.0

AVL-APB now supports CocoTB2.0 https://docs.cocotb.org/en/development/upgrade-2.0.html. This was introduced in v0.2.0.

All older versions support v1.9.1 and will fail if run with CocoTB 2.0.

To upgrade follow the instructions given on the link above.

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-apb

# Development build
pip install avl-apb[dev]

Install from Source

git clone https://github.com/projectapheleia/avl-apb.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 doc
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.3.1.tar.gz (16.1 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.3.1-py3-none-any.whl (22.0 kB view details)

Uploaded Python 3

File details

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

File metadata

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

File hashes

Hashes for avl_apb-0.3.1.tar.gz
Algorithm Hash digest
SHA256 b5cbcac43632a74ccd1ec5ca51ab5ffcefdd07a8b87907341e5245987e777e24
MD5 a89e43f37e1025324ff05cc84dab2014
BLAKE2b-256 9df29e9320b477e2f6ca2458c4147c5d98685be6844ed24df9446dfca25953d4

See more details on using hashes here.

File details

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

File metadata

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

File hashes

Hashes for avl_apb-0.3.1-py3-none-any.whl
Algorithm Hash digest
SHA256 6e783684e7e112ec7e0a11a06be70c2dea83f189bf6a4ec34c48aee381235d15
MD5 9590355a42ee681a9daf6291b451f918
BLAKE2b-256 b6e6e0cd5b8fc53f962866af815114a0f08a8a03f6871df6f5ee5afef2cc0701

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