1 /*
2 * Copyright 2008-2012 Freescale Semiconductor Inc.
3 *
4 * Redistribution and use in source and binary forms, with or without
5 * modification, are permitted provided that the following conditions are met:
6 * * Redistributions of source code must retain the above copyright
7 * notice, this list of conditions and the following disclaimer.
8 * * Redistributions in binary form must reproduce the above copyright
9 * notice, this list of conditions and the following disclaimer in the
10 * documentation and/or other materials provided with the distribution.
11 * * Neither the name of Freescale Semiconductor nor the
12 * names of its contributors may be used to endorse or promote products
13 * derived from this software without specific prior written permission.
14 *
15 *
16 * ALTERNATIVELY, this software may be distributed under the terms of the
17 * GNU General Public License ("GPL") as published by the Free Software
18 * Foundation, either version 2 of that License or (at your option) any
19 * later version.
20 *
21 * THIS SOFTWARE IS PROVIDED BY Freescale Semiconductor ``AS IS'' AND ANY
22 * EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE IMPLIED
23 * WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE ARE
24 * DISCLAIMED. IN NO EVENT SHALL Freescale Semiconductor BE LIABLE FOR ANY
25 * DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR CONSEQUENTIAL DAMAGES
26 * (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF SUBSTITUTE GOODS OR SERVICES;
27 * LOSS OF USE, DATA, OR PROFITS; OR BUSINESS INTERRUPTION) HOWEVER CAUSED AND
28 * ON ANY THEORY OF LIABILITY, WHETHER IN CONTRACT, STRICT LIABILITY, OR TORT
29 * (INCLUDING NEGLIGENCE OR OTHERWISE) ARISING IN ANY WAY OUT OF THE USE OF THIS
30 * SOFTWARE, EVEN IF ADVISED OF THE POSSIBILITY OF SUCH DAMAGE.
31 */
32
33
34 /**************************************************************************//**
35 @File crc64.h
36
37 @Description brief This file contains the CRC64 Table, and __inline__
38 functions used for calculating crc.
39 *//***************************************************************************/
40 #ifndef __CRC64_H
41 #define __CRC64_H
42
43 #include "std_ext.h"
44
45
46 #define BITS_PER_BYTE 8
47
48 #define CRC64_EXPON_ECMA_182 0xC96C5795D7870F42ULL
49 #define CRC64_DEFAULT_INITVAL 0xFFFFFFFFFFFFFFFFULL
50
51 #define CRC64_BYTE_MASK 0xFF
52 #define CRC64_TABLE_ENTRIES ( 1 << BITS_PER_BYTE )
53 #define CRC64_ODD_MASK 1
54
55
56 /**
57 \brief '64 bit crc' Table
58 */
59 struct crc64_t {
60 uint64_t initial; /**< Initial seed */
61 uint64_t table[CRC64_TABLE_ENTRIES]; /**< CRC table entries */
62 };
63
64
65 static struct crc64_t CRC64_ECMA_182 = {
66 CRC64_DEFAULT_INITVAL,
67 {
68 0x0000000000000000ULL,
69 0xb32e4cbe03a75f6fULL,
70 0xf4843657a840a05bULL,
71 0x47aa7ae9abe7ff34ULL,
72 0x7bd0c384ff8f5e33ULL,
73 0xc8fe8f3afc28015cULL,
74 0x8f54f5d357cffe68ULL,
75 0x3c7ab96d5468a107ULL,
76 0xf7a18709ff1ebc66ULL,
77 0x448fcbb7fcb9e309ULL,
78 0x0325b15e575e1c3dULL,
79 0xb00bfde054f94352ULL,
80 0x8c71448d0091e255ULL,
81 0x3f5f08330336bd3aULL,
82 0x78f572daa8d1420eULL,
83 0xcbdb3e64ab761d61ULL,
84 0x7d9ba13851336649ULL,
85 0xceb5ed8652943926ULL,
86 0x891f976ff973c612ULL,
87 0x3a31dbd1fad4997dULL,
88 0x064b62bcaebc387aULL,
89 0xb5652e02ad1b6715ULL,
90 0xf2cf54eb06fc9821ULL,
91 0x41e11855055bc74eULL,
92 0x8a3a2631ae2dda2fULL,
93 0x39146a8fad8a8540ULL,
94 0x7ebe1066066d7a74ULL,
95 0xcd905cd805ca251bULL,
96 0xf1eae5b551a2841cULL,
97 0x42c4a90b5205db73ULL,
98 0x056ed3e2f9e22447ULL,
99 0xb6409f5cfa457b28ULL,
100 0xfb374270a266cc92ULL,
101 0x48190ecea1c193fdULL,
102 0x0fb374270a266cc9ULL,
103 0xbc9d3899098133a6ULL,
104 0x80e781f45de992a1ULL,
105 0x33c9cd4a5e4ecdceULL,
106 0x7463b7a3f5a932faULL,
107 0xc74dfb1df60e6d95ULL,
108 0x0c96c5795d7870f4ULL,
109 0xbfb889c75edf2f9bULL,
110 0xf812f32ef538d0afULL,
111 0x4b3cbf90f69f8fc0ULL,
112 0x774606fda2f72ec7ULL,
113 0xc4684a43a15071a8ULL,
114 0x83c230aa0ab78e9cULL,
115 0x30ec7c140910d1f3ULL,
116 0x86ace348f355aadbULL,
117 0x3582aff6f0f2f5b4ULL,
118 0x7228d51f5b150a80ULL,
119 0xc10699a158b255efULL,
120 0xfd7c20cc0cdaf4e8ULL,
121 0x4e526c720f7dab87ULL,
122 0x09f8169ba49a54b3ULL,
123 0xbad65a25a73d0bdcULL,
124 0x710d64410c4b16bdULL,
125 0xc22328ff0fec49d2ULL,
126 0x85895216a40bb6e6ULL,
127 0x36a71ea8a7ace989ULL,
128 0x0adda7c5f3c4488eULL,
129 0xb9f3eb7bf06317e1ULL,
130 0xfe5991925b84e8d5ULL,
131 0x4d77dd2c5823b7baULL,
132 0x64b62bcaebc387a1ULL,
133 0xd7986774e864d8ceULL,
134 0x90321d9d438327faULL,
135 0x231c512340247895ULL,
136 0x1f66e84e144cd992ULL,
137 0xac48a4f017eb86fdULL,
138 0xebe2de19bc0c79c9ULL,
139 0x58cc92a7bfab26a6ULL,
140 0x9317acc314dd3bc7ULL,
141 0x2039e07d177a64a8ULL,
142 0x67939a94bc9d9b9cULL,
143 0xd4bdd62abf3ac4f3ULL,
144 0xe8c76f47eb5265f4ULL,
145 0x5be923f9e8f53a9bULL,
146 0x1c4359104312c5afULL,
147 0xaf6d15ae40b59ac0ULL,
148 0x192d8af2baf0e1e8ULL,
149 0xaa03c64cb957be87ULL,
150 0xeda9bca512b041b3ULL,
151 0x5e87f01b11171edcULL,
152 0x62fd4976457fbfdbULL,
153 0xd1d305c846d8e0b4ULL,
154 0x96797f21ed3f1f80ULL,
155 0x2557339fee9840efULL,
156 0xee8c0dfb45ee5d8eULL,
157 0x5da24145464902e1ULL,
158 0x1a083bacedaefdd5ULL,
159 0xa9267712ee09a2baULL,
160 0x955cce7fba6103bdULL,
161 0x267282c1b9c65cd2ULL,
162 0x61d8f8281221a3e6ULL,
163 0xd2f6b4961186fc89ULL,
164 0x9f8169ba49a54b33ULL,
165 0x2caf25044a02145cULL,
166 0x6b055fede1e5eb68ULL,
167 0xd82b1353e242b407ULL,
168 0xe451aa3eb62a1500ULL,
169 0x577fe680b58d4a6fULL,
170 0x10d59c691e6ab55bULL,
171 0xa3fbd0d71dcdea34ULL,
172 0x6820eeb3b6bbf755ULL,
173 0xdb0ea20db51ca83aULL,
174 0x9ca4d8e41efb570eULL,
175 0x2f8a945a1d5c0861ULL,
176 0x13f02d374934a966ULL,
177 0xa0de61894a93f609ULL,
178 0xe7741b60e174093dULL,
179 0x545a57dee2d35652ULL,
180 0xe21ac88218962d7aULL,
181 0x5134843c1b317215ULL,
182 0x169efed5b0d68d21ULL,
183 0xa5b0b26bb371d24eULL,
184 0x99ca0b06e7197349ULL,
185 0x2ae447b8e4be2c26ULL,
186 0x6d4e3d514f59d312ULL,
187 0xde6071ef4cfe8c7dULL,
188 0x15bb4f8be788911cULL,
189 0xa6950335e42fce73ULL,
190 0xe13f79dc4fc83147ULL,
191 0x521135624c6f6e28ULL,
192 0x6e6b8c0f1807cf2fULL,
193 0xdd45c0b11ba09040ULL,
194 0x9aefba58b0476f74ULL,
195 0x29c1f6e6b3e0301bULL,
196 0xc96c5795d7870f42ULL,
197 0x7a421b2bd420502dULL,
198 0x3de861c27fc7af19ULL,
199 0x8ec62d7c7c60f076ULL,
200 0xb2bc941128085171ULL,
201 0x0192d8af2baf0e1eULL,
202 0x4638a2468048f12aULL,
203 0xf516eef883efae45ULL,
204 0x3ecdd09c2899b324ULL,
205 0x8de39c222b3eec4bULL,
206 0xca49e6cb80d9137fULL,
207 0x7967aa75837e4c10ULL,
208 0x451d1318d716ed17ULL,
209 0xf6335fa6d4b1b278ULL,
210 0xb199254f7f564d4cULL,
211 0x02b769f17cf11223ULL,
212 0xb4f7f6ad86b4690bULL,
213 0x07d9ba1385133664ULL,
214 0x4073c0fa2ef4c950ULL,
215 0xf35d8c442d53963fULL,
216 0xcf273529793b3738ULL,
217 0x7c0979977a9c6857ULL,
218 0x3ba3037ed17b9763ULL,
219 0x888d4fc0d2dcc80cULL,
220 0x435671a479aad56dULL,
221 0xf0783d1a7a0d8a02ULL,
222 0xb7d247f3d1ea7536ULL,
223 0x04fc0b4dd24d2a59ULL,
224 0x3886b22086258b5eULL,
225 0x8ba8fe9e8582d431ULL,
226 0xcc0284772e652b05ULL,
227 0x7f2cc8c92dc2746aULL,
228 0x325b15e575e1c3d0ULL,
229 0x8175595b76469cbfULL,
230 0xc6df23b2dda1638bULL,
231 0x75f16f0cde063ce4ULL,
232 0x498bd6618a6e9de3ULL,
233 0xfaa59adf89c9c28cULL,
234 0xbd0fe036222e3db8ULL,
235 0x0e21ac88218962d7ULL,
236 0xc5fa92ec8aff7fb6ULL,
237 0x76d4de52895820d9ULL,
238 0x317ea4bb22bfdfedULL,
239 0x8250e80521188082ULL,
240 0xbe2a516875702185ULL,
241 0x0d041dd676d77eeaULL,
242 0x4aae673fdd3081deULL,
243 0xf9802b81de97deb1ULL,
244 0x4fc0b4dd24d2a599ULL,
245 0xfceef8632775faf6ULL,
246 0xbb44828a8c9205c2ULL,
247 0x086ace348f355aadULL,
248 0x34107759db5dfbaaULL,
249 0x873e3be7d8faa4c5ULL,
250 0xc094410e731d5bf1ULL,
251 0x73ba0db070ba049eULL,
252 0xb86133d4dbcc19ffULL,
253 0x0b4f7f6ad86b4690ULL,
254 0x4ce50583738cb9a4ULL,
255 0xffcb493d702be6cbULL,
256 0xc3b1f050244347ccULL,
257 0x709fbcee27e418a3ULL,
258 0x3735c6078c03e797ULL,
259 0x841b8ab98fa4b8f8ULL,
260 0xadda7c5f3c4488e3ULL,
261 0x1ef430e13fe3d78cULL,
262 0x595e4a08940428b8ULL,
263 0xea7006b697a377d7ULL,
264 0xd60abfdbc3cbd6d0ULL,
265 0x6524f365c06c89bfULL,
266 0x228e898c6b8b768bULL,
267 0x91a0c532682c29e4ULL,
268 0x5a7bfb56c35a3485ULL,
269 0xe955b7e8c0fd6beaULL,
270 0xaeffcd016b1a94deULL,
271 0x1dd181bf68bdcbb1ULL,
272 0x21ab38d23cd56ab6ULL,
273 0x9285746c3f7235d9ULL,
274 0xd52f0e859495caedULL,
275 0x6601423b97329582ULL,
276 0xd041dd676d77eeaaULL,
277 0x636f91d96ed0b1c5ULL,
278 0x24c5eb30c5374ef1ULL,
279 0x97eba78ec690119eULL,
280 0xab911ee392f8b099ULL,
281 0x18bf525d915feff6ULL,
282 0x5f1528b43ab810c2ULL,
283 0xec3b640a391f4fadULL,
284 0x27e05a6e926952ccULL,
285 0x94ce16d091ce0da3ULL,
286 0xd3646c393a29f297ULL,
287 0x604a2087398eadf8ULL,
288 0x5c3099ea6de60cffULL,
289 0xef1ed5546e415390ULL,
290 0xa8b4afbdc5a6aca4ULL,
291 0x1b9ae303c601f3cbULL,
292 0x56ed3e2f9e224471ULL,
293 0xe5c372919d851b1eULL,
294 0xa26908783662e42aULL,
295 0x114744c635c5bb45ULL,
296 0x2d3dfdab61ad1a42ULL,
297 0x9e13b115620a452dULL,
298 0xd9b9cbfcc9edba19ULL,
299 0x6a978742ca4ae576ULL,
300 0xa14cb926613cf817ULL,
301 0x1262f598629ba778ULL,
302 0x55c88f71c97c584cULL,
303 0xe6e6c3cfcadb0723ULL,
304 0xda9c7aa29eb3a624ULL,
305 0x69b2361c9d14f94bULL,
306 0x2e184cf536f3067fULL,
307 0x9d36004b35545910ULL,
308 0x2b769f17cf112238ULL,
309 0x9858d3a9ccb67d57ULL,
310 0xdff2a94067518263ULL,
311 0x6cdce5fe64f6dd0cULL,
312 0x50a65c93309e7c0bULL,
313 0xe388102d33392364ULL,
314 0xa4226ac498dedc50ULL,
315 0x170c267a9b79833fULL,
316 0xdcd7181e300f9e5eULL,
317 0x6ff954a033a8c131ULL,
318 0x28532e49984f3e05ULL,
319 0x9b7d62f79be8616aULL,
320 0xa707db9acf80c06dULL,
321 0x14299724cc279f02ULL,
322 0x5383edcd67c06036ULL,
323 0xe0ada17364673f59ULL
324 }
325 };
326
327
328 /**
329 \brief Initializes the crc seed
330 */
crc64_init(void)331 static __inline__ uint64_t crc64_init(void)
332 {
333 return CRC64_ECMA_182.initial;
334 }
335
336 /**
337 \brief Computes 64 bit the crc
338 \param[in] data Pointer to the Data in the frame
339 \param[in] len Length of the Data
340 \param[in] crc seed
341 \return calculated crc
342 */
crc64_compute(void const * data,uint32_t len,uint64_t seed)343 static __inline__ uint64_t crc64_compute(void const *data,
344 uint32_t len,
345 uint64_t seed)
346 {
347 uint32_t i;
348 uint64_t crc = seed;
349 uint8_t *bdata = (uint8_t *) data;
350
351 for (i = 0; i < len; i++)
352 crc =
353 CRC64_ECMA_182.
354 table[(crc ^ *bdata++) & CRC64_BYTE_MASK] ^ (crc >> 8);
355
356 return crc;
357 }
358
359
360 #endif /* __CRC64_H */
361