Skip to main content

CRC algorithm HDL code generator (VHDL, Verilog, MyHDL)

Project description

CRC algorithm HDL code generator (VHDL, Verilog, MyHDL)

Homepage

Git repository

Github repository

This tool generates VHDL, Verilog or MyHDL code for use in FPGAs to calculate CRC (Cyclic Redundancy Check) checksums.

The generated HDL code is synthesizable and combinatorial. That means the calculation runs in one clock cycle on an FPGA.

Any combination of CRC algorithm parameters and polynomial coefficients can be selected.

Example usage

Display all options:

crcgen -h

Generate Verilog code for CRC-32:

crcgen -a CRC-32 -v

Generate VHDL code for CRC-32:

crcgen -a CRC-32 -V

Generate Verilog code for a custom non-standard CRC or any standard algorithm that’s not included in crcgen’s -a list:

crcgen -P "x^8 + x^7 + x^5 + x^4 + x^2 + x + 1" -B16 -R -v

Online crcgen

An easy to use online version of crcgen that can be used without installing or downloading anything to your machine is available here:

Online crcgen

License of the generated HDL code

The generated code is Public Domain.

Permission to use, copy, modify, and/or distribute this software for any purpose with or without fee is hereby granted.

THE SOFTWARE IS PROVIDED “AS IS” AND THE AUTHOR DISCLAIMS ALL WARRANTIES WITH REGARD TO THIS SOFTWARE INCLUDING ALL IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS. IN NO EVENT SHALL THE AUTHOR BE LIABLE FOR ANY SPECIAL, DIRECT, INDIRECT, OR CONSEQUENTIAL DAMAGES OR ANY DAMAGES WHATSOEVER RESULTING FROM LOSS OF USE, DATA OR PROFITS, WHETHER IN AN ACTION OF CONTRACT, NEGLIGENCE OR OTHER TORTIOUS ACTION, ARISING OUT OF OR IN CONNECTION WITH THE USE OR PERFORMANCE OF THIS SOFTWARE.

License of the generator

Copyright (c) 2019-2023 Michael Büsch <m@bues.ch>

This program is free software; you can redistribute it and/or modify it under the terms of the GNU General Public License as published by the Free Software Foundation; either version 2 of the License, or (at your option) any later version.

This program is distributed in the hope that it will be useful, but WITHOUT ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU General Public License for more details.

You should have received a copy of the GNU General Public License along with this program; if not, write to the Free Software Foundation, Inc., 51 Franklin Street, Fifth Floor, Boston, MA 02110-1301 USA.

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

crcgen-2.6.tar.gz (23.2 kB view details)

Uploaded Source

File details

Details for the file crcgen-2.6.tar.gz.

File metadata

  • Download URL: crcgen-2.6.tar.gz
  • Upload date:
  • Size: 23.2 kB
  • Tags: Source
  • Uploaded using Trusted Publishing? No
  • Uploaded via: twine/4.0.2 CPython/3.11.6

File hashes

Hashes for crcgen-2.6.tar.gz
Algorithm Hash digest
SHA256 c1546bd8d97d50cec6755fd42deafc4d99bb869378184700b768b614bd2edc4c
MD5 05cd3f1d3c09940e47c1f7658b4f7feb
BLAKE2b-256 be30e80f8be56c378d4c9074086806152fd8ce5e477dfefe07776536cd985922

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