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_ */
							 |