xref: /btstack/port/msp432p401lp-cc256x/ti/devices/msp432p4xx/driverlib/crc32.c (revision 5fd0122a3e19d95e11e1f3eb8a08a2b2acb2557e)
1*5fd0122aSMatthias Ringwald /* --COPYRIGHT--,BSD
2*5fd0122aSMatthias Ringwald  * Copyright (c) 2017, Texas Instruments Incorporated
3*5fd0122aSMatthias Ringwald  * All rights reserved.
4*5fd0122aSMatthias Ringwald  *
5*5fd0122aSMatthias Ringwald  * Redistribution and use in source and binary forms, with or without
6*5fd0122aSMatthias Ringwald  * modification, are permitted provided that the following conditions
7*5fd0122aSMatthias Ringwald  * are met:
8*5fd0122aSMatthias Ringwald  *
9*5fd0122aSMatthias Ringwald  * *  Redistributions of source code must retain the above copyright
10*5fd0122aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer.
11*5fd0122aSMatthias Ringwald  *
12*5fd0122aSMatthias Ringwald  * *  Redistributions in binary form must reproduce the above copyright
13*5fd0122aSMatthias Ringwald  *    notice, this list of conditions and the following disclaimer in the
14*5fd0122aSMatthias Ringwald  *    documentation and/or other materials provided with the distribution.
15*5fd0122aSMatthias Ringwald  *
16*5fd0122aSMatthias Ringwald  * *  Neither the name of Texas Instruments Incorporated nor the names of
17*5fd0122aSMatthias Ringwald  *    its contributors may be used to endorse or promote products derived
18*5fd0122aSMatthias Ringwald  *    from this software without specific prior written permission.
19*5fd0122aSMatthias Ringwald  *
20*5fd0122aSMatthias Ringwald  * THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
21*5fd0122aSMatthias Ringwald  * AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO,
22*5fd0122aSMatthias Ringwald  * THE IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR
23*5fd0122aSMatthias Ringwald  * PURPOSE ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT OWNER OR
24*5fd0122aSMatthias Ringwald  * CONTRIBUTORS BE LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL,
25*5fd0122aSMatthias Ringwald  * EXEMPLARY, OR CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO,
26*5fd0122aSMatthias Ringwald  * PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS;
27*5fd0122aSMatthias Ringwald  * OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY,
28*5fd0122aSMatthias Ringwald  * WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR
29*5fd0122aSMatthias Ringwald  * OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE,
30*5fd0122aSMatthias Ringwald  * EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31*5fd0122aSMatthias Ringwald  * --/COPYRIGHT--*/
32*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/crc32.h>
33*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/inc/msp.h>
34*5fd0122aSMatthias Ringwald #include <ti/devices/msp432p4xx/driverlib/debug.h>
35*5fd0122aSMatthias Ringwald 
36*5fd0122aSMatthias Ringwald 
CRC32_setSeed(uint32_t seed,uint_fast8_t crcType)37*5fd0122aSMatthias Ringwald void CRC32_setSeed(uint32_t seed, uint_fast8_t crcType)
38*5fd0122aSMatthias Ringwald {
39*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
40*5fd0122aSMatthias Ringwald 
41*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
42*5fd0122aSMatthias Ringwald         CRC32->INIRES16 = seed;
43*5fd0122aSMatthias Ringwald     else
44*5fd0122aSMatthias Ringwald     {
45*5fd0122aSMatthias Ringwald         CRC32->INIRES32_HI = ((seed & 0xFFFF0000) >> 16);
46*5fd0122aSMatthias Ringwald         CRC32->INIRES32_LO = (seed & 0xFFFF);
47*5fd0122aSMatthias Ringwald     }
48*5fd0122aSMatthias Ringwald }
49*5fd0122aSMatthias Ringwald 
CRC32_set8BitData(uint8_t dataIn,uint_fast8_t crcType)50*5fd0122aSMatthias Ringwald void CRC32_set8BitData(uint8_t dataIn, uint_fast8_t crcType)
51*5fd0122aSMatthias Ringwald {
52*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
53*5fd0122aSMatthias Ringwald 
54*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
55*5fd0122aSMatthias Ringwald         HWREG8(&(CRC32->DI16)) = dataIn;
56*5fd0122aSMatthias Ringwald     else
57*5fd0122aSMatthias Ringwald         HWREG8(&(CRC32->DI32)) = dataIn;
58*5fd0122aSMatthias Ringwald }
59*5fd0122aSMatthias Ringwald 
CRC32_set16BitData(uint16_t dataIn,uint_fast8_t crcType)60*5fd0122aSMatthias Ringwald void CRC32_set16BitData(uint16_t dataIn, uint_fast8_t crcType)
61*5fd0122aSMatthias Ringwald {
62*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
63*5fd0122aSMatthias Ringwald 
64*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
65*5fd0122aSMatthias Ringwald         CRC32->DI16 = dataIn;
66*5fd0122aSMatthias Ringwald     else
67*5fd0122aSMatthias Ringwald         CRC32->DI32 = dataIn;
68*5fd0122aSMatthias Ringwald }
69*5fd0122aSMatthias Ringwald 
CRC32_set32BitData(uint32_t dataIn)70*5fd0122aSMatthias Ringwald void CRC32_set32BitData(uint32_t dataIn)
71*5fd0122aSMatthias Ringwald {
72*5fd0122aSMatthias Ringwald     //CRC32->DI32 = dataIn & 0xFFFF;
73*5fd0122aSMatthias Ringwald     //CRC32->DI32 = (uint16_t) ((dataIn & 0xFFFF0000) >> 16);
74*5fd0122aSMatthias Ringwald 
75*5fd0122aSMatthias Ringwald     HWREG16(&(CRC32->DI32)) = dataIn & 0xFFFF;
76*5fd0122aSMatthias Ringwald     HWREG16(&(CRC32->DI32)) = (uint16_t)(
77*5fd0122aSMatthias Ringwald             (dataIn & 0xFFFF0000) >> 16);
78*5fd0122aSMatthias Ringwald }
79*5fd0122aSMatthias Ringwald 
CRC32_set8BitDataReversed(uint8_t dataIn,uint_fast8_t crcType)80*5fd0122aSMatthias Ringwald void CRC32_set8BitDataReversed(uint8_t dataIn, uint_fast8_t crcType)
81*5fd0122aSMatthias Ringwald {
82*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
83*5fd0122aSMatthias Ringwald 
84*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
85*5fd0122aSMatthias Ringwald         HWREG8(&(CRC32->DIRB16)) = dataIn;
86*5fd0122aSMatthias Ringwald     else
87*5fd0122aSMatthias Ringwald         HWREG8(&(CRC32->DIRB32)) = dataIn;
88*5fd0122aSMatthias Ringwald }
89*5fd0122aSMatthias Ringwald 
CRC32_set16BitDataReversed(uint16_t dataIn,uint_fast8_t crcType)90*5fd0122aSMatthias Ringwald void CRC32_set16BitDataReversed(uint16_t dataIn, uint_fast8_t crcType)
91*5fd0122aSMatthias Ringwald {
92*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
93*5fd0122aSMatthias Ringwald 
94*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
95*5fd0122aSMatthias Ringwald         CRC32->DIRB16 = dataIn;
96*5fd0122aSMatthias Ringwald     else
97*5fd0122aSMatthias Ringwald         CRC32->DIRB32 = dataIn;
98*5fd0122aSMatthias Ringwald }
99*5fd0122aSMatthias Ringwald 
CRC32_set32BitDataReversed(uint32_t dataIn)100*5fd0122aSMatthias Ringwald void CRC32_set32BitDataReversed(uint32_t dataIn)
101*5fd0122aSMatthias Ringwald {
102*5fd0122aSMatthias Ringwald     //CRC32->DIRB32 = dataIn & 0xFFFF;
103*5fd0122aSMatthias Ringwald     //CRC32->DIRB32 = (uint16_t) ((dataIn & 0xFFFF0000) >> 16);
104*5fd0122aSMatthias Ringwald 
105*5fd0122aSMatthias Ringwald     HWREG16(&(CRC32->DIRB32)) = dataIn & 0xFFFF;
106*5fd0122aSMatthias Ringwald     HWREG16(&(CRC32->DIRB32)) = (uint16_t)(
107*5fd0122aSMatthias Ringwald             (dataIn & 0xFFFF0000) >> 16);
108*5fd0122aSMatthias Ringwald 
109*5fd0122aSMatthias Ringwald }
110*5fd0122aSMatthias Ringwald 
CRC32_getResult(uint_fast8_t crcType)111*5fd0122aSMatthias Ringwald uint32_t CRC32_getResult(uint_fast8_t crcType)
112*5fd0122aSMatthias Ringwald {
113*5fd0122aSMatthias Ringwald     uint32_t result;
114*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
115*5fd0122aSMatthias Ringwald 
116*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
117*5fd0122aSMatthias Ringwald         return CRC32->INIRES16;
118*5fd0122aSMatthias Ringwald     else
119*5fd0122aSMatthias Ringwald     {
120*5fd0122aSMatthias Ringwald         result = CRC32->INIRES32_HI;
121*5fd0122aSMatthias Ringwald         result = (result << 16);
122*5fd0122aSMatthias Ringwald         result |= (uint32_t) CRC32->INIRES32_LO;
123*5fd0122aSMatthias Ringwald         return (result);
124*5fd0122aSMatthias Ringwald     }
125*5fd0122aSMatthias Ringwald }
126*5fd0122aSMatthias Ringwald 
CRC32_getResultReversed(uint_fast8_t crcType)127*5fd0122aSMatthias Ringwald uint32_t CRC32_getResultReversed(uint_fast8_t crcType)
128*5fd0122aSMatthias Ringwald {
129*5fd0122aSMatthias Ringwald     uint32_t result;
130*5fd0122aSMatthias Ringwald     ASSERT((CRC16_MODE == crcType) || (CRC32_MODE == crcType));
131*5fd0122aSMatthias Ringwald 
132*5fd0122aSMatthias Ringwald     if (CRC16_MODE == crcType)
133*5fd0122aSMatthias Ringwald         return CRC32->RESR16;
134*5fd0122aSMatthias Ringwald     else
135*5fd0122aSMatthias Ringwald     {
136*5fd0122aSMatthias Ringwald         result = CRC32->RESR32_HI;
137*5fd0122aSMatthias Ringwald         result = (result << 16);
138*5fd0122aSMatthias Ringwald         result |= (uint32_t) CRC32->RESR32_LO;
139*5fd0122aSMatthias Ringwald         return (result);
140*5fd0122aSMatthias Ringwald     }
141*5fd0122aSMatthias Ringwald }
142*5fd0122aSMatthias Ringwald 
143