Suma kontrolna SIO
From Atariki
(Różnice między wersjami)
Wersja z dnia 22:42, 8 kwi 2010 KMK (Dyskusja | wkład) ← Previous diff |
Wersja z dnia 22:49, 8 kwi 2010 KMK (Dyskusja | wkład) Next diff → |
||
Linia 1: | Linia 1: | ||
- | Z angielskiego ''cyclic redundancy check'', czyli [http://pl.wikipedia.org/wiki/Cykliczny_kod_nadmiarowy cykliczny kod nadmiarowy], liczba dołączana do bloku przesyłanych danych, zapewniająca weryfikację poprawności przesłania. | + | Z angielskiego ''cyclic redundancy check'', czyli [http://pl.wikipedia.org/wiki/Cykliczny_kod_nadmiarowy cykliczny kod nadmiarowy], obliczana w pewien określony z góry sposób i dołączana do bloku przesyłanych danych wartość, zapewniająca weryfikację poprawności przesłania. |
W praktyce skrót CRC stosuje się często (acz niezbyt prawidłowo) na określenie [http://pl.wikipedia.org/wiki/Suma_kontrolna sumy kontrolnej]. | W praktyce skrót CRC stosuje się często (acz niezbyt prawidłowo) na określenie [http://pl.wikipedia.org/wiki/Suma_kontrolna sumy kontrolnej]. |
Wersja z dnia 22:49, 8 kwi 2010
Z angielskiego cyclic redundancy check, czyli cykliczny kod nadmiarowy, obliczana w pewien określony z góry sposób i dołączana do bloku przesyłanych danych wartość, zapewniająca weryfikację poprawności przesłania.
W praktyce skrót CRC stosuje się często (acz niezbyt prawidłowo) na określenie sumy kontrolnej.
Suma kontrolna SIO
SIO oblicza sumę kontrolną dodając do siebie kolejne bajty przesyłanego bloku, przy czym do wyniku każdego z dodawań dodawane jest przeniesienie. Przykład obliczenia sumy kontrolnej 256 bajtów umieszczonych pod arbitralnie wybranym adresem w pamięci (oznaczonym etykietą DATA):
LDX #$00 STX CHKSUM CRC LDA DATA,X CLC ADC CHKSUM ADC #$00 STA CHKSUM INX BNE CRC
W języku C (wynik w zmiennej cks):
unsigned char cks = 0; unsigned short nck; int i; for (i = 0; i < 256; i++) { nck = cks + data[i]; cks = (nck > 0x00ff) ? ((nck & 0x00ff) + 1) : (nck & 0x00ff); }