Cyclic redundancy checks
The amaranth.lib.crc module provides utilities for computing cyclic
redundancy checks (CRCs) in software and in hardware.
CRCs are specified using the Algorithm class, which contains
settings for CRC width, polynomial, initial value, input/output reflection, and
output XOR. Many commonly used CRC algorithms are available in the
catalog module, while most other CRC designs can be
accommodated by manually constructing Algorithm.
Call the Algorithm with a data_width to obtain a
Parameters class, which fully defines a CRC computation. The
Parameters class provides the compute() method
to perform software computations, and the create() method
to create a hardware CRC module, Processor.
# Create a predefined CRC16-CCITT hardware module, using the default
# 8-bit data width (in other words, bytes).
from amaranth.lib.crc.catalog import CRC16_CCITT
crc = m.submodules.crc = CRC16_CCITT().create()
# Create a custom CRC algorithm, specify the data width explicitly,
# and use it to compute a CRC value in software.
from amaranth.lib.crc import Algorithm
algo = Algorithm(crc_width=16, polynomial=0x1021, initial_crc=0xffff,
                 reflect_input=False, reflect_output=False,
                 xor_output=0x0000)
assert algo(data_width=8).compute(b"123456789") == 0x29b1
- class amaranth.lib.crc.Algorithm(*, crc_width, polynomial, initial_crc, reflect_input, reflect_output, xor_output)
- Settings for a CRC algorithm, excluding data width. - The parameter set is based on the Williams model from “A Painless Guide to CRC Error Detection Algorithms”: http://www.ross.net/crc/download/crc_v3.txt - For a reference of standard CRC parameter sets, refer to: - reveng’s catalogue, which uses an identical parameterisation, 
- crcmod’s list of predefined functions, but remove the leading ‘1’ from the polynominal, XOR the “Init-value” with “XOR-out” to obtain - initial_crc, and where “Reversed” is True, set both- reflect_inputand- reflect_outputto True,
- CRC Zoo, which contains only polynomials; use the “explicit +1” form of polynomial but remove the leading ‘1’. 
 - Many commonly used CRC algorithms are available in the - catalogmodule, which includes all entries in the reveng catalogue.- To create a - Parametersinstance, call the- Algorithmobject with the required data width, which defaults to 8 bits.- Parameters:
- crc_width (int) – Bit width of CRC word. Also known as “width” in the Williams model. 
- polynomial (int) – CRC polynomial to use, - crc_widthbits long, without the implicit- x**crc_widthterm. Polynomial is always specified with the highest order terms in the most significant bit positions; use- reflect_inputand- reflect_outputto perform a least significant bit first computation.
- initial_crc (int) – Initial value of CRC register at reset. Most significant bit always corresponds to the highest order term in the CRC register. 
- reflect_input (bool) – If True, the input data words are bit-reflected, so that they are processed least significant bit first. 
- reflect_output (bool) – If True, the output CRC is bit-reflected, so the least-significant bit of the output is the highest-order bit of the CRC register. Note that this reflection is performed over the entire CRC register; for transmission you may want to treat the output as a little-endian multi-word value, so for example the reflected 16-bit output 0x4E4C would be transmitted as the two octets 0x4C 0x4E, each transmitted least significant bit first. 
- xor_output (int) – The output CRC will be the CRC register XOR’d with this value, applied after any output bit-reflection. 
 
 - __call__(data_width=8)
- Constructs a - Parametersinstance from this- Algorithmwith the specified- data_width.- Parameters:
- data_width (int) – Bit width of data words, default 8. 
 
 
- class amaranth.lib.crc.Parameters(algorithm, data_width=8)
- Full set of parameters for a CRC computation. - Contains the settings from - Algorithmand additionally- data_width. Refer to- Algorithmfor details of what each parameter means and how to construct them.- From this class, you can directly compute CRCs with the - compute()method, or construct a hardware module with the- create()method.- Parameters:
 - residue()
- Compute the residue value for this CRC, which is the value left in the CRC register after processing any valid codeword. 
 - create()
- Returns a - Processorconfigured with these parameters.
 - compute(data)
