📄 ceilf.asm
字号:
;--------------------------------------------------------
; File Created by SDCC : FreeWare ANSI-C Compiler
; Version 2.3.1-pj3 Sun Jan 20 13:10:11 2002
;--------------------------------------------------------
.module ceilf
;--------------------------------------------------------
; Public variables in this module
;--------------------------------------------------------
.globl _ceilf
;--------------------------------------------------------
; special function registers
;--------------------------------------------------------
;--------------------------------------------------------
; special function bits
;--------------------------------------------------------
;--------------------------------------------------------
; internal ram data
;--------------------------------------------------------
.area DSEG (DATA)
;--------------------------------------------------------
; overlayable items in internal ram
;--------------------------------------------------------
.area OSEG (OVR,DATA)
;--------------------------------------------------------
; 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 'ceilf'
;------------------------------------------------------------
;x Allocated to stack - offset 1
;r Allocated to stack - offset 5
; ceilf.c 23
; -----------------------------------------
; function ceilf
; -----------------------------------------
_ceilf:
ar2 = 0x02
ar3 = 0x03
ar4 = 0x04
ar5 = 0x05
ar6 = 0x06
ar7 = 0x07
ar0 = 0x00
ar1 = 0x01
push _bp
mov _bp,sp
mov ar0,a
mov a,sp
add a,#0x08
mov sp,a
mov a,ar0
; ceilf.c 0
; genReceive
push acc
; Peephole 212 reduced add sequence to inc
mov r0,_bp
inc r0
pop acc
mov @r0,dpl
inc r0
mov @r0,dph
inc r0
mov @r0,b
inc r0
mov @r0,a
; ceilf.c 26
; genCall
; Peephole 212 reduced add sequence to inc
mov r0,_bp
inc r0
mov dpl,@r0
inc r0
mov dph,@r0
inc r0
mov b,@r0
inc r0
mov a,@r0
lcall ___fs2slong
mov r2,dpl
mov r3,dph
mov r4,b
mov r5,a
; genAssign
mov a,_bp
add a,#0x05
mov r0,a
mov @r0,ar2
inc r0
mov @r0,ar3
inc r0
mov @r0,ar4
inc r0
mov @r0,ar5
; ceilf.c 27
; genCmpLt
mov a,_bp
add a,#0x05
; genCmp
; Peephole 185 changed order of increment (acc incremented also!)
inc a
mov r0,a
inc r0
inc r0
mov a,@r0
; genIfxJump
; Peephole 111 removed ljmp by inverse jump logic
jnb acc.7,00102$
00110$:
; ceilf.c 28
; genCall
dec r0
dec r0
dec r0
mov dpl,@r0
inc r0
mov dph,@r0
inc r0
mov b,@r0
inc r0
mov a,@r0
lcall ___slong2fs
mov r4,dpl
mov r5,dph
mov r2,b
; genRet
; Peephole 191 removed redundant mov
mov r3,a
mov dpl,r4
mov dph,r5
mov b,r2
ljmp 00104$
00102$:
; ceilf.c 30
; genCall
mov a,_bp
add a,#0x05
mov r0,a
mov dpl,@r0
inc r0
mov dph,@r0
inc r0
mov b,@r0
inc r0
mov a,@r0
lcall ___slong2fs
mov r2,dpl
mov r3,dph
mov r4,b
mov r5,a
; genAssign
; Peephole 212 reduced add sequence to inc
mov r0,_bp
inc r0
mov ___fslt_PARM_2,@r0
inc r0
mov (___fslt_PARM_2 + 1),@r0
inc r0
mov (___fslt_PARM_2 + 2),@r0
inc r0
mov (___fslt_PARM_2 + 3),@r0
; genCall
mov dpl,r2
mov dph,r3
mov b,r4
mov a,r5
lcall ___fslt
mov a,dpl
; genIfx
; genIfxJump
; Peephole 110 removed ljmp by inverse jump logic
jz 00106$
00111$:
; genAssign
mov r2,#0x01
; Peephole 132 changed ljmp to sjmp
sjmp 00107$
00106$:
; genAssign
mov r2,#0x00
00107$:
; genCast
mov a,r2
rlc a
subb a,acc
mov r3,a
mov r4,a
mov r5,a
; genPlus
mov a,_bp
add a,#0x05
mov r0,a
mov a,r2
add a,@r0
mov r2,a
mov a,r3
inc r0
addc a,@r0
mov r3,a
mov a,r4
inc r0
addc a,@r0
mov r4,a
mov a,r5
inc r0
addc a,@r0
; genCall
; Peephole 191 removed redundant mov
mov r5,a
mov dpl,r2
mov dph,r3
mov b,r4
lcall ___slong2fs
mov r2,dpl
mov r3,dph
mov r4,b
; genRet
; Peephole 191 removed redundant mov
mov r5,a
mov dpl,r2
mov dph,r3
mov b,r4
00104$:
mov sp,_bp
pop _bp
ret
.area CSEG (CODE)
.area XINIT (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -