- Visual C++源码
- Visual Basic源码
- C++ Builder源码
- Java源码
- Delphi源码
- C/C++源码
- PHP源码
- Perl源码
- Python源码
- Asm源码
- Pascal源码
- Borland C++源码
- Others源码
- SQL源码
- VBScript源码
- JavaScript源码
- ASP/ASPX源码
- C#源码
- Flash/ActionScript源码
- matlab源码
- PowerBuilder源码
- LabView源码
- Flex源码
- MathCAD源码
- VBA源码
- IDL源码
- Lisp/Scheme源码
- VHDL源码
- Objective-C源码
- Fortran源码
- tcl/tk源码
- QT源码
INCHKSUM.ASM
资源名称:ertos.rar [点击查看]
上传用户:sunrenlu
上传日期:2022-06-13
资源大小:1419k
文件大小:1k
源码类别:
操作系统开发
开发平台:
DOS
- ;
- ;
- ; Usage :
- ; void far *inchksum()
- ;
- ; Internet compatible 1's complement checksum
- ;
- ; (c) 1990 Erick Engelke
- ;
- ; version
- ;
- ; 0.1 17 Dec -1990 E. P. Engelke
- ;
- ;
- include masmdefs.hsm
- include model.hsm
- codedef INCHKSUM
- datadef
- cstart INCHKSUM
- cpublic inchksum
- ; Compute 1's-complement sum of data buffer
- ;
- ; unsigned lcsum( usigned far *buf, unsigned cnt)
- push DS
- lds SI, +@AB + 0 [BP]
- mov CX, +@AB + 4 [BP] ; cx = cnt
- mov BL, CL
- shr CX, 1 ; group into words
- xor DX, DX ; set checksum to 0
- cld
- jcxz remain
- clc
- deloop: lodsw
- adc DX, AX
- loop deloop
- adc DX, 0 ; only two necessary
- adc DX, 0
- remain: and BL, 1
- jz done
- xor AH, AH
- lodsb
- add DX, AX
- adc DX, 0
- adc DX, 0
- done: mov AX,DX ; result into ax
- or AX,AX
- ok: pop DS
- creturn inchksum
- cend INCHKSUM
- end