- Computes and returns the CRC of all data words in - data.- Parameters:
- data (iterable of integers) – The CRC is computed over this complete set of data. Each item is an integer of bitwidth equal to - data_width.
 
 
- class amaranth.lib.crc.Processor(*args, src_loc_at=0, **kwargs)
- Cyclic redundancy check (CRC) processor module. - This module generates CRCs from an input data stream, which can be used to validate an existing CRC or generate a new CRC. It is configured by the - Parametersclass, which can handle most forms of CRCs. Refer to that class’s documentation for a description of the parameters.- The CRC value is updated on any clock cycle where - validis asserted, with the updated value available on the- crcoutput on the subsequent clock cycle. The latency is therefore one clock cycle, and the throughput is one data word per clock cycle.- The CRC is reset to its initial value whenever - startis asserted.- startand- validmay be asserted on the same clock cycle, in which case a new CRC computation is started with the current value of- data.- With - data_width=1, a classic bit-serial CRC is implemented for the given polynomial in a Galois-type shift register. For larger values of- data_width, a similar architecture computes every new bit of the CRC in parallel.- The - match_detectedoutput may be used to validate data with a trailing CRC (also known as a codeword). If the most recently processed word(s) form the valid CRC of all the previous data since- startwas asserted, the CRC register will always take on a fixed value known as the residue. The- match_detectedoutput indicates whether the CRC register currently contains this residue.- Parameters:
- parameters (Parameters) – CRC parameters. 
- Variables:
- start (Signal(), in) – Assert to indicate the start of a CRC computation, re-initialising the CRC register to the initial value. May be asserted simultaneously with - validor by itself.
- data (Signal(data_width), in) – Data word to add to CRC when - validis asserted.
- valid (Signal(), in) – Assert when - datais valid to add the data word to the CRC.
- crc (Signal(crc_width), out) – Registered CRC output value, updated one clock cycle after - validbecomes asserted.
- match_detected (Signal(), out) – Asserted if the current CRC value indicates a valid codeword has been received. 
 
 
The following pre-defined CRC algorithms are available:
- Predefined CRC Algorithms- CRC3_GSM
- CRC3_ROHC
- CRC4_G_704
- CRC4_ITU
- CRC4_INTERLAKEN
- CRC5_EPC_C1G2
- CRC5_EPC
- CRC5_G_704
- CRC5_ITU
- CRC5_USB
- CRC6_CDMA2000_A
- CRC6_CDMA2000_B
- CRC6_DARC
- CRC6_G_704
- CRC6_ITU
- CRC6_GSM
- CRC7_MMC
- CRC7_ROHC
- CRC7_UMTS
- CRC8_AUTOSAR
- CRC8_BLUETOOTH
- CRC8_CDMA2000
- CRC8_DARC
- CRC8_DVB_S2
- CRC8_GSM_A
- CRC8_GSM_B
- CRC8_HITAG
- CRC8_I_432_1
- CRC8_ITU
- CRC8_I_CODE
- CRC8_LTE
- CRC8_MAXIM_DOW
- CRC8_MAXIM
- CRC8_MIFARE_MAD
- CRC8_NRSC_5
- CRC8_OPENSAFETY
- CRC8_ROHC
- CRC8_SAE_J1850
- CRC8_SMBUS
- CRC8_TECH_3250
- CRC8_AES
- CRC8_ETU
- CRC8_WCDMA
- CRC10_ATM
- CRC10_I_610
- CRC10_CDMA2000
- CRC10_GSM
- CRC11_FLEXRAY
- CRC11_UMTS
- CRC12_CDMA2000
- CRC12_DECT
- CRC12_GSM
- CRC12_UMTS
- CRC12_3GPP
- CRC13_BBC
- CRC14_DARC
- CRC14_GSM
- CRC15_CAN
- CRC15_MPT1327
- CRC16_ARC
- CRC16_IBM
- CRC16_CDMA2000
- CRC16_CMS
- CRC16_DDS_110
- CRC16_DECT_R
- CRC16_DECT_X
- CRC16_DNP
- CRC16_EN_13757
- CRC16_GENIBUS
- CRC16_DARC
- CRC16_EPC
- CRC16_EPC_C1G2
- CRC16_I_CODE
- CRC16_GSM
- CRC16_IBM_3740
- CRC16_AUTOSAR
- CRC16_CCITT_FALSE
- CRC16_IBM_SDLC
- CRC16_ISO_HDLC
- CRC16_ISO_IEC_14443_3_B
- CRC16_X25
- CRC16_ISO_IEC_14443_3_A
- CRC16_KERMIT
- CRC16_BLUETOOTH
- CRC16_CCITT
- CRC16_CCITT_TRUE
- CRC16_V_41_LSB
- CRC16_LJ1200
- CRC16_M17
- CRC16_MAXIM_DOW
- CRC16_MAXIM
- CRC16_MCRF4XX
- CRC16_MODBUS
- CRC16_NRSC_5
- CRC16_OPENSAFETY_A
- CRC16_OPENSAFETY_B
- CRC16_PROFIBUS
- CRC16_IEC_61158_2
- CRC16_RIELLO
- CRC16_SPI_FUJITSU
- CRC16_AUG_CCITT
- CRC16_T10_DIF
- CRC16_TELEDISK
- CRC16_TMS37157
- CRC16_UMTS
- CRC16_BUYPASS
- CRC16_VERIFONE
- CRC16_USB
- CRC16_XMODEM
- CRC16_ACORN
- CRC16_LTE
- CRC16_V_41_MSB
- CRC16_ZMODEM
- CRC17_CAN_FD
- CRC21_CAN_FD
- CRC24_BLE
- CRC24_FLEXRAY_A
- CRC24_FLEXRAY_B
- CRC24_INTERLAKEN
- CRC24_LTE_A
- CRC24_LTE_B
- CRC24_OPENPGP
- CRC24_OS_9
- CRC30_CDMA
- CRC31_PHILIPS
- CRC32_AIXM
- CRC32_AUTOSAR
- CRC32_BASE91_D
- CRC32_BZIP2
- CRC32_AAL5
- CRC32_DECT_B
- CRC32_CD_ROM_EDC
- CRC32_CKSUM
- CRC32_POSIX
- CRC32_ISCSI
- CRC32_BASE91_C
- CRC32_CASTAGNOLI
- CRC32_INTERLAKEN
- CRC32_ISO_HDLC
- CRC32_ADCCP
- CRC32_V_42
- CRC32_XZ
- CRC32_PKZIP
- CRC32_ETHERNET
- CRC32_JAMCRC
- CRC32_MEF
- CRC32_MPEG_2
- CRC32_XFER
- CRC40_GSM
- CRC64_ECMA_182
- CRC64_GO_ISO
- CRC64_MS
- CRC64_REDIS
- CRC64_WE
- CRC64_XZ
- CRC64_ECMA
- CRC82_DARC