//***************************************************************************** // // crc.c // // Driver for the CRC module. // // Copyright (C) 2014 Texas Instruments Incorporated - http://www.ti.com/ // // // Redistribution and use in source and binary forms, with or without // modification, are permitted provided that the following conditions // are met: // // Redistributions of source code must retain the above copyright // notice, this list of conditions and the following disclaimer. // // Redistributions in binary form must reproduce the above copyright // notice, this list of conditions and the following disclaimer in the // documentation and/or other materials provided with the // distribution. // // Neither the name of Texas Instruments Incorporated nor the names of // its contributors may be used to endorse or promote products derived // from this software without specific prior written permission. // // THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS // "AS IS" AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT // LIMITED TO, THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR // A PARTICULAR PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT // OWNER OR CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, // SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT // LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, // DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY // THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT // (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE // OF THIS SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE. // //***************************************************************************** //***************************************************************************** // //! \addtogroup CRC_Cyclic_Redundancy_Check_api //! @{ // //***************************************************************************** #include #include #include "inc/hw_dthe.h" #include "inc/hw_memmap.h" #include "inc/hw_types.h" #include "crc.h" #include "debug.h" //***************************************************************************** // //! Set the configuration of CRC functionality with the EC module. //! //! \param ui32Base is the base address of the EC module. //! \param ui32CRCConfig is the configuration of the CRC engine. //! //! This function configures the operation of the CRC engine within the EC //! module. The configuration is specified with the \e ui32CRCConfig argument. //! It is the logical OR of any of the following options: //! //! CRC Initialization Value //! - \b EC_CRC_CFG_INIT_SEED - Initialize with seed value //! - \b EC_CRC_CFG_INIT_0 - Initialize to all '0s' //! - \b EC_CRC_CFG_INIT_1 - Initialize to all '1s' //! //! Input Data Size //! - \b EC_CRC_CFG_SIZE_8BIT - Input data size of 8 bits //! - \b EC_CRC_CFG_SIZE_32BIT - Input data size of 32 bits //! //! Post Process Reverse/Inverse //! - \b EC_CRC_CFG_RESINV - Result inverse enable //! - \b EC_CRC_CFG_OBR - Output reverse enable //! //! Input Bit Reverse //! - \b EC_CRC_CFG_IBR - Bit reverse enable //! //! Endian Control //! - \b EC_CRC_CFG_ENDIAN_SBHW - Swap byte in half-word //! - \b EC_CRC_CFG_ENDIAN_SHW - Swap half-word //! //! Operation Type //! - \b EC_CRC_CFG_TYPE_P8005 - Polynomial 0x8005 //! - \b EC_CRC_CFG_TYPE_P1021 - Polynomial 0x1021 //! - \b EC_CRC_CFG_TYPE_P4C11DB7 - Polynomial 0x4C11DB7 //! - \b EC_CRC_CFG_TYPE_P1EDC6F41 - Polynomial 0x1EDC6F41 //! - \b EC_CRC_CFG_TYPE_TCPCHKSUM - TCP checksum //! //! \return None. // //***************************************************************************** void CRCConfigSet(uint32_t ui32Base, uint32_t ui32CRCConfig) { // // Check the arguments. // ASSERT(ui32Base == DTHE_BASE); ASSERT((ui32CRCConfig & CRC_CFG_INIT_SEED) || (ui32CRCConfig & CRC_CFG_INIT_0) || (ui32CRCConfig & CRC_CFG_INIT_1) || (ui32CRCConfig & CRC_CFG_SIZE_8BIT) || (ui32CRCConfig & CRC_CFG_SIZE_32BIT) || (ui32CRCConfig & CRC_CFG_RESINV) || (ui32CRCConfig & CRC_CFG_OBR) || (ui32CRCConfig & CRC_CFG_IBR) || (ui32CRCConfig & CRC_CFG_ENDIAN_SBHW) || (ui32CRCConfig & CRC_CFG_ENDIAN_SHW) || (ui32CRCConfig & CRC_CFG_TYPE_P8005) || (ui32CRCConfig & CRC_CFG_TYPE_P1021) || (ui32CRCConfig & CRC_CFG_TYPE_P4C11DB7) || (ui32CRCConfig & CRC_CFG_TYPE_P1EDC6F41) || (ui32CRCConfig & CRC_CFG_TYPE_TCPCHKSUM)); // // Write the control register with the configuration. // HWREG(ui32Base + DTHE_O_CRC_CTRL) = ui32CRCConfig; } //***************************************************************************** // //! Write the seed value for CRC operations in the EC module. //! //! \param ui32Base is the base address of the EC module. //! \param ui32Seed is the seed value. //! //! This function writes the seed value for use with CRC operations in the //! EC module. This value is the start value for CRC operations. If this //! value is not written, then the residual seed from the previous operation //! is used as the starting value. //! //! \note The seed must be written only if \b EC_CRC_CFG_INIT_SEED is //! set with the CRCConfigSet() function. // //***************************************************************************** void CRCSeedSet(uint32_t ui32Base, uint32_t ui32Seed) { // // Check the arguments. // ASSERT(ui32Base == DTHE_BASE); // // Write the seed value to the seed register. // HWREG(ui32Base + DTHE_O_CRC_SEED) = ui32Seed; } //***************************************************************************** // //! Write data into the EC module for CRC operations. //! //! \param ui32Base is the base address of the EC module. //! \param ui32Data is the data to be written. //! //! This function writes either 8 or 32 bits of data into the EC module for //! CRC operations. The distinction between 8 and 32 bits of data is made //! when the \b EC_CRC_CFG_SIZE_8BIT or \b EC_CRC_CFG_SIZE_32BIT flag //! is set using the CRCConfigSet() function. //! //! When writing 8 bits of data, ensure the data is in the least signficant //! byte position. The remaining bytes should be written with zero. For //! example, when writing 0xAB, \e ui32Data should be 0x000000AB. //! //! \return None // //***************************************************************************** void CRCDataWrite(uint32_t ui32Base, uint32_t ui32Data) { // // Check the arguments. // ASSERT(ui32Base == DTHE_BASE); // // Write the data // HWREG(DTHE_BASE + DTHE_O_CRC_DIN) = ui32Data; } //***************************************************************************** // //! Reads the result of a CRC operation in the EC module. //! //! \param ui32Base is the base address of the EC module. //! //! This function reads either the unmodified CRC result or the post //! processed CRC result from the EC module. The post-processing options //! are selectable through \b EC_CRC_CFG_RESINV and \b EC_CRC_CFG_OBR //! parameters in the CRCConfigSet() function. //! //! \return The CRC result. // //***************************************************************************** uint32_t CRCResultRead(uint32_t ui32Base) { // // Check the arguments. // ASSERT(ui32Base == DTHE_BASE); // // return value. // return(HWREG(DTHE_BASE + DTHE_O_CRC_RSLT_PP)); } //***************************************************************************** // //! Process data to generate a CRC with the EC module. //! //! \param ui32Base is the base address of the EC module. //! \param puiDataIn is a pointer to an array of data that is processed. //! \param ui32DataLength is the number of data items that are processed //! to produce the CRC. //! \param ui32Config the config parameter to determine the CRC mode //! //! This function processes an array of data to produce a CRC result. //! This function takes the CRC mode as the parameter. //! //! The data in the array pointed to be \e pui32DataIn is either an array //! of bytes or an array or words depending on the selection of the input //! data size options \b EC_CRC_CFG_SIZE_8BIT and //! \b EC_CRC_CFG_SIZE_32BIT. //! //! This function returns either the unmodified CRC result or the //! post- processed CRC result from the EC module. The post-processing //! options are selectable through \b EC_CRC_CFG_RESINV and //! \b EC_CRC_CFG_OBR parameters. //! //! \return The CRC result. // //***************************************************************************** uint32_t CRCDataProcess(uint32_t ui32Base, void *puiDataIn, uint32_t ui32DataLength, uint32_t ui32Config) { uint8_t *pui8DataIn; uint32_t *pui32DataIn; // // Check the arguments. // ASSERT(ui32Base == DTHE_BASE); // // See if the CRC is operating in 8-bit or 32-bit mode. // if(ui32Config & DTHE_CRC_CTRL_SIZE) { // // The CRC is operating in 8-bit mode, so create an 8-bit pointer to // the data. // pui8DataIn = (uint8_t *)puiDataIn; // // Loop through the input data. // while(ui32DataLength--) { // // Write the next data byte. // HWREG(ui32Base + DTHE_O_CRC_DIN) = *pui8DataIn++; } } else { // // The CRC is operating in 32-bit mode, so loop through the input data. // pui32DataIn = (uint32_t *)puiDataIn; while(ui32DataLength--) { // // Write the next data word. // HWREG(ui32Base + DTHE_O_CRC_DIN) = *pui32DataIn++; } } // // Return the result. // return(CRCResultRead(ui32Base)); } //***************************************************************************** // // Close the Doxygen group. //! @} // //*****************************************************************************