crc.h 4.1 KB

123456789101112131415161718192021222324252627282930313233343536373839404142434445464748495051525354555657585960616263646566676869707172737475767778798081828384858687888990919293949596979899100101102103104105106107108109110111112
  1. /**************************************************************************//**
  2. * @file crc.h
  3. * @version V1.00
  4. * @brief M480 series CRC driver header file
  5. *
  6. * @copyright (C) 2016 Nuvoton Technology Corp. All rights reserved.
  7. *****************************************************************************/
  8. #ifndef __CRC_H__
  9. #define __CRC_H__
  10. #ifdef __cplusplus
  11. extern "C"
  12. {
  13. #endif
  14. /** @addtogroup Standard_Driver Standard Driver
  15. @{
  16. */
  17. /** @addtogroup CRC_Driver CRC Driver
  18. @{
  19. */
  20. /** @addtogroup CRC_EXPORTED_CONSTANTS CRC Exported Constants
  21. @{
  22. */
  23. /*---------------------------------------------------------------------------------------------------------*/
  24. /* CRC Polynomial Mode Constant Definitions */
  25. /*---------------------------------------------------------------------------------------------------------*/
  26. #define CRC_CCITT (0UL << CRC_CTL_CRCMODE_Pos) /*!<CRC Polynomial Mode - CCITT \hideinitializer */
  27. #define CRC_8 (1UL << CRC_CTL_CRCMODE_Pos) /*!<CRC Polynomial Mode - CRC8 \hideinitializer */
  28. #define CRC_16 (2UL << CRC_CTL_CRCMODE_Pos) /*!<CRC Polynomial Mode - CRC16 \hideinitializer */
  29. #define CRC_32 (3UL << CRC_CTL_CRCMODE_Pos) /*!<CRC Polynomial Mode - CRC32 \hideinitializer */
  30. /*---------------------------------------------------------------------------------------------------------*/
  31. /* Checksum, Write data Constant Definitions */
  32. /*---------------------------------------------------------------------------------------------------------*/
  33. #define CRC_CHECKSUM_COM (CRC_CTL_CHKSFMT_Msk) /*!<CRC Checksum Complement \hideinitializer */
  34. #define CRC_CHECKSUM_RVS (CRC_CTL_CHKSREV_Msk) /*!<CRC Checksum Reverse \hideinitializer */
  35. #define CRC_WDATA_COM (CRC_CTL_DATFMT_Msk) /*!<CRC Write Data Complement \hideinitializer */
  36. #define CRC_WDATA_RVS (CRC_CTL_DATREV_Msk) /*!<CRC Write Data Reverse \hideinitializer */
  37. /*---------------------------------------------------------------------------------------------------------*/
  38. /* CPU Write Data Length Constant Definitions */
  39. /*---------------------------------------------------------------------------------------------------------*/
  40. #define CRC_CPU_WDATA_8 (0UL << CRC_CTL_DATLEN_Pos) /*!<CRC CPU Write Data length is 8-bit \hideinitializer */
  41. #define CRC_CPU_WDATA_16 (1UL << CRC_CTL_DATLEN_Pos) /*!<CRC CPU Write Data length is 16-bit \hideinitializer */
  42. #define CRC_CPU_WDATA_32 (2UL << CRC_CTL_DATLEN_Pos) /*!<CRC CPU Write Data length is 32-bit \hideinitializer */
  43. /*@}*/ /* end of group CRC_EXPORTED_CONSTANTS */
  44. /** @addtogroup CRC_EXPORTED_FUNCTIONS CRC Exported Functions
  45. @{
  46. */
  47. /**
  48. * @brief Set CRC Seed Value
  49. *
  50. * @param[in] u32Seed Seed value
  51. *
  52. * @return None
  53. *
  54. * @details This macro is used to set CRC seed value.
  55. *
  56. * @note User must to perform CRC_CHKSINIT(CRC_CTL[1] CRC Engine Reset) to reload the new seed value
  57. * to CRC controller.
  58. * \hideinitializer
  59. */
  60. #define CRC_SET_SEED(u32Seed) do{ CRC->SEED = (u32Seed); CRC->CTL |= CRC_CTL_CHKSINIT_Msk; }while(0)
  61. /**
  62. * @brief Get CRC Seed Value
  63. *
  64. * @param None
  65. *
  66. * @return CRC seed value
  67. *
  68. * @details This macro gets the current CRC seed value.
  69. * \hideinitializer
  70. */
  71. #define CRC_GET_SEED() (CRC->SEED)
  72. /**
  73. * @brief CRC Write Data
  74. *
  75. * @param[in] u32Data Write data
  76. *
  77. * @return None
  78. *
  79. * @details User can write data directly to CRC Write Data Register(CRC_DAT) by this macro to perform CRC operation.
  80. * \hideinitializer
  81. */
  82. #define CRC_WRITE_DATA(u32Data) (CRC->DAT = (u32Data))
  83. void CRC_Open(uint32_t u32Mode, uint32_t u32Attribute, uint32_t u32Seed, uint32_t u32DataLen);
  84. uint32_t CRC_GetChecksum(void);
  85. /*@}*/ /* end of group CRC_EXPORTED_FUNCTIONS */
  86. /*@}*/ /* end of group CRC_Driver */
  87. /*@}*/ /* end of group Standard_Driver */
  88. #ifdef __cplusplus
  89. }
  90. #endif
  91. #endif
  92. /*** (C) COPYRIGHT 2016 Nuvoton Technology Corp. ***/