📄 _strrchr.asm
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:28 2001;-------------------------------------------------------- .module _strrchr ;--------------------------------------------------------; 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_string_1_1:: .ds 3;--------------------------------------------------------; 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 'strrchr';------------------------------------------------------------;ch Allocated to in memory with name '_strrchr_PARM_2';string Allocated to in memory with name '_strrchr_string_1_1';start Allocated to in memory with name '_strrchr_start_1_1'; _strrchr.c 27; -----------------------------------------; function strrchr; -----------------------------------------_strrchr: ar2 = 0x02 ar3 = 0x03 ar4 = 0x04 ar5 = 0x05 ar6 = 0x06 ar7 = 0x07 ar0 = 0x00 ar1 = 0x01; _strrchr.c 0 push b push dph push dpl mov dptr,#_strrchr_string_1_1 pop acc movx @dptr,a pop acc inc dptr movx @dptr,a pop acc inc dptr movx @dptr,a; _strrchr.c 32 mov dptr,#_strrchr_string_1_1 movx a,@dptr mov r2,a inc dptr movx a,@dptr mov r3,a inc dptr movx a,@dptr mov r4,a; _strrchr.c 34 mov ar5,r2 mov ar6,r3 mov ar7,r400101$: mov dpl,r5 mov dph,r6 mov b,r7 lcall __gptrget mov r0,a inc dptr mov r5,dpl mov r6,dph mov dptr,#_strrchr_string_1_1 mov a,r5 movx @dptr,a inc dptr mov a,r6 movx @dptr,a inc dptr mov a,r7 movx @dptr,a mov a,r0; Peephole 109 removed ljmp by inverse jump logic jnz 00101$00116$:; _strrchr.c 37 mov dptr,#_strrchr_PARM_2 movx a,@dptr mov r5,a00105$: mov dptr,#_strrchr_string_1_1 movx a,@dptr add a,#0xff mov r6,a inc dptr movx a,@dptr addc a,#0xff mov r7,a inc dptr movx a,@dptr mov r0,a mov dptr,#_strrchr_string_1_1 mov a,r6 movx @dptr,a inc dptr mov a,r7 movx @dptr,a inc dptr mov a,r0 movx @dptr,a mov a,r6 cjne a,ar2,00117$ mov a,r7 cjne a,ar3,00117$ mov a,r0 cjne a,ar4,00117$; Peephole 132 changed ljmp to sjmp sjmp 00107$00117$: mov dpl,r6 mov dph,r7 mov b,r0 lcall __gptrget; Peephole 105 removed redundant mov mov r1,a; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,ar5,00105$;00118$:; Peephole 200 removed redundant sjmp00119$:00107$:; _strrchr.c 40 mov dpl,r6 mov dph,r7 mov b,r0 lcall __gptrget; Peephole 105 removed redundant mov mov r2,a; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,ar5,00109$;00120$:; Peephole 200 removed redundant sjmp00121$:; _strrchr.c 41 mov dpl,r6 mov dph,r7 mov b,r0; Peephole 132 changed ljmp to sjmp sjmp 00110$00109$:; _strrchr.c 43; Peephole 181 used 16 bit load of dptr mov dptr,#0x0000 mov b,#0x0000110$: ret .area CSEG (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -