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 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.2.0.tar.gz (16.0 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.2.0-py3-none-any.whl (21.9 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: avl_apb-0.2.0.tar.gz
  • Upload date:
  • Size: 16.0 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.2.0.tar.gz
Algorithm Hash digest
SHA256 538afe4a00840f92261d8a28493e73a8b3b8033043a63cb90ac35827d0fd6a52
MD5 7dfabf473fe3d0ba76868d12d421a43b
BLAKE2b-256 5573c32e9e3b0a46de6391749d6c1b32cb6ca3a0e8a5cffe4a75f9763575ba17

See more details on using hashes here.

File details

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

File metadata

  • Download URL: avl_apb-0.2.0-py3-none-any.whl
  • Upload date:
  • Size: 21.9 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.2.0-py3-none-any.whl
Algorithm Hash digest
SHA256 4a97ce9af00c5d7e0541b738b0ab813f0e26cfc804a156c947585475a8995d24
MD5 5778b5a6d3d06947d86aa7182bde7d73
BLAKE2b-256 5a8aec80b02730c508bce61b79024f26516e65892b8f013b9578479ad9292bde

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