📄 _strrchr.asm
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:17 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 _DUMMY .area OSEG (OVR,DATA)_strrchr_PARM_2:: .ds 1;--------------------------------------------------------; indirectly addressable internal ram data;-------------------------------------------------------- .area ISEG (DATA);--------------------------------------------------------; bit data;-------------------------------------------------------- .area BSEG (BIT);--------------------------------------------------------; external ram data;-------------------------------------------------------- .area XSEG (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 'strrchr';------------------------------------------------------------; _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 mov r2,dpl mov r3,dph mov r4,b; _strrchr.c 32 mov ar5,r2 mov ar6,r3 mov ar7,r4; _strrchr.c 3400101$: mov dpl,r2 mov dph,r3 mov b,r4 lcall __gptrget mov r0,a inc dptr mov r2,dpl mov r3,dph mov a,r0; Peephole 109 removed ljmp by inverse jump logic jnz 00101$00116$:; _strrchr.c 3700105$: dec r2 cjne r2,#0xff,00117$ dec r300117$: mov a,r2 cjne a,ar5,00118$ mov a,r3 cjne a,ar6,00118$ mov a,r4 cjne a,ar7,00118$; Peephole 132 changed ljmp to sjmp sjmp 00107$00118$: mov dpl,r2 mov dph,r3 mov b,r4 lcall __gptrget; Peephole 105 removed redundant mov mov r0,a; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,_strrchr_PARM_2,00105$;00119$:; Peephole 200 removed redundant sjmp00120$:00107$:; _strrchr.c 40 mov dpl,r2 mov dph,r3 mov b,r4 lcall __gptrget; Peephole 105 removed redundant mov mov r5,a; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,_strrchr_PARM_2,00109$;00121$:; Peephole 200 removed redundant sjmp00122$:; _strrchr.c 41 mov dpl,r2 mov dph,r3 mov b,r4; 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 + -