📄 _strrchr.asm
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:40 2001;-------------------------------------------------------- .module _strrchr .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 _strrchr_PARM_2 .globl _strrchr;--------------------------------------------------------; 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)_strrchr_PARM_2:: .ds 1_strrchr_start_1_1:: .ds 4;--------------------------------------------------------; global & static initialisations;-------------------------------------------------------- .area GSINIT (CODE) .area GSFINAL (CODE) .area GSINIT (CODE);--------------------------------------------------------; Home;-------------------------------------------------------- .area HOME (CODE) .area CSEG (CODE);--------------------------------------------------------; code;-------------------------------------------------------- .area CSEG (CODE); _strrchr.c 27; genFunction ; -----------------------------------------; function strrchr; -----------------------------------------_strrchr: ar2 = 0x02 ar3 = 0x03 ar4 = 0x04 ar5 = 0x05 ar6 = 0x06 ar7 = 0x07 ar0 = 0x00 ar1 = 0x01; _strrchr.c 0; genReceive mov r2,dpl mov r3,dph mov r4,dpx mov r5,b; _strrchr.c 32; genAssign ; genAssign: resultIsFar = TRUE mov dptr,#_strrchr_start_1_1 mov a,r2 movx @dptr,a inc dptr mov a,r3 movx @dptr,a inc dptr mov a,r4 movx @dptr,a inc dptr mov a,r5 movx @dptr,a; _strrchr.c 34; genAssign ; genAssign: resultIsFar = TRUE; genLabel 00101$:; genPointerGet ; genGenPointerGet mov dpl,r2 mov dph,r3 mov dpx,r4 mov b,r5 lcall __gptrget mov r6,a; genPlus inc r2 cjne r2,#0x00,00116$ inc r3 cjne r3,#0x00,00116$ inc r400116$:; did genPlusIncr; genIfx mov a,r6; genIfxJump ; Peephole 109 removed ljmp by inverse jump logic jnz 00101$00117$:; _strrchr.c 37; genAssign ; genAssign: resultIsFar = TRUE; genLabel 00105$:; genMinus dec r2 cjne r2,#0xff,00118$ dec r3 cjne r3,#0xff,00118$ dec r400118$:; genCmpEq mov dptr,#_strrchr_start_1_1; gencjneshort; cjneshort: generic ptr special case. mov b,r2 movx a,@dptr cjne a,b,00119$ mov b,r3 inc dptr movx a,@dptr cjne a,b,00119$ mov b,r4 inc dptr movx a,@dptr cjne a,b,00119$; Peephole 132 changed ljmp to sjmp sjmp 00107$00119$:; genPointerGet ; genGenPointerGet mov dpl,r2 mov dph,r3 mov dpx,r4 mov b,r5 lcall __gptrget mov r6,a; genCmpEq mov dptr,#_strrchr_PARM_2; gencjneshort mov b,r6 movx a,@dptr; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,b,00105$;00120$:; Peephole 200 removed redundant sjmp00121$:; genLabel 00107$:; _strrchr.c 40; genPointerGet ; genGenPointerGet mov dpl,r2 mov dph,r3 mov dpx,r4 mov b,r5 lcall __gptrget mov r6,a; genCmpEq mov dptr,#_strrchr_PARM_2; gencjneshort mov b,r6 movx a,@dptr; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,b,00109$;00122$:; Peephole 200 removed redundant sjmp00123$:; _strrchr.c 41; genRet mov dpl,r2 mov dph,r3 mov dpx,r4 mov b,r5; genLabel ; Peephole 132 changed ljmp to sjmp sjmp 00110$00109$:; _strrchr.c 43; genRet ; Peephole 181a used 24 bit load of dptr mov dptr,#0x0000 mov b,#0x00; genLabel 00110$:; genEndFunction ret .area CSEG (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -