263 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
			
		
		
	
	
			263 lines
		
	
	
		
			7.7 KiB
		
	
	
	
		
			C
		
	
	
	
	
	
| /*
 | |
|  * @brief LPC11u6x Cyclic Redundancy Check (CRC) Engine driver
 | |
|  *
 | |
|  * @note
 | |
|  * Copyright(C) NXP Semiconductors, 2013
 | |
|  * All rights reserved.
 | |
|  *
 | |
|  * @par
 | |
|  * Software that is described herein is for illustrative purposes only
 | |
|  * which provides customers with programming information regarding the
 | |
|  * LPC products.  This software is supplied "AS IS" without any warranties of
 | |
|  * any kind, and NXP Semiconductors and its licenser disclaim any and
 | |
|  * all warranties, express or implied, including all implied warranties of
 | |
|  * merchantability, fitness for a particular purpose and non-infringement of
 | |
|  * intellectual property rights.  NXP Semiconductors assumes no responsibility
 | |
|  * or liability for the use of the software, conveys no license or rights under any
 | |
|  * patent, copyright, mask work right, or any other intellectual property rights in
 | |
|  * or to any products. NXP Semiconductors reserves the right to make changes
 | |
|  * in the software without notification. NXP Semiconductors also makes no
 | |
|  * representation or warranty that such application will be suitable for the
 | |
|  * specified use without further testing or modification.
 | |
|  *
 | |
|  * @par
 | |
|  * Permission to use, copy, modify, and distribute this software and its
 | |
|  * documentation is hereby granted, under NXP Semiconductors' and its
 | |
|  * licensor's relevant copyrights in the software, without fee, provided that it
 | |
|  * is used in conjunction with NXP Semiconductors microcontrollers.  This
 | |
|  * copyright, permission, and disclaimer notice must appear in all copies of
 | |
|  * this code.
 | |
|  */
 | |
| 
 | |
| #ifndef __CRC_11U6X_H_
 | |
| #define __CRC_11U6X_H_
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| extern "C" {
 | |
| #endif
 | |
| 
 | |
| /** @defgroup CRC_11U6X CHIP: LPC11u6x Cyclic Redundancy Check Engine driver
 | |
|  * @ingroup CHIP_11U6X_Drivers
 | |
|  * @{
 | |
|  */
 | |
| 
 | |
| /**
 | |
|  * @brief CRC register block structure
 | |
|  */
 | |
| typedef struct {					/*!< CRC Structure */
 | |
| 	__IO    uint32_t    MODE;		/*!< CRC Mode Register */
 | |
| 	__IO    uint32_t    SEED;		/*!< CRC SEED Register */
 | |
| 	union {
 | |
| 		__I     uint32_t    SUM;	/*!< CRC Checksum Register. */
 | |
| 		__O     uint32_t    WRDATA32;	/*!< CRC Data Register: write size 32-bit*/
 | |
| 		__O     uint16_t    WRDATA16;	/*!< CRC Data Register: write size 16-bit*/
 | |
| 		__O     uint8_t     WRDATA8;	/*!< CRC Data Register: write size 8-bit*/
 | |
| 	};
 | |
| 
 | |
| } LPC_CRC_T;
 | |
| 
 | |
| /*
 | |
|  * @brief CRC MODE register description
 | |
|  */
 | |
| #define CRC_MODE_POLY_BITMASK   ((0x03))	/** CRC polynomial Bit mask */
 | |
| #define CRC_MODE_POLY_CCITT     (0x00)		/** Select CRC-CCITT polynomial */
 | |
| #define CRC_MODE_POLY_CRC16     (0x01)		/** Select CRC-16 polynomial */
 | |
| #define CRC_MODE_POLY_CRC32     (0x02)		/** Select CRC-32 polynomial */
 | |
| #define CRC_MODE_WRDATA_BITMASK (0x03 << 2)	/** CRC WR_Data Config Bit mask */
 | |
| #define CRC_MODE_WRDATA_BIT_RVS (1 << 2)	/** Select Bit order reverse for WR_DATA (per byte) */
 | |
| #define CRC_MODE_WRDATA_CMPL    (1 << 3)	/** Select One's complement for WR_DATA */
 | |
| #define CRC_MODE_SUM_BITMASK    (0x03 << 4)	/** CRC Sum Config Bit mask */
 | |
| #define CRC_MODE_SUM_BIT_RVS    (1 << 4)	/** Select Bit order reverse for CRC_SUM */
 | |
| #define CRC_MODE_SUM_CMPL       (1 << 5)	/** Select One's complement for CRC_SUM */
 | |
| 
 | |
| #define MODE_CFG_CCITT          (0x00)	/** Pre-defined mode word for default CCITT setup */
 | |
| #define MODE_CFG_CRC16          (0x15)	/** Pre-defined mode word for default CRC16 setup */
 | |
| #define MODE_CFG_CRC32          (0x36)	/** Pre-defined mode word for default CRC32 setup */
 | |
| 
 | |
| #define CRC_SEED_CCITT          (0x0000FFFF)/** Initial seed value for CCITT mode */
 | |
| #define CRC_SEED_CRC16          (0x00000000)/** Initial seed value for CRC16 mode */
 | |
| #define CRC_SEED_CRC32          (0xFFFFFFFF)/** Initial seed value for CRC32 mode */
 | |
| 
 | |
| /**
 | |
|  * @brief CRC polynomial
 | |
|  */
 | |
| typedef enum IP_CRC_001_POLY {
 | |
| 	CRC_POLY_CCITT = CRC_MODE_POLY_CCITT,	/**< CRC-CCIT polynomial */
 | |
| 	CRC_POLY_CRC16 = CRC_MODE_POLY_CRC16,	/**< CRC-16 polynomial */
 | |
| 	CRC_POLY_CRC32 = CRC_MODE_POLY_CRC32,	/**< CRC-32 polynomial */
 | |
| 	CRC_POLY_LAST,
 | |
| } CRC_POLY_T;
 | |
| 
 | |
| /**
 | |
|  * @brief	Initializes the CRC Engine
 | |
|  * @return	Nothing
 | |
|  */
 | |
| void Chip_CRC_Init(void);
 | |
| 
 | |
| /**
 | |
|  * @brief	Deinitializes the CRC Engine
 | |
|  * @return	Nothing
 | |
|  */
 | |
| void Chip_CRC_Deinit(void);
 | |
| 
 | |
| /**
 | |
|  * @brief	Set the polynomial used for the CRC calculation
 | |
|  * @param	poly	: The enumerated polynomial to be used
 | |
|  * @param	flags	: An Or'ed value of flags that setup the mode
 | |
|  * @return	Nothing
 | |
|  * @note	Flags for setting up the mode word include CRC_MODE_WRDATA_BIT_RVS,
 | |
|  * CRC_MODE_WRDATA_CMPL, CRC_MODE_SUM_BIT_RVS, and CRC_MODE_SUM_CMPL.
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_SetPoly(CRC_POLY_T poly, uint32_t flags)
 | |
| {
 | |
| 	LPC_CRC->MODE = (uint32_t) poly | flags;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Sets up the CRC engine for CRC16 mode
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_UseCRC16(void)
 | |
| {
 | |
| 	LPC_CRC->MODE = MODE_CFG_CRC16;
 | |
| 	LPC_CRC->SEED = CRC_SEED_CRC16;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Sets up the CRC engine for CRC32 mode
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_UseCRC32(void)
 | |
| {
 | |
| 	LPC_CRC->MODE = MODE_CFG_CRC32;
 | |
| 	LPC_CRC->SEED = CRC_SEED_CRC32;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Sets up the CRC engine for CCITT mode
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_UseCCITT(void)
 | |
| {
 | |
| 	LPC_CRC->MODE = MODE_CFG_CCITT;
 | |
| 	LPC_CRC->SEED = CRC_SEED_CCITT;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Engage the CRC engine with defaults based on the polynomial to be used
 | |
|  * @param	poly	: The enumerated polynomial to be used
 | |
|  * @return	Nothing
 | |
|  */
 | |
| void Chip_CRC_UseDefaultConfig(CRC_POLY_T poly);
 | |
| 
 | |
| /**
 | |
|  * @brief	Set the CRC Mode bits
 | |
|  * @param	mode	: Mode value
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_SetMode(uint32_t mode)
 | |
| {
 | |
| 	LPC_CRC->MODE = mode;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Get the CRC Mode bits
 | |
|  * @return	The current value of the CRC Mode bits
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_CRC_GetMode(void)
 | |
| {
 | |
| 	return LPC_CRC->MODE;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Set the seed bits used by the CRC_SUM register
 | |
|  * @param	seed	: Seed value
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_SetSeed(uint32_t seed)
 | |
| {
 | |
| 	LPC_CRC->SEED = seed;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Get the CRC seed value
 | |
|  * @return	Seed value
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_CRC_GetSeed(void)
 | |
| {
 | |
| 	return LPC_CRC->SEED;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for writing 8-bit data to the CRC engine
 | |
|  * @param	data	: 8-bit data to write
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_Write8(uint8_t data)
 | |
| {
 | |
| 	LPC_CRC->WRDATA8 = data;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for writing 16-bit data to the CRC engine
 | |
|  * @param	data	: 16-bit data to write
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_Write16(uint16_t data)
 | |
| {
 | |
| 	LPC_CRC->WRDATA16 = data;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for writing 32-bit data to the CRC engine
 | |
|  * @param	data	: 32-bit data to write
 | |
|  * @return	Nothing
 | |
|  */
 | |
| STATIC INLINE void Chip_CRC_Write32(uint32_t data)
 | |
| {
 | |
| 	LPC_CRC->WRDATA32 = data;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Gets the CRC Sum based on the Mode and Seed as previously configured
 | |
|  * @return	CRC Checksum value
 | |
|  */
 | |
| STATIC INLINE uint32_t Chip_CRC_Sum(void)
 | |
| {
 | |
| 	return LPC_CRC->SUM;
 | |
| }
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for computing a standard CCITT checksum from an 8-bit data block
 | |
|  * @param	data	: Pointer to the block of 8-bit data
 | |
|  * @param   bytes	: The number of bytes pointed to by data
 | |
|  * @return	Check sum value
 | |
|  */
 | |
| uint32_t Chip_CRC_CRC8(const uint8_t *data, uint32_t bytes);
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for computing a standard CRC16 checksum from 16-bit data block
 | |
|  * @param	data	: Pointer to the block of 16-bit data
 | |
|  * @param   hwords	: The number of 16 byte entries pointed to by data
 | |
|  * @return	Check sum value
 | |
|  */
 | |
| uint32_t Chip_CRC_CRC16(const uint16_t *data, uint32_t hwords);
 | |
| 
 | |
| /**
 | |
|  * @brief	Convenience function for computing a standard CRC32 checksum from 32-bit data block
 | |
|  * @param	data	: Pointer to the block of 32-bit data
 | |
|  * @param   words	: The number of 32-bit entries pointed to by data
 | |
|  * @return	Check sum value
 | |
|  */
 | |
| uint32_t Chip_CRC_CRC32(const uint32_t *data, uint32_t words);
 | |
| 
 | |
| /**
 | |
|  * @}
 | |
|  */
 | |
| 
 | |
| #ifdef __cplusplus
 | |
| }
 | |
| #endif
 | |
| 
 | |
| #endif /* __CRC_11U6X_H_ */
 | 
