[DemoCode下载] nano100的CRC操作

[复制链接]
978|7
 楼主| 捉虫天师 发表于 2017-12-28 14:25 | 显示全部楼层 |阅读模式
CRC, AN, ck, TE, DM
  1. /**************************************************************************//**
  2. * [url=home.php?mod=space&uid=288409]@file[/url]     main.c
  3. * [url=home.php?mod=space&uid=895143]@version[/url]  V2.10
  4. * $Date: 15/06/30 11:25a $
  5. * [url=home.php?mod=space&uid=247401]@brief[/url]    Calculate the CRC-CCITT checksum value by CRC DMA mode.
  6. *
  7. * @note
  8. * Copyright (C) 2014 Nuvoton Technology Corp. All rights reserved.
  9. *
  10. ******************************************************************************/
  11. #include <stdio.h>
  12. #include <string.h>
  13. #include "nano100series.h"

  14. uint8_t volatile g_u8IsTargetAbortINTFlag = 0, g_u8IsBlockTransferDoneINTFlag = 0;

  15. /**
  16. * @brief       DMA IRQ
  17. *
  18. * @param       None
  19. *
  20. * [url=home.php?mod=space&uid=266161]@return[/url]      None
  21. *
  22. * [url=home.php?mod=space&uid=1543424]@Details[/url]     The DMA default IRQ, declared in startup_nano100series.s.
  23. */
  24. void PDMA_IRQHandler(void)
  25. {
  26.     uint32_t status = CRC_GET_INT_FLAG();
  27.     if (status & DMA_CRC_DMAISR_BLKD_IF_Msk) {
  28.         /* Clear Block Transfer Done Interrupt Flag */
  29.         CRC_CLR_INT_FLAG(DMA_CRC_DMAISR_BLKD_IF_Msk);

  30.         g_u8IsBlockTransferDoneINTFlag++;
  31.     } else if (status & DMA_CRC_DMAISR_TABORT_IF_Msk) {
  32.         /* Clear Target Abort Interrupt Flag */
  33.         CRC_CLR_INT_FLAG(DMA_CRC_DMAISR_TABORT_IF_Msk);

  34.         g_u8IsTargetAbortINTFlag++;
  35.     } else {
  36.         printf("Un-expected interrupts. \n");
  37.     }
  38. }

  39. void SYS_Init(void)
  40. {
  41.     /* Unlock protected registers */
  42.     SYS_UnlockReg();

  43.     /* Enable external 12MHz HXT */
  44.     CLK_EnableXtalRC(CLK_PWRCTL_HXT_EN_Msk);
  45.     CLK_EnablePLL(CLK_PLLCTL_PLL_SRC_HXT, 96000000);
  46.     /* Waiting for clock ready */
  47.     CLK_WaitClockReady(CLK_CLKSTATUS_HXT_STB_Msk | CLK_CLKSTATUS_PLL_STB_Msk);

  48.     CLK_SetHCLK(CLK_CLKSEL0_HCLK_S_PLL, CLK_HCLK_CLK_DIVIDER(3));

  49.     CLK->AHBCLK |= CLK_AHBCLK_DMA_EN_Msk;
  50.     /* Select IP clock source */
  51.     CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UART_S_HXT, CLK_UART_CLK_DIVIDER(1));
  52.     /* Enable IP clock */
  53.     CLK_EnableModuleClock(UART0_MODULE);

  54.     /*---------------------------------------------------------------------------------------------------------*/
  55.     /* Init I/O Multi-function                                                                                 */
  56.     /*---------------------------------------------------------------------------------------------------------*/
  57.     /* Set PA multi-function pins for UART0 RXD and TXD */
  58. //    SYS->PA_H_MFP &= ~( SYS_PA_H_MFP_PA15_MFP_Msk | SYS_PA_H_MFP_PA14_MFP_Msk);
  59. //    SYS->PA_H_MFP |= (SYS_PA_H_MFP_PA15_MFP_UART0_TX|SYS_PA_H_MFP_PA14_MFP_UART0_RX);
  60.     SYS->PB_L_MFP &= ~( SYS_PB_L_MFP_PB0_MFP_Msk | SYS_PB_L_MFP_PB1_MFP_Msk);
  61.     SYS->PB_L_MFP |= (SYS_PB_L_MFP_PB1_MFP_UART0_TX|SYS_PB_L_MFP_PB0_MFP_UART0_RX);

  62.     /* Lock protected registers */
  63.     SYS_LockReg();
  64. }

  65. void UART0_Init(void)
  66. {
  67.     /* Reset IP */
  68.     SYS_ResetModule(UART0_RST);
  69.     UART0->BAUD = 0x67;              /* Baud Rate:115200  OSC:12MHz */
  70.     UART0->TLCTL = 0x03;             /* Character len is 8 bits */
  71. }

  72. /*---------------------------------------------------------------------------------------------------------*/
  73. /*  CRC-CCITT Polynomial Mode Test                                                                         */
  74. /*---------------------------------------------------------------------------------------------------------*/
  75. void CRC_CCITTPolyModeTest(uint32_t u32SrcAddr, uint32_t u32TransByteCount)
  76. {
  77.     uint32_t u32TargetChecksum = 0x29B1, u32CalChecksum = 0;

  78.     printf("# Calculate string "123456789" CRC-CCITT checksum value by CRC DMA mode. \n");
  79.     printf("    - Seed value is 0xFFFF          \n");
  80.     printf("    - Checksum Complement disable   \n");
  81.     printf("    - Checksum Reverse disable      \n");
  82.     printf("    - Write Data Complement disable \n");
  83.     printf("    - Write Data Reverse disable    \n");
  84.     printf("    - Checksum should be 0x%X       \n", u32TargetChecksum);
  85.     printf("... \n\n");

  86.     g_u8IsTargetAbortINTFlag = g_u8IsBlockTransferDoneINTFlag = 0;

  87.     /* Enable CRC channel clock */
  88.     /* Configure CRC Operation Settings for CRC DMA mode */
  89.     CRC_Open(CRC_CCITT, 0, 0xFFFF, 0);

  90.     /* Enable DMA Target Abort and Block Transfer Done Interrupt */
  91.     CRC_ENABLE_INT(DMA_CRC_DMAIER_TABORT_IE_Msk|DMA_CRC_DMAIER_BLKD_IE_Msk);

  92.     /* Enable PDMA and CRC NVIC */
  93.     NVIC_EnableIRQ(PDMA_IRQn);

  94.     /* Trigger CRC DMA transfer */
  95.     CRC_StartDMATransfer(u32SrcAddr, u32TransByteCount);

  96.     /* Wait CRC Interrupt Flag occurred */
  97.     while (1) {
  98.         if (g_u8IsTargetAbortINTFlag == 1) {
  99.             printf("DMA Target Abort Interrupt occurred. \n");
  100.             break;
  101.         }
  102.         if (g_u8IsBlockTransferDoneINTFlag == 1) {
  103.             break;
  104.         }
  105.     }

  106.     /* Disable PDMA and CRC NVIC */
  107.     NVIC_DisableIRQ(PDMA_IRQn);

  108.     /* Get CRC Checksum value */
  109.     u32CalChecksum = CRC_GetChecksum();
  110.     if (g_u8IsBlockTransferDoneINTFlag == 1) {
  111.         printf("CRC checksum is 0x%X ... %s.\n", u32CalChecksum, (u32CalChecksum==u32TargetChecksum)?"PASS":"FAIL");
  112.     }

  113.     printf("\n");
  114. }

  115. /*---------------------------------------------------------------------------------------------------------*/
  116. /*  CRC-8 Polynomial Mode Test                                                                             */
  117. /*---------------------------------------------------------------------------------------------------------*/
  118. void CRC_CRC8PolyModeTest(uint32_t u32SrcAddr, uint32_t u32TransByteCount)
  119. {
  120.     uint32_t i = 0;
  121.     uint32_t u32TargetChecksum = 0x58, u32CalChecksum = 0;
  122.     uint8_t *p8SrcAddr;

  123.     printf("# Calculate string "123456789" CRC-8 checksum value by CRC CPU mode. \n");
  124.     printf("    - Seed value is 0x5A            \n");
  125.     printf("    - CPU Write Length is 8-bit     \n");
  126.     printf("    - Checksum Complement disable   \n");
  127.     printf("    - Checksum Reverse disable      \n");
  128.     printf("    - Write Data Complement disable \n");
  129.     printf("    - Write Data Reverse disable    \n");
  130.     printf("    - Checksum should be 0x%X       \n", u32TargetChecksum);
  131.     printf("... \n\n");

  132.     p8SrcAddr = (uint8_t *)u32SrcAddr;

  133.     /* Enable CRC channel clock */
  134.     /* Configure CRC Operation Settings for CRC DMA mode */
  135.     CRC_Open(CRC_8, 0, 0x5A, CRC_CPU_WDATA_8);

  136.     for (i=0; i<u32TransByteCount; i++) {
  137.         CRC_WRITE_DATA((p8SrcAddr[i]&0xFF));
  138.     }

  139.     /* Get CRC Checksum value */
  140.     u32CalChecksum = CRC_GetChecksum();
  141.     printf("CRC checksum is 0x%X ... %s.\n", u32CalChecksum, (u32CalChecksum==u32TargetChecksum)?"PASS":"FAIL");

  142.     printf("\n");
  143. }


  144. /*---------------------------------------------------------------------------------------------------------*/
  145. /* MAIN function                                                                                           */
  146. /*---------------------------------------------------------------------------------------------------------*/
  147. int main (void)
  148. {
  149.     const uint8_t acCRCSrcPattern[] = "123456789";

  150.     /* Init System, IP clock and multi-function I/O */
  151.     SYS_Init(); //In the end of SYS_Init() will issue SYS_LockReg() to lock protected register. If user want to write protected register, please issue SYS_UnlockReg() to unlock protected register.

  152.     /* Init UART for printf */
  153.     UART0_Init();

  154.     printf("\n\nCPU [url=home.php?mod=space&uid=72445]@[/url] %dHz \n", SystemCoreClock);

  155.     printf("+--------------------------------------+ \n");
  156.     printf("|    NANO100 CRC Driver Sample Code    | \n");
  157.     printf("+--------------------------------------+ \n");

  158.     printf(" CRC-CCITT Polynomial mode test \n");
  159.     CRC_CCITTPolyModeTest((uint32_t )acCRCSrcPattern, strlen((char *)acCRCSrcPattern));

  160.     printf(" CRC-8 Polynomial mode test \n");
  161.     CRC_CRC8PolyModeTest((uint32_t )acCRCSrcPattern, strlen((char *)acCRCSrcPattern));

  162.     printf("\nExit CRC Sample Code. \n");
  163.     while(1);
  164. }




 楼主| 捉虫天师 发表于 2017-12-28 14:25 | 显示全部楼层
新唐的单片机好多提供的有CRC库函数可以用的,非常方便。
734774645 发表于 2017-12-28 19:08 | 显示全部楼层
这个CRC的库函数在哪个头文件
稳稳の幸福 发表于 2017-12-29 19:34 | 显示全部楼层
这个CRC的用法貌似很复杂啊。
zhuotuzi 发表于 2017-12-29 20:03 | 显示全部楼层
看看手册上有没有这个详细介绍
antusheng 发表于 2017-12-30 13:09 | 显示全部楼层
CRC中断是怎么一个过程
xuanhuanzi 发表于 2017-12-30 14:32 | 显示全部楼层
应该再出个CRC教程文档。
wanduzi 发表于 2017-12-31 11:43 | 显示全部楼层
貌似新唐的每个单片机都可以CRC。
您需要登录后才可以回帖 登录 | 注册

本版积分规则

213

主题

3276

帖子

7

粉丝
快速回复 在线客服 返回列表 返回顶部