Skip to main content

PCI express simulation framework for cocotb

Project description

PCI express simulation framework for Cocotb

Build Status codecov PyPI version Downloads

GitHub repository: https://github.com/alexforencich/cocotbext-pcie

Introduction

PCI express simulation framework for cocotb.

Installation

Installation from pip (release version, stable):

$ pip install cocotbext-pcie

Installation from git (latest development version, potentially unstable):

$ pip install https://github.com/alexforencich/cocotbext-pcie/archive/master.zip

Installation for active development:

$ git clone https://github.com/alexforencich/cocotbext-pcie
$ pip install -e cocotbext-pcie

Documentation and usage examples

See the tests directory, verilog-pcie, and corundum for complete testbenches using these modules.

Core PCIe simulation framework

The core PCIe simulation framework is included in cocotbext.pcie.core. This framework implements an extensive event driven simulation of a complete PCI express system, including root complex, switches, devices, and functions, including support for configuration spaces, capabilities and extended capabilities, and memory and IO operations between devices. The framework includes code to enumerate the bus, initialize configuration space registers and allocate BARs, route messages between devices, perform memory read and write operations, allocate DMA accessible memory regions in the root complex, and handle message signaled interrupts. Any module can be connected to a cosimulated design, enabling testing of not only isolated components and host-device communication but also communication between multiple components such as device-to-device DMA and message passing.

PCIe IP core models

Xilinx UltraScale and UltraScale+

Models of the Xilinx UltraScale and UltraScale+ PCIe hard cores are included in cocotbext.pcie.xilinx.us. These modules can be used in combination with the PCIe BFM to test an HDL design that targets Xilinx UltraScale, UltraScale+, or Virtex 7 series FPGAs, up to PCIe gen 3 x16 or PCIe gen 4 x8. The models currently only support operation as a device, not as a root port.

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

cocotbext-pcie-0.1.12.tar.gz (92.9 kB view details)

Uploaded Source

Built Distribution

cocotbext_pcie-0.1.12-py3-none-any.whl (92.6 kB view details)

Uploaded Python 3

File details

Details for the file cocotbext-pcie-0.1.12.tar.gz.

File metadata

  • Download URL: cocotbext-pcie-0.1.12.tar.gz
  • Upload date:
  • Size: 92.9 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.2 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for cocotbext-pcie-0.1.12.tar.gz
Algorithm Hash digest
SHA256 ddec35d9e3d4dde56e20a4fc2e4d8fbaf9c13d838710e70fb28529d3a727f07f
MD5 8ed99259ed6c1f97b7dd63c242a1f07f
BLAKE2b-256 b5a0d7bffaef7d5e4bc5eb5106629f9f70b827bef747a481048eca8663f53699

See more details on using hashes here.

File details

Details for the file cocotbext_pcie-0.1.12-py3-none-any.whl.

File metadata

  • Download URL: cocotbext_pcie-0.1.12-py3-none-any.whl
  • Upload date:
  • Size: 92.6 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/3.7.2 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.59.0 CPython/3.9.2

File hashes

Hashes for cocotbext_pcie-0.1.12-py3-none-any.whl
Algorithm Hash digest
SHA256 0f36f780b2a7c60c1e2ad0872ff33caa28a9b2552115113fa875afa971812169
MD5 551ab4b639e8d5ecc4c50bfcb2458197
BLAKE2b-256 591bebd5ffdafe502eaeb0d75659e31d1bbbcbb9181f203e89eed7f29ec4e63f

See more details on using hashes here.

Supported by

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