/**************************************************************************//**
* [url=home.php?mod=space&uid=288409]@file[/url] main.c
* [url=home.php?mod=space&uid=895143]@version[/url] V2.10
* $Date: 15/06/30 11:25a $
* [url=home.php?mod=space&uid=247401]@brief[/url] Calculate the CRC-CCITT checksum value by CRC DMA mode.
*
* @note
* Copyright (C) 2014 Nuvoton Technology Corp. All rights reserved.
*
******************************************************************************/
#include <stdio.h>
#include <string.h>
#include "nano100series.h"
uint8_t volatile g_u8IsTargetAbortINTFlag = 0, g_u8IsBlockTransferDoneINTFlag = 0;
/**
* @brief DMA IRQ
*
* @param None
*
* [url=home.php?mod=space&uid=266161]@return[/url] None
*
* [url=home.php?mod=space&uid=1543424]@Details[/url] The DMA default IRQ, declared in startup_nano100series.s.
*/
void PDMA_IRQHandler(void)
{
uint32_t status = CRC_GET_INT_FLAG();
if (status & DMA_CRC_DMAISR_BLKD_IF_Msk) {
/* Clear Block Transfer Done Interrupt Flag */
CRC_CLR_INT_FLAG(DMA_CRC_DMAISR_BLKD_IF_Msk);
g_u8IsBlockTransferDoneINTFlag++;
} else if (status & DMA_CRC_DMAISR_TABORT_IF_Msk) {
/* Clear Target Abort Interrupt Flag */
CRC_CLR_INT_FLAG(DMA_CRC_DMAISR_TABORT_IF_Msk);
g_u8IsTargetAbortINTFlag++;
} else {
printf("Un-expected interrupts. \n");
}
}
void SYS_Init(void)
{
/* Unlock protected registers */
SYS_UnlockReg();
/* Enable external 12MHz HXT */
CLK_EnableXtalRC(CLK_PWRCTL_HXT_EN_Msk);
CLK_EnablePLL(CLK_PLLCTL_PLL_SRC_HXT, 96000000);
/* Waiting for clock ready */
CLK_WaitClockReady(CLK_CLKSTATUS_HXT_STB_Msk | CLK_CLKSTATUS_PLL_STB_Msk);
CLK_SetHCLK(CLK_CLKSEL0_HCLK_S_PLL, CLK_HCLK_CLK_DIVIDER(3));
CLK->AHBCLK |= CLK_AHBCLK_DMA_EN_Msk;
/* Select IP clock source */
CLK_SetModuleClock(UART0_MODULE, CLK_CLKSEL1_UART_S_HXT, CLK_UART_CLK_DIVIDER(1));
/* Enable IP clock */
CLK_EnableModuleClock(UART0_MODULE);
/*---------------------------------------------------------------------------------------------------------*/
/* Init I/O Multi-function */
/*---------------------------------------------------------------------------------------------------------*/
/* Set PA multi-function pins for UART0 RXD and TXD */
// SYS->PA_H_MFP &= ~( SYS_PA_H_MFP_PA15_MFP_Msk | SYS_PA_H_MFP_PA14_MFP_Msk);
// SYS->PA_H_MFP |= (SYS_PA_H_MFP_PA15_MFP_UART0_TX|SYS_PA_H_MFP_PA14_MFP_UART0_RX);
SYS->PB_L_MFP &= ~( SYS_PB_L_MFP_PB0_MFP_Msk | SYS_PB_L_MFP_PB1_MFP_Msk);
SYS->PB_L_MFP |= (SYS_PB_L_MFP_PB1_MFP_UART0_TX|SYS_PB_L_MFP_PB0_MFP_UART0_RX);
/* Lock protected registers */
SYS_LockReg();
}
void UART0_Init(void)
{
/* Reset IP */
SYS_ResetModule(UART0_RST);
UART0->BAUD = 0x67; /* Baud Rate:115200 OSC:12MHz */
UART0->TLCTL = 0x03; /* Character len is 8 bits */
}
/*---------------------------------------------------------------------------------------------------------*/
/* CRC-CCITT Polynomial Mode Test */
/*---------------------------------------------------------------------------------------------------------*/
void CRC_CCITTPolyModeTest(uint32_t u32SrcAddr, uint32_t u32TransByteCount)
{
uint32_t u32TargetChecksum = 0x29B1, u32CalChecksum = 0;
printf("# Calculate string \"123456789\" CRC-CCITT checksum value by CRC DMA mode. \n");
printf(" - Seed value is 0xFFFF \n");
printf(" - Checksum Complement disable \n");
printf(" - Checksum Reverse disable \n");
printf(" - Write Data Complement disable \n");
printf(" - Write Data Reverse disable \n");
printf(" - Checksum should be 0x%X \n", u32TargetChecksum);
printf("... \n\n");
g_u8IsTargetAbortINTFlag = g_u8IsBlockTransferDoneINTFlag = 0;
/* Enable CRC channel clock */
/* Configure CRC Operation Settings for CRC DMA mode */
CRC_Open(CRC_CCITT, 0, 0xFFFF, 0);
/* Enable DMA Target Abort and Block Transfer Done Interrupt */
CRC_ENABLE_INT(DMA_CRC_DMAIER_TABORT_IE_Msk|DMA_CRC_DMAIER_BLKD_IE_Msk);
/* Enable PDMA and CRC NVIC */
NVIC_EnableIRQ(PDMA_IRQn);
/* Trigger CRC DMA transfer */
CRC_StartDMATransfer(u32SrcAddr, u32TransByteCount);
/* Wait CRC Interrupt Flag occurred */
while (1) {
if (g_u8IsTargetAbortINTFlag == 1) {
printf("DMA Target Abort Interrupt occurred. \n");
break;
}
if (g_u8IsBlockTransferDoneINTFlag == 1) {
break;
}
}
/* Disable PDMA and CRC NVIC */
NVIC_DisableIRQ(PDMA_IRQn);
/* Get CRC Checksum value */
u32CalChecksum = CRC_GetChecksum();
if (g_u8IsBlockTransferDoneINTFlag == 1) {
printf("CRC checksum is 0x%X ... %s.\n", u32CalChecksum, (u32CalChecksum==u32TargetChecksum)?"PASS":"FAIL");
}
printf("\n");
}
/*---------------------------------------------------------------------------------------------------------*/
/* CRC-8 Polynomial Mode Test */
/*---------------------------------------------------------------------------------------------------------*/
void CRC_CRC8PolyModeTest(uint32_t u32SrcAddr, uint32_t u32TransByteCount)
{
uint32_t i = 0;
uint32_t u32TargetChecksum = 0x58, u32CalChecksum = 0;
uint8_t *p8SrcAddr;
printf("# Calculate string \"123456789\" CRC-8 checksum value by CRC CPU mode. \n");
printf(" - Seed value is 0x5A \n");
printf(" - CPU Write Length is 8-bit \n");
printf(" - Checksum Complement disable \n");
printf(" - Checksum Reverse disable \n");
printf(" - Write Data Complement disable \n");
printf(" - Write Data Reverse disable \n");
printf(" - Checksum should be 0x%X \n", u32TargetChecksum);
printf("... \n\n");
p8SrcAddr = (uint8_t *)u32SrcAddr;
/* Enable CRC channel clock */
/* Configure CRC Operation Settings for CRC DMA mode */
CRC_Open(CRC_8, 0, 0x5A, CRC_CPU_WDATA_8);
for (i=0; i<u32TransByteCount; i++) {
CRC_WRITE_DATA((p8SrcAddr[i]&0xFF));
}
/* Get CRC Checksum value */
u32CalChecksum = CRC_GetChecksum();
printf("CRC checksum is 0x%X ... %s.\n", u32CalChecksum, (u32CalChecksum==u32TargetChecksum)?"PASS":"FAIL");
printf("\n");
}
/*---------------------------------------------------------------------------------------------------------*/
/* MAIN function */
/*---------------------------------------------------------------------------------------------------------*/
int main (void)
{
const uint8_t acCRCSrcPattern[] = "123456789";
/* Init System, IP clock and multi-function I/O */
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.
/* Init UART for printf */
UART0_Init();
printf("\n\nCPU [url=home.php?mod=space&uid=72445]@[/url] %dHz \n", SystemCoreClock);
printf("+--------------------------------------+ \n");
printf("| NANO100 CRC Driver Sample Code | \n");
printf("+--------------------------------------+ \n");
printf(" CRC-CCITT Polynomial mode test \n");
CRC_CCITTPolyModeTest((uint32_t )acCRCSrcPattern, strlen((char *)acCRCSrcPattern));
printf(" CRC-8 Polynomial mode test \n");
CRC_CRC8PolyModeTest((uint32_t )acCRCSrcPattern, strlen((char *)acCRCSrcPattern));
printf("\nExit CRC Sample Code. \n");
while(1);
}
|