📄 _strcmp.asm
字号:
;--------------------------------------------------------
; File Created by SDCC : FreeWare ANSI-C Compiler
; Version 2.3.1-pj3 Sun Jan 20 13:09:59 2002
;--------------------------------------------------------
.module _strcmp
;--------------------------------------------------------
; Public variables in this module
;--------------------------------------------------------
.globl _strcmp_PARM_2
.globl _strcmp
;--------------------------------------------------------
; special function registers
;--------------------------------------------------------
;--------------------------------------------------------
; special function bits
;--------------------------------------------------------
;--------------------------------------------------------
; internal ram data
;--------------------------------------------------------
.area DSEG (DATA)
;--------------------------------------------------------
; overlayable items in internal ram
;--------------------------------------------------------
.area OSEG (OVR,DATA)
_strcmp_PARM_2::
.ds 3
_strcmp_ret_1_1::
.ds 2
;--------------------------------------------------------
; indirectly addressable internal ram data
;--------------------------------------------------------
.area ISEG (DATA)
;--------------------------------------------------------
; bit data
;--------------------------------------------------------
.area BSEG (BIT)
;--------------------------------------------------------
; external ram data
;--------------------------------------------------------
.area XSEG (XDATA)
;--------------------------------------------------------
; external initialized ram data
;--------------------------------------------------------
.area XISEG (XDATA)
;--------------------------------------------------------
; global & static initialisations
;--------------------------------------------------------
.area GSINIT (CODE)
.area GSFINAL (CODE)
.area GSINIT (CODE)
;--------------------------------------------------------
; Home
;--------------------------------------------------------
.area HOME (CODE)
.area CSEG (CODE)
;--------------------------------------------------------
; code
;--------------------------------------------------------
.area CSEG (CODE)
;------------------------------------------------------------
;Allocation info for local variables in function 'strcmp'
;------------------------------------------------------------
; _strcmp.c 31
; -----------------------------------------
; function strcmp
; -----------------------------------------
_strcmp:
ar2 = 0x02
ar3 = 0x03
ar4 = 0x04
ar5 = 0x05
ar6 = 0x06
ar7 = 0x07
ar0 = 0x00
ar1 = 0x01
; _strcmp.c 58
; genReceive
mov r2,dpl
mov r3,dph
mov r4,b
; _strcmp.c 50
; genAssign
; genAssign
mov r5,_strcmp_PARM_2
mov r6,(_strcmp_PARM_2 + 1)
mov r7,(_strcmp_PARM_2 + 2)
00102$:
; genPointerGet
; genGenPointerGet
mov dpl,r2
mov dph,r3
mov b,r4
lcall __gptrget
mov r0,a
; genPointerGet
; genGenPointerGet
mov dpl,r5
mov dph,r6
mov b,r7
lcall __gptrget
mov r1,a
; genMinus
clr c
mov a,r0
subb a,r1
; genCast
; Peephole 166 removed redundant mov
mov r0,a
mov _strcmp_ret_1_1,r0
rlc a
subb a,acc
mov (_strcmp_ret_1_1 + 1),a
; genIfx
mov a,r0
; genIfxJump
; Peephole 109 removed ljmp by inverse jump logic
jnz 00104$
00117$:
; genIfx
mov a,r1
; genIfxJump
; Peephole 110 removed ljmp by inverse jump logic
jz 00104$
00118$:
; _strcmp.c 51
; genPlus
; genPlusIncr
inc r2
cjne r2,#0x00,00119$
inc r3
00119$:
; genPlus
; genPlusIncr
; tail increment optimized
inc r5
cjne r5,#0x00,00102$
inc r6
; Peephole 132 changed ljmp to sjmp
sjmp 00102$
00104$:
; _strcmp.c 53
; genCmpLt
; genCmp
mov a,(_strcmp_ret_1_1 + 1)
; genIfxJump
; Peephole 111 removed ljmp by inverse jump logic
jnb acc.7,00108$
00120$:
; _strcmp.c 54
; genAssign
mov _strcmp_ret_1_1,#0xFF
mov (_strcmp_ret_1_1 + 1),#0xFF
; Peephole 132 changed ljmp to sjmp
sjmp 00109$
00108$:
; _strcmp.c 55
; genCmpGt
; genCmp
clr c
; Peephole 180 changed mov to clr
clr a
subb a,_strcmp_ret_1_1
; Peephole 159 avoided xrl during execution
mov a,#(0x00 ^ 0x80)
mov b,(_strcmp_ret_1_1 + 1)
xrl b,#0x80
subb a,b
; genIfxJump
; Peephole 108 removed ljmp by inverse jump logic
jnc 00109$
00121$:
; _strcmp.c 56
; genAssign
clr a
mov (_strcmp_ret_1_1 + 1),a
mov _strcmp_ret_1_1,#0x01
00109$:
; _strcmp.c 58
; genRet
mov dpl,_strcmp_ret_1_1
mov dph,(_strcmp_ret_1_1 + 1)
00110$:
ret
.area CSEG (CODE)
.area XINIT (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -