📄 _strncmp.asm
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:17 2001;-------------------------------------------------------- .module _strncmp ;--------------------------------------------------------; Public variables in this module;-------------------------------------------------------- .globl _strncmp_PARM_3 .globl _strncmp_PARM_2 .globl _strncmp;--------------------------------------------------------; special function registers;--------------------------------------------------------;--------------------------------------------------------; special function bits ;--------------------------------------------------------;--------------------------------------------------------; internal ram data;-------------------------------------------------------- .area DSEG (DATA);--------------------------------------------------------; overlayable items in internal ram ;-------------------------------------------------------- .area _DUMMY .area OSEG (OVR,DATA)_strncmp_PARM_2:: .ds 3_strncmp_PARM_3:: .ds 2;--------------------------------------------------------; 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 'strncmp';------------------------------------------------------------; _strncmp.c 27; -----------------------------------------; function strncmp; -----------------------------------------_strncmp: ar2 = 0x02 ar3 = 0x03 ar4 = 0x04 ar5 = 0x05 ar6 = 0x06 ar7 = 0x07 ar0 = 0x00 ar1 = 0x01; _strncmp.c 0 mov r2,dpl mov r3,dph mov r4,b; _strncmp.c 33 mov a,_strncmp_PARM_3 orl a,(_strncmp_PARM_3 + 1); Peephole 109 removed ljmp by inverse jump logic jnz 00114$00115$:; _strncmp.c 34; Peephole 181 used 16 bit load of dptr mov dptr,#0x0000 ljmp 00108$; _strncmp.c 3600114$: mov r5,_strncmp_PARM_2 mov r6,(_strncmp_PARM_2 + 1) mov r7,(_strncmp_PARM_2 + 2)00105$: mov a,_strncmp_PARM_3 add a,#0xff mov r0,a mov a,(_strncmp_PARM_3 + 1) addc a,#0xff mov r1,a mov _strncmp_PARM_3,r0 mov (_strncmp_PARM_3 + 1),r1 mov a,r0 orl a,r1; Peephole 110 removed ljmp by inverse jump logic jz 00107$00116$: 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 110 removed ljmp by inverse jump logic jz 00107$00117$: mov dpl,r5 mov dph,r6 mov b,r7 lcall __gptrget mov r1,a inc dptr mov r5,dpl mov r6,dph mov a,r0; Peephole 132 changed ljmp to sjmp; Peephole 199 optimized misc jump sequence cjne a,ar1,00107$;00118$:; Peephole 200 removed redundant sjmp00119$:; _strncmp.c 37; _strncmp.c 38; Peephole 132 changed ljmp to sjmp sjmp 00105$00107$:; _strncmp.c 41 mov dpl,r2 mov dph,r3 mov b,r4 lcall __gptrget mov r2,a mov dpl,r5 mov dph,r6 mov b,r7 lcall __gptrget mov r5,a clr c mov a,r2 subb a,r5 mov r2,a; Peephole 180 changed mov to clr clr a subb a,#0x00 mov r3,a mov dpl,r2 mov dph,r300108$: ret .area CSEG (CODE)
⌨️ 快捷键说明
复制代码
Ctrl + C
搜索代码
Ctrl + F
全屏模式
F11
切换主题
Ctrl + Shift + D
显示快捷键
?
增大字号
Ctrl + =
减小字号
Ctrl + -