📄 _divuint.asm
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:33 2001;-------------------------------------------------------- .module _divuint .flat24 on ; 24 bit flat addressingdpx = 0x93 ; dpx register unknown to assemblerdps = 0x86 ; dps register unknown to assemblerdpl1 = 0x84 ; dpl1 register unknown to assemblerdph1 = 0x85 ; dph1 register unknown to assemblerdpx1 = 0x95 ; dpx1 register unknown to assemblerap = 0x9C ; ap register unknown to assembler;--------------------------------------------------------; Public variables in this module;-------------------------------------------------------- .globl __divuint_PARM_2 .globl __divuint;--------------------------------------------------------; 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)__divuint_c_1_1:: .ds 1;--------------------------------------------------------; external ram data;-------------------------------------------------------- .area XSEG (XDATA)__divuint_PARM_2:: .ds 2;--------------------------------------------------------; global & static initialisations;-------------------------------------------------------- .area GSINIT (CODE) .area GSFINAL (CODE) .area GSINIT (CODE);--------------------------------------------------------; Home;-------------------------------------------------------- .area HOME (CODE) .area CSEG (CODE);--------------------------------------------------------; code;-------------------------------------------------------- .area CSEG (CODE); _divuint.c 28; genFunction ; -----------------------------------------; function _divuint; -----------------------------------------__divuint: ar2 = 0x02 ar3 = 0x03 ar4 = 0x04 ar5 = 0x05 ar6 = 0x06 ar7 = 0x07 ar0 = 0x00 ar1 = 0x01; _divuint.c 53; genReceive mov r2,dpl mov r3,dph; _divuint.c 30; genAssign ; genAssign: resultIsFar = TRUE mov r4,#0x00 mov r5,#0x00; _divuint.c 38; genAssign ; genAssign: resultIsFar = TRUE mov r6,#0x10; genLabel 00105$:; _divuint.c 40; genGetHbit mov a,r3 rl a anl a,#0x01 mov r7,a; genCast ; _divuint.c 41; genLeftShift ; genLeftShiftLiteral (1), size 2; left (iTemp0) is 2; aka __divuint_a_1_1; result (iTemp5) is 2; genlshTwo mov ar0,r2 mov a,r3 xch a,r0 add a,acc xch a,r0 rlc a mov r1,a; genAssign ; genAssign: resultIsFar = TRUE mov ar2,r0 mov ar3,r1; _divuint.c 42; genLeftShift ; genLeftShiftLiteral (1), size 2; left (iTemp1) is 2; aka __divuint_reste_1_1; result (iTemp6) is 2; genlshTwo mov ar0,r4 mov a,r5 xch a,r0 add a,acc xch a,r0 rlc a mov r1,a; genAssign ; genAssign: resultIsFar = TRUE mov ar4,r0 mov ar5,r1; _divuint.c 43; genIfx mov a,r7; genIfxJump ; Peephole 110 removed ljmp by inverse jump logic jz 00102$00114$:; _divuint.c 44; genOr orl ar4,#0x01; genLabel 00102$:; _divuint.c 46; genCmpLt mov dptr,#__divuint_PARM_2; genCmp clr c; genCmp #1: 1/0/0 mov a,r4; genCmp #2; genCmp #4; genCmp #4.1 xch a, b movx a,@dptr xch a, b subb a,b; genCmp #1: 0/0/1 mov a,r5; genCmp #2; genCmp #4; genCmp #4.1 xch a, b inc dptr movx a,@dptr xch a, b subb a,b; genIfxJump ; Peephole 132 changed ljmp to sjmp; Peephole 160 removed sjmp by inverse jump logic jc 00106$00115$:; _divuint.c 47; genMinus mov dps, #0x01 mov dptr, #__divuint_PARM_2 dec dps clr c mov a,r4 xch a, ap inc dps movx a,@dptr xch a, ap subb a,ap mov r7,a mov a,r5 xch a, ap inc dptr movx a,@dptr xch a, ap subb a,ap mov r0,a mov dps, #0x00; genAssign ; genAssign: resultIsFar = TRUE mov ar4,r7 mov ar5,r0; _divuint.c 49; genOr orl ar2,#0x01; genLabel 00106$:; _divuint.c 51; genDjnz djnz ar6,00116$ sjmp 00117$00116$: ljmp 00105$00117$:; _divuint.c 53; genRet mov dpl,r2 mov dph,r3; genLabel 00108$:; genEndFunction ret .area CSEG (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -