Hallo Forengemeinde, ich muss eine Software-CRC über 30bit mit einem 5bit Polynom machen. Dabei hab ich eine Frage: An die Message sind (Polybit)-1 Nullen anzuhängen und dann das übliche Verfahren durchzuführen. Nun passt das ganze aber nicht mehr in ein uint32_t Datentypen. Wie würdet ihr das am besten, schnellsten, effizientesten ohne LUT prozessieren? Hintergrund: Ich schicke etwas per DMA-SPI doublebuffer raus, was einen CRC-Remainder über die Nachricht erfordert. Während der eine Buffer gesendet wird lege ich den zweiten Buffer fest, der unter anderem dann eine CRC-Prüfsumme verschickt. Beste Grüße
Andere Frage... ist dein Polynom dazu geeignet deine Daten ausreichend zu schützen? Ein standard CRC5 hat laut Tante Wiki eine Länge von 31 und eine MHD von 3.
Hallo Frank, danke für den Hinweis. Mein Empfänger erwartet eine CRC5, sonst verwirft er die gesendeten Pakete. Den Empfänger muss ich als gegen nehmen und ihm jetzt passende Pakete mit der enthaltenen CRC5 schicken. Beste Grüße
Nachtrag: Es handelt sich um eine "CRC-CCITT (CRC-4)" also x^4+x+1
Problem hat sich soeben gelöst, trotzdem danke.
1 | #define POLYNOMIAL 0x98000000 /* 10011 followed by 0's */ |
2 | |
3 | uint32_t crcNaive(uint32_t message){ |
4 | uint32_t remainder = message; |
5 | for (uint8_t bit = 32; bit > 0; --bit){ |
6 | if (remainder & 0x80000000) |
7 | {
|
8 | remainder ^= POLYNOMIAL; |
9 | }
|
10 | remainder = (remainder << 1); |
11 | }
|
12 | return (remainder >> 28); |
13 | }
|
Bitte melde dich an um einen Beitrag zu schreiben. Anmeldung ist kostenlos und dauert nur eine Minute.
Bestehender Account
Schon ein Account bei Google/GoogleMail? Keine Anmeldung erforderlich!
Mit Google-Account einloggen
Mit Google-Account einloggen
Noch kein Account? Hier anmelden.