?? crc16.src
字號:
; .\crc16.SRC generated from: crc16.c
; COMPILER INVOKED BY:
; C:\Keil\C51\BIN\C51.EXE crc16.c LARGE BROWSE DEBUG OBJECTEXTEND SRC(.\crc16.SRC)
$NOMOD51
NAME CRC16
CCF2 BIT 0D8H.2
TB80 BIT 098H.3
SPI0CKR DATA 0A2H
CCF3 BIT 0D8H.3
P0 DATA 080H
SPIEN BIT 0F8H.0
CCF4 BIT 0D8H.4
P1 DATA 090H
P2 DATA 0A0H
ADC0CF DATA 0BCH
P3 DATA 0B0H
AC BIT 0D0H.6
PCA0 DATA 0F9H
EIE1 DATA 0E6H
EA BIT 0A8H.7
MCE0 BIT 098H.5
PSCTL DATA 08FH
CF BIT 0D8H.7
IT01CF DATA 0E4H
ADC0CN DATA 0E8H
D0IN BIT 090H.4
P0MDOUT DATA 0A4H
DI BIT 0A0H.4
D1IN BIT 090H.5
P1MDOUT DATA 0A5H
TMR2RLH DATA 0CBH
IE DATA 0A8H
P2MDOUT DATA 0A6H
P3MDOUT DATA 0A7H
TMR3RLH DATA 093H
EIP1 DATA 0F6H
TRIG_OUT BIT 0B0H.4
W_FLG BIT 0A0H.3
TXBMT BIT 0F8H.1
PCA0CPH0 DATA 0FCH
TMR2RLL DATA 0CAH
PCA0CPH1 DATA 0EAH
TMR3RLL DATA 092H
DP DATA 082H
PCA0CPH2 DATA 0ECH
ADC0GT DATA 0C3H
CR BIT 0D8H.6
TF2H BIT 0C8H.7
T2SPLIT BIT 0C8H.3
PCA0CPH3 DATA 0EEH
REN0 BIT 098H.4
PCA0CPH4 DATA 0FEH
PCA0CPL0 DATA 0FBH
RE BIT 0A0H.5
PCA0CPL1 DATA 0E9H
PCA0CPM0 DATA 0DAH
PCA0MD DATA 0D9H
PCA0CN DATA 0D8H
PCA0CPL2 DATA 0EBH
PCA0CPM1 DATA 0DBH
TF2L BIT 0C8H.6
PCA0CPL3 DATA 0EDH
PCA0CPM2 DATA 0DCH
IP DATA 0B8H
ADC0LT DATA 0C5H
X_SCK BIT 080H.0
ARBLOST BIT 0C0H.2
PCA0CPL4 DATA 0FDH
PCA0CPM3 DATA 0DDH
PCA0CPM4 DATA 0DEH
INT0 BIT 080H.7
TXBSY BIT 0F8H.3
CY BIT 0D0H.7
SI BIT 0C0H.0
LEDG BIT 080H.3
XBR0 DATA 0E1H
SMB0CF DATA 0C1H
XBR1 DATA 0E2H
EMI0CN DATA 0AAH
BELL BIT 0A0H.7
REF0CN DATA 0D1H
AD0INT BIT 0E8H.5
SP DATA 081H
OV BIT 0D0H.2
SMB0CN DATA 0C0H
TMR2 DATA 0CCH
TMR3 DATA 094H
MODF BIT 0F8H.5
LEDR BIT 080H.2
RX BIT 080H.5
S0MODE BIT 098H.7
VDM0CN DATA 0FFH
P0MDIN DATA 0F1H
CPT0MD DATA 09DH
CPT0CN DATA 09BH
P1MDIN DATA 0F2H
CPT1MD DATA 09CH
CPT1CN DATA 09AH
TX BIT 080H.4
P2MDIN DATA 0F3H
TF2LEN BIT 0C8H.5
P3MDIN DATA 0F4H
TRIG_IN BIT 0B0H.3
SPI0CN DATA 0F8H
W_RST BIT 0A0H.6
PCON DATA 087H
SPIF BIT 0F8H.7
nsel BIT 090H.0
TMOD DATA 089H
TCON DATA 088H
WCOL BIT 0F8H.6
TRIG BIT 0A0H.1
TMR2CN DATA 0C8H
P0SKIP DATA 0D4H
TMR3CN DATA 091H
nres BIT 080H.7
T2XCLK BIT 0C8H.0
P1SKIP DATA 0D5H
P2SKIP DATA 0D6H
IE0 BIT 088H.1
CPT0MX DATA 09FH
IE1 BIT 088H.3
OSCICL DATA 0B3H
CPT1MX DATA 09EH
CLKSEL DATA 0A9H
sdi BIT 080H.6
B DATA 0F0H
ADC0H DATA 0BEH
OSCICN DATA 0B2H
sck BIT 080H.0
TMR2RL DATA 0CAH
ADC0L DATA 0BDH
TMR3RL DATA 092H
sdo BIT 080H.1
ACC DATA 0E0H
ES0 BIT 0A8H.4
PCA0CP0 DATA 0FBH
AD0EN BIT 0E8H.7
ET0 BIT 0A8H.1
PCA0CP1 DATA 0E9H
ET1 BIT 0A8H.3
TF0 BIT 088H.5
PCA0CP2 DATA 0EBH
D0W BIT 090H.2
ET2 BIT 0A8H.5
RI0 BIT 098H.0
TF1 BIT 088H.7
PCA0CP3 DATA 0EDH
D1W BIT 090H.3
TH0 DATA 08CH
PCA0CP4 DATA 0FDH
EX0 BIT 0A8H.0
TI0 BIT 098H.1
IT0 BIT 088H.0
PCA0H DATA 0FAH
TH1 DATA 08DH
X_CS BIT 090H.1
MASTER BIT 0C0H.7
EX1 BIT 0A8H.2
IT1 BIT 088H.2
P BIT 0D0H.0
ACK BIT 0C0H.1
OSCXCN DATA 0B1H
TL0 DATA 08AH
PCA0L DATA 0F9H
TL1 DATA 08BH
TXMODE BIT 0C0H.6
PS0 BIT 0B8H.4
WIE_CK BIT 0A0H.0
X_SI BIT 080H.6
PT0 BIT 0B8H.1
RS0 BIT 0D0H.3
PT1 BIT 0B8H.3
RS1 BIT 0D0H.4
PT2 BIT 0B8H.5
TR0 BIT 088H.4
AD0TM BIT 0E8H.6
TR1 BIT 088H.6
RELAY_OUT BIT 0B0H.2
TR2 BIT 0C8H.2
PX0 BIT 0B8H.0
PX1 BIT 0B8H.2
X_SO BIT 080H.1
SLVSEL BIT 0F8H.2
DPH DATA 083H
ADC0GTH DATA 0C4H
DPL DATA 082H
ADC0GTL DATA 0C3H
SBUF0 DATA 099H
ADC0LTH DATA 0C6H
RSTSRC DATA 0EFH
FLACL DATA 0B5H
SCON0 DATA 098H
AMX0N DATA 0BAH
ADC0LTL DATA 0C5H
AMX0P DATA 0BBH
STA BIT 0C0H.5
D0OUT BIT 090H.6
SMB0DAT DATA 0C2H
D1OUT BIT 090H.7
TMR2H DATA 0CDH
SPI0CFG DATA 0A1H
TMR3H DATA 095H
CKCON DATA 08EH
IN_OUT BIT 0A0H.2
RXOVRN BIT 0F8H.4
TMR2L DATA 0CCH
ACKRQ BIT 0C0H.3
TMR3L DATA 094H
F0 BIT 0D0H.5
FLSCL DATA 0B6H
RELAY_IN BIT 0B0H.1
AD0CM0 BIT 0E8H.0
F1 BIT 0D0H.1
STO BIT 0C0H.4
AD0CM1 BIT 0E8H.1
SPI0DAT DATA 0A3H
ADC0 DATA 0BDH
AD0CM2 BIT 0E8H.2
AD0WINT BIT 0E8H.3
AD0BUSY BIT 0E8H.4
PSW DATA 0D0H
CCF0 BIT 0D8H.0
RB80 BIT 098H.2
FLKEY DATA 0B7H
CCF1 BIT 0D8H.1
?PR?_cal_crc?CRC16 SEGMENT CODE
?XD?_cal_crc?CRC16 SEGMENT XDATA OVERLAYABLE
?PR?_cksum?CRC16 SEGMENT CODE
?XD?_cksum?CRC16 SEGMENT XDATA OVERLAYABLE
EXTRN CODE (?C?CLDPTR)
EXTRN CODE (?C?LSTKXDATA)
EXTRN CODE (?C?ILDIX)
EXTRN CODE (?C?LSTXDATA)
EXTRN CODE (?C?ULSHR)
PUBLIC _cksum
PUBLIC _cal_crc
RSEG ?XD?_cksum?CRC16
?_cksum?BYTE:
length?145: DS 2
ORG 2
sum?146: DS 4
ORG 6
i?147: DS 2
ORG 8
ptr?148: DS 2
RSEG ?XD?_cal_crc?CRC16
?_cal_crc?BYTE:
len?041: DS 1
ORG 1
i?042: DS 1
; /******************************************************************************
; ** 函數: cal_crc
; ** 入參: unsigned char *ptr, unsigned char len
; ** 返回: unsigned int crc
; ** 作者: jerkoh
; ** 說明:CRC16-CCITT x16+x12+x5+1 1021 初始crc=0; crc=0xffff
; CRC寄存器組初始化為全"0"(0x0000)。
; 注意:CRC寄存器組初始化全為1時,最后CRC應取反
; ******************************************************************************/
; #include "global.h"
;
;
; unsigned int cal_crc(unsigned char *ptr, unsigned char len)
RSEG ?PR?_cal_crc?CRC16
_cal_crc:
USING 0
; SOURCE LINE # 13
MOV DPTR,#len?041
MOV A,R5
MOVX @DPTR,A
;---- Variable 'ptr?040' assigned to Register 'R1/R2/R3' ----
; {
; SOURCE LINE # 14
; unsigned char i;
; unsigned int crc=0xffff;
; SOURCE LINE # 16
;---- Variable 'crc?043' assigned to Register 'R6/R7' ----
MOV A,#0FFH
MOV R7,A
MOV R6,A
?C0001:
;
; while(len--!=0)
; SOURCE LINE # 18
MOV DPTR,#len?041
MOVX A,@DPTR
MOV R5,A
DEC A
MOVX @DPTR,A
MOV A,R5
JZ ?C0002
; {
; SOURCE LINE # 19
; for(i=0x80;i!=0;i/=2) /*8字節*/
; SOURCE LINE # 20
INC DPTR
MOV A,#080H
MOVX @DPTR,A
?C0003:
MOV DPTR,#i?042
MOVX A,@DPTR
JZ ?C0004
; {
; SOURCE LINE # 21
; if((crc&0x8000)!=0)
; SOURCE LINE # 22
MOV A,R6
JNB ACC.7,?C0006
; {
; SOURCE LINE # 23
; crc*=2;
; SOURCE LINE # 24
MOV A,R7
ADD A,ACC
MOV R7,A
MOV A,R6
RLC A
; crc^=0x1021; /*左移異或CRC*/
; SOURCE LINE # 25
XRL A,#010H
MOV R6,A
MOV A,R7
XRL A,#021H
MOV R7,A
; }
; SOURCE LINE # 26
SJMP ?C0007
?C0006:
; else
; {
; SOURCE LINE # 28
; crc*=2;
; SOURCE LINE # 29
MOV A,R7
ADD A,ACC
MOV R7,A
MOV A,R6
RLC A
MOV R6,A
; }
; SOURCE LINE # 30
?C0007:
; if((*ptr&i)!=0) crc^=0x1021;
; SOURCE LINE # 31
LCALL ?C?CLDPTR
MOV R5,A
MOV DPTR,#i?042
MOVX A,@DPTR
ANL A,R5
JZ ?C0005
MOV A,R6
XRL A,#010H
MOV R6,A
MOV A,R7
XRL A,#021H
MOV R7,A
; }
; SOURCE LINE # 32
?C0005:
MOV DPTR,#i?042
MOVX A,@DPTR
CLR C
RRC A
MOVX @DPTR,A
SJMP ?C0003
?C0004:
; ptr++;
; SOURCE LINE # 33
MOV A,#01H
ADD A,R1
MOV R1,A
CLR A
ADDC A,R2
MOV R2,A
;
; }
; SOURCE LINE # 35
SJMP ?C0001
?C0002:
; return(crc);
; SOURCE LINE # 36
; }
; SOURCE LINE # 37
?C0009:
RET
; END OF _cal_crc
;
;
; /******************************************************************************
; ** 函數: cksum()
; ** 入參: rxdata
; ** 返回: sum
; ** 說明:
; ******************************************************************************/
; UINT cksum(UCHAR xdata *check,UINT length) //計算校驗和
RSEG ?PR?_cksum?CRC16
_cksum:
USING 0
; SOURCE LINE # 46
MOV DPTR,#length?145
MOV A,R4
MOVX @DPTR,A
INC DPTR
MOV A,R5
MOVX @DPTR,A
;---- Variable 'check?144' assigned to Register 'R2/R3' ----
MOV R3,AR7
MOV R2,AR6
; {
; SOURCE LINE # 47
; LONG sum=0;
; SOURCE LINE # 48
INC DPTR
LCALL ?C?LSTKXDATA
DB 00H
DB 00H
DB 00H
DB 00H
; UINT i;
; UINT xdata *ptr;
; ptr=(UINT xdata *)check;
; SOURCE LINE # 51
MOV R7,AR3
MOV DPTR,#ptr?148
MOV A,R2
MOVX @DPTR,A
INC DPTR
MOV A,R7
MOVX @DPTR,A
; for (i=0;i<(length)/2;i++)
; SOURCE LINE # 52
CLR A
MOV DPTR,#i?147
MOVX @DPTR,A
INC DPTR
MOVX @DPTR,A
?C0010:
MOV DPTR,#length?145
MOVX A,@DPTR
CLR C
RRC A
MOV R6,A
INC DPTR
MOVX A,@DPTR
RRC A
MOV R7,A
CLR C
MOV DPTR,#i?147+01H
MOVX A,@DPTR
SUBB A,R7
MOV DPTR,#i?147
MOVX A,@DPTR
SUBB A,R6
JNC ?C0011
; {
; SOURCE LINE # 53
; sum+=*ptr++;
; SOURCE LINE # 54
MOV DPTR,#sum?146
MOVX A,@DPTR
MOV R0,A
INC DPTR
MOVX A,@DPTR
MOV R1,A
INC DPTR
MOVX A,@DPTR
MOV R2,A
INC DPTR
MOVX A,@DPTR
MOV R3,A
PUSH AR0
MOV DPTR,#ptr?148
CLR A
MOV B,#02H
LCALL ?C?ILDIX
MOV DPL,B
MOV DPH,A
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
MOV R7,A
CLR A
MOV R4,A
MOV R5,A
POP AR0
MOV A,R3
ADD A,R7
MOV R7,A
MOV A,R2
ADDC A,R6
MOV R6,A
MOV A,R5
ADDC A,R1
MOV R5,A
MOV A,R4
ADDC A,R0
MOV R4,A
MOV DPTR,#sum?146
LCALL ?C?LSTXDATA
; }
; SOURCE LINE # 55
MOV DPTR,#i?147+01H
MOVX A,@DPTR
INC A
MOVX @DPTR,A
JNZ ?C0010
MOV DPTR,#i?147
MOVX A,@DPTR
INC A
MOVX @DPTR,A
?C0016:
SJMP ?C0010
?C0011:
; if (length&0x01)//表示長度為單數
; SOURCE LINE # 56
MOV DPTR,#length?145+01H
MOVX A,@DPTR
JNB ACC.0,?C0013
; {
; SOURCE LINE # 57
; sum=sum+((*ptr)&0xff00);
; SOURCE LINE # 58
INC DPTR
MOVX A,@DPTR
MOV R0,A
INC DPTR
MOVX A,@DPTR
MOV R1,A
INC DPTR
MOVX A,@DPTR
MOV R2,A
INC DPTR
MOVX A,@DPTR
MOV R3,A
MOV DPTR,#ptr?148
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
MOV DPL,A
MOV DPH,R6
MOVX A,@DPTR
MOV R6,A
MOV R7,#00H
CLR A
MOV R4,A
MOV R5,A
MOV A,R7
ADD A,R3
MOV R7,A
MOV A,R2
ADDC A,R6
MOV R6,A
MOV A,R5
ADDC A,R1
MOV R5,A
MOV A,R4
ADDC A,R0
MOV R4,A
MOV DPTR,#sum?146
LCALL ?C?LSTXDATA
; }
; SOURCE LINE # 59
?C0013:
; sum=(sum&0xffff)+((sum>>16)&0xffff); //高16位和低16位相加
; SOURCE LINE # 60
MOV DPTR,#sum?146
MOVX A,@DPTR
MOV R4,A
INC DPTR
MOVX A,@DPTR
MOV R5,A
INC DPTR
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
MOV R7,A
MOV R0,#010H
LCALL ?C?ULSHR
MOV A,R7
MOV R3,A
MOV A,R6
MOV R2,A
MOV DPTR,#sum?146
INC DPTR
INC DPTR
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
MOV R7,A
MOV A,R7
ADD A,R3
MOV R7,A
MOV A,R6
ADDC A,R2
MOV R6,A
CLR A
RLC A
MOV R5,A
CLR A
RLC A
MOV R4,A
MOV DPTR,#sum?146
LCALL ?C?LSTXDATA
; if(sum&0xffff0000)
; SOURCE LINE # 61
MOV DPTR,#sum?146
MOVX A,@DPTR
MOV R4,A
INC DPTR
MOVX A,@DPTR
MOV R5,A
MOV A,R4
ORL A,R5
JZ ?C0014
; {//表示有進位
; SOURCE LINE # 62
; sum++;
; SOURCE LINE # 63
MOV DPTR,#sum?146
INC DPTR
INC DPTR
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
ADD A,#01H
MOV R7,A
CLR A
ADDC A,R6
MOV R6,A
CLR A
ADDC A,R5
MOV R5,A
CLR A
ADDC A,R4
MOV R4,A
MOV DPTR,#sum?146
LCALL ?C?LSTXDATA
; }
; SOURCE LINE # 64
?C0014:
; return ( (UINT)((sum)&0xffff));
; SOURCE LINE # 65
MOV DPTR,#sum?146
INC DPTR
INC DPTR
MOVX A,@DPTR
MOV R6,A
INC DPTR
MOVX A,@DPTR
MOV R7,A
; // return ( (UINT)(~((sum)&0xffff)));
; } ; SOURCE LINE # 67
?C0015:
RET
; END OF _cksum
END
?? 快捷鍵說明
復制代碼
Ctrl + C
搜索代碼
Ctrl + F
全屏模式
F11
切換主題
Ctrl + Shift + D
顯示快捷鍵
?
增大字號
Ctrl + =
減小字號
Ctrl + -