Skip to main content

library of hardware components and test for HWToolkit framework (hwt, FPGA devel. tools)

Project description

hwtLib

CircleCI PyPI version Coverage Status Documentation Status Python version Join the chat at https://gitter.im/hwt-community/community

hwtLib is the library of hardware components writen using hwt library. Any component can be exported as Xilinx Vivado (IP-exact) or Quartus IPcore using IpPackager or as raw Verilog/VHDL/SystemC code and constraints by to_rtl() function. Target language is specified by keyword parameter serializer.

Content

For example there is a component AxiLiteEndpoint, wich is configured using c-like data type description and it generates a address decoders and convertors to other intefaces if requested. Another example is AxiS_frameParser, which is configured in same way and performs an extraction of the data fields from an input stream. Hwt type system does contains all c-like and SystemVerilog-like types but in addition it allows for better specification of padding and allignment and has an explicit data type for streams. This allows AxiS_frameParser to be easily configured to change alignemnt of the stream, cut/split/replace part of the steam with an easy to read HLS-like description.

Verifications are write in UVM like style and as hwt based design are actually a graph we can easily analyse them. This is every usefull as it allows us to generate most of the test environment automatically in a user controlled and predictable way and write mostly only a test scenario. For example there is no need to build bus transactions manually as AddressSpaceProbe can discover the mapped address space (for any interface) and we can set register values using a proxy as if it was a normal value. This means that you can write a verification which will have a component with arbitrary bus/address space and it will work as long as you keep the names of the registers the same.

Clock frequencies and target chips usually does not matter but if componet generates constraints it surely needs a correct clock period to generate them correctly.

Also note that the code of the components should be shared if @serializeParamsUniq is used, the design for largest FPGAs takes 5s to generate. The verification should be also fast (take look at travis build) if this is not your case you are probably doing something wrong.

  • abstract - abstract classes for component classes like bus endpoint, etc
  • amba - AXI interfaces and components for them (AXI3/4 DMAs, interconnects, Axi-stream components, Axi4Lite address decoders etc...)
  • avalon - same thing as amba just for Avalon interfaces (AvalonST, AvalonMM, ... and components for them)
  • cesnet - components and interfaces specific to Cesnet designs
  • clocking - various generic PLLs, timer generators etc.
  • examples - demonstrative examples of hwt functionality
  • handshaked - components for handshaked interfaces (FIFO, AsyncFifo, Resizer, interconnects, Register, ...)
  • img - image preprocessing utils (parse PNG font to bits for OLED, ...)
  • interfaces - various interfaces which does not have it's package yet
  • logic - various components like CRC generator, gray counter, decoders-encoders ...
  • mem - various memories (BRAM, ROM, FIFO, Async FIFO, CAM, LUT, ...)
  • peripheral - various peripheral interfaces and components (I2C, MDIO, SPI, UART, USB, Ethernet, ...)
  • sim - simulation utils
  • structManipulators - DMAs for specific data structures
  • tests - tests which are not related to another components
  • types - deffinitions of common types (uint32_t, ipv6_t, udp_t, ...)
  • xilinx - components, primitives and interfaces specific to Xilinx based designs (IPIF, LocalLink, ...)

If you see any problem/do not underestand something/do miss something open the github issue as others may step uppon same problem sooner or later.

Installation

# from PYPI (latest release)
sudo pip3 install hwtLib

# or from git (latest)
sudo pip3 install -r https://raw.githubusercontent.com/Nic30/hwtLib/master/doc/requirements.txt git+git://github.com/Nic30/hwtLib#egg=hwtLib --upgrade --no-cache

Repositories with opensource HW:

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

hwtLib-2.9.tar.gz (588.8 kB view details)

Uploaded Source

Built Distributions

hwtLib-2.9-py3.9.egg (2.2 MB view details)

Uploaded Source

hwtLib-2.9-py3-none-any.whl (898.3 kB view details)

Uploaded Python 3

File details

Details for the file hwtLib-2.9.tar.gz.

File metadata

  • Download URL: hwtLib-2.9.tar.gz
  • Upload date:
  • Size: 588.8 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.6

File hashes

Hashes for hwtLib-2.9.tar.gz
Algorithm Hash digest
SHA256 906d76009963b480f9e9439b67f98763680500a17c1c399b408828f932e66e5d
MD5 e4d85bb40cb3d1d447bb007d7ef37a08
BLAKE2b-256 ca4ffcdf397e91f7fbdb06239f467216b9de2829e88f37a1fdebd22236d1c534

See more details on using hashes here.

File details

Details for the file hwtLib-2.9-py3.9.egg.

File metadata

  • Download URL: hwtLib-2.9-py3.9.egg
  • Upload date:
  • Size: 2.2 MB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.6

File hashes

Hashes for hwtLib-2.9-py3.9.egg
Algorithm Hash digest
SHA256 f0144472c82be522ee2afa8623a1dad7265414d6ada612928cf2a40e92e348f4
MD5 8da4169f25ef1b0094cca4f512469d83
BLAKE2b-256 2fd0f57737eeed95b26715413bbca9763f4fb23d4fc20a3d8a4a4db06aef4c0d

See more details on using hashes here.

File details

Details for the file hwtLib-2.9-py3-none-any.whl.

File metadata

  • Download URL: hwtLib-2.9-py3-none-any.whl
  • Upload date:
  • Size: 898.3 kB
  • Tags: Python 3
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/3.4.1 importlib_metadata/4.6.0 pkginfo/1.7.0 requests/2.25.1 requests-toolbelt/0.9.1 tqdm/4.61.1 CPython/3.9.6

File hashes

Hashes for hwtLib-2.9-py3-none-any.whl
Algorithm Hash digest
SHA256 3aa455f3562bcba59c9c78a5e583354f758baec7a21610604579963214ecedca
MD5 f2c25c404c9082a9824170a70cddc58a
BLAKE2b-256 d081f879c652bb1bdd33ebaf98ed9d25adf563f697e4b094a8efeda39f711db6

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