 
;By Dr. Imre Bartfai
; What you need is to define the polynomial. E. g. for the CCITT one:
poly0	equ	$21
poly1	equ	$10
; Do not forget to initialize <crcval> = <crch:crcl> before the 1st call
; e. g. with 0xFF or with zeroes, as the particular CRC algorithm
; requires.
;This subroutine calculates a 16-bit CRC
;--------
; CrcUpd: update <crcval> using <W>
;
;
crch	DS 1
crcl	DS 1
saved	DS 1
oldcch	DS 1
i	DS 1
CrcUpd	mov	saved, W	; j = W
	mov	W, #8		; W = 8
	mov	i, W		; i = W
_loop	mov	W, crch
	mov	oldcch, W	; temporary save
	clrb	C		; clear carry for rlf
	rl	crcl		; crc << 1
	rl	crch
	mov	W, saved	; the char read
	xor	oldcch, W	; test with old high
	sb	oldcch.7	; if bit set, apply mask
        jmp     _notset         ; otherwise skip
	mov	W, #poly0
	xor	crcl, W
	mov	W, #poly1
	xor	crch, W
_notset	clrb	C		; for rl
	rl	saved		; next bit of saved
	decsz	i
        jmp     _loop
	ret
;
; End CrcUpd
| file: /Techref/scenix/lib/io/osi2/crc_sx.htm, 1KB, , updated: 2001/5/19 20:49, local time: 2025/10/23 04:44, 
 
216.73.216.53,10-2-207-162:LOG IN | 
| ©2025 These pages are served without commercial sponsorship. (No popup ads, etc...).Bandwidth abuse increases hosting cost forcing sponsorship or shutdown. This server aggressively defends against automated copying for any reason including offline viewing, duplication, etc... Please respect this requirement and DO NOT RIP THIS SITE. Questions? <A HREF="http://techref.massmind.org/techref/scenix/lib/io/osi2/crc_sx.htm"> SX Specific Cyclic Redundancy Check 16 and 32 Bit </A> | 
| Did you find what you needed? | 
| Welcome to massmind.org! | 
| Welcome to techref.massmind.org! | 
.