Hi Ich habe hier mal ein kleines Programm, dass die CRC über einen
Datenstrom von variabler Länge bildet. Ich habe selbst mehrere Tage und
sehr große Hilfe aus diesem Forum benötigt und möchte die Lösung deshalb
für Anfänger auf diesem Gebiet (wie ich selbst) zur Verfügung stellen.
1 | /* Funktion zur eigentlichen Generierung der CRC */
|
2 |
|
3 | uint16_t crc_update(uint16_t crc, uint8_t daten, uint16_t mask)
|
4 | {
|
5 | uint8_t i;
|
6 |
|
7 | for(i = 0; i < 8; i++)
|
8 | {
|
9 | if((crc ^ daten) & 1)
|
10 | {
|
11 | crc = (uint16_t)((crc >> 1) ^ mask);
|
12 | }
|
13 | else
|
14 | {
|
15 | crc >>= 1;
|
16 | }
|
17 | daten >>= 1;
|
18 | }
|
19 | return (crc);
|
20 | }
|
21 |
|
22 |
|
23 |
|
24 | int main()
|
25 | {
|
26 |
|
27 | ...
|
28 |
|
29 | uint32_t data_len; /* Länge des Datenstroms */
|
30 | uint16_t crcmask = 0xC599; /* Polynom für CRC (hier CAN CRC) */
|
31 | uint8_t data[] /* Array für Daten */
|
32 | uint16_t crc = 0; /* Initialisierung von 'crc' */
|
33 |
|
34 | ...
|
35 |
|
36 | /* Hier wird die Funktion crc_update für jedes Byte des
|
37 | ** Datenstroms aufgerufen */
|
38 |
|
39 | for(i = 0; i < data_len; i++)
|
40 | {
|
41 | crc = crc_update(crc, data[i], crcmask);
|
42 | }
|
43 |
|
44 | ...
|
45 | }
|
Anschließend kann zum Test die CRC mit dem Low Byte zuerst an den
Datenstrom angehängt werden und die mit dem selben Algorithmus über den
neuen, gesamten Datenstrom gebildete CRC sollte '0' ergeben.
MfG