1.10 DMAC CRC-32 Generation

This example application demonstrates how to use the DMAC peripheral to compute 32-bit Cyclic Redundancy Checksum (CRC).

Description

The DMAC unit provides support for calculating a CRC-16 and CRC-32 value for data passing through any DMA channel.

This example application computes the 32-bit CRC value for the polynomial (0x04C11DB7) using the CRC engine in DMAC peripheral.

It uses a DMA Channel with software trigger to initiate a memory-memory transfer from the source buffer to the destination buffer with 8-bit beat size. Once the transfer is completed a 32-bit CRC will be generated for the source buffer.

Once the hardware CRC is generated using a DMA Channel it is validated using a software-calculated CRC value.

Downloading and Building the Application

To clone or download this application from Github, go to the main page of this repository and then click Clone button to clone this repository or download as zip file. This content can also be downloaded using content manager by following these instructions.

Path of the application within the repository is apps/dmac/dmac_crc32_generate/firmware.

To build the application, refer to the following table and open the project using its IDE.

Project NameDescription
pic32mz_ef_sk.XMPLABX project for PIC32MZ Embedded Connectivity with FPU (EF) Starter Kit

Setting Up the Hardware

The following table shows the target hardware for the application projects.

Project NameDescription
pic32mz_ef_sk.XPIC32MZ Embedded Connectivity with FPU (EF) Starter Kit

Setting Up PIC32MZ Embedded Connectivity with FPU (EF) Starter Kit

  • Connect mini USB cables from the ‘Debug USB’ and ‘USB-to-UART’ connectors on the board to the computer

Running the Application

  1. Open the Terminal application (Ex.: Tera term) on the computer
  2. Connect to the “USB to UART” COM port and configure the serial settings as follows:
    • Baud : 115200
    • Data : 8 Bits
    • Parity : None
    • Stop : 1 Bit
    • Flow Control : None
  3. Build and Program the application project using its IDE
  4. Following message is output on console:
    • Expected CRC Value for the polynomial (0x04C11DB7) is (0xcbf43926)
  5. The LED indicates the success or failure:
    • LED is turned ON when the DMAC memory transfer is successful and hardware CRC value matches with the software calculated CRC value
Following table provides LED names: