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.0.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.0-py3-none-any.whl (22.0 kB view details)

Uploaded Python 3

File details

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

File metadata

  • Download URL: avl_apb-0.3.0.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.0.tar.gz
Algorithm Hash digest
SHA256 1238d4ca923ba8369c2c1f85b119a1ffa12732c314872929f42f4f93e64bb387
MD5 44b147f3627fb7bd2a92bb2922fe6b65
BLAKE2b-256 5d92cc85120d94c98510c6a23806b31d9ac6349d6cb3d8daa2da449ed5f11b1a

See more details on using hashes here.

File details

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

File metadata

  • Download URL: avl_apb-0.3.0-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.0-py3-none-any.whl
Algorithm Hash digest
SHA256 28c4170bfca8c461194084fbfbdc4b3e33e9325ded629ca8fd34858b9f92e666
MD5 531c07f6f1a4ccf6caf8039898a25d09
BLAKE2b-256 f3f01a987df3c4431ddab893ce5aec1234c8c8291d9d9e7cd584bd086d48f5c4

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