⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 _fs2slong.asm

📁 很少见的源码公开的msc51和z80的c编译器。
💻 ASM
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:34 2001;--------------------------------------------------------	.module _fs2slong	.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 ___fs2slong;--------------------------------------------------------; 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);--------------------------------------------------------; global & static initialisations;--------------------------------------------------------	.area GSINIT  (CODE)	.area GSFINAL (CODE)	.area GSINIT  (CODE);--------------------------------------------------------; Home;--------------------------------------------------------	.area HOME	 (CODE)	.area CSEG    (CODE);--------------------------------------------------------; code;--------------------------------------------------------	.area CSEG    (CODE);	_fs2slong.c 4;	genFunction ;	-----------------------------------------;	 function __fs2slong;	-----------------------------------------___fs2slong:	ar2 = 0x02	ar3 = 0x03	ar4 = 0x04	ar5 = 0x05	ar6 = 0x06	ar7 = 0x07	ar0 = 0x00	ar1 = 0x01;	_fs2slong.c 0;	genReceive 	mov	r2,dpl	mov	r3,dph	mov	r4,dpx	mov	r5,b;	_fs2slong.c 6;	genIfx 	mov	a,r2	orl	a,r3	orl	a,r4	orl	a,r5;	genIfxJump ; Peephole 109   removed ljmp by inverse jump logic	jnz  00102$00116$:;	_fs2slong.c 7;	genRet ; Peephole 181a   used 24 bit load of dptr	mov  dptr,#0x0000	mov	b,#0x00	ljmp	00110$;	genLabel 00102$:;	_fs2slong.c 9;	genAssign ;	genAssign: resultIsFar = TRUE	mov	dptr,#___fslt_PARM_2; Peephole 101   removed redundant mov; Peephole 180   changed mov to clr	clr  a	movx @dptr,a	inc  dptr	movx @dptr,a	inc	dptr; Peephole 101   removed redundant mov; Peephole 180   changed mov to clr	clr  a	movx @dptr,a	inc  dptr	movx @dptr,a;	genCall 	push	ar2	push	ar3	push	ar4	push	ar5	mov	dpl,r2	mov	dph,r3	mov	dpx,r4	mov	b,r5	lcall	___fslt	mov	r6,dpl	pop	ar5	pop	ar4	pop	ar3	pop	ar2;	genIfx 	mov	a,r6;	genIfxJump 	jnz	00117$	ljmp	00108$00117$:;	_fs2slong.c 10;	genAssign ;	genAssign: resultIsFar = TRUE	mov	dptr,#___fsgt_PARM_2; Peephole 101   removed redundant mov; Peephole 180   changed mov to clr	clr  a	movx @dptr,a	inc  dptr	movx @dptr,a	inc	dptr; Peephole 180   changed mov to clr	clr  a	movx	@dptr,a	inc	dptr	mov	a,#0xCF	movx	@dptr,a;	genCall 	push	ar2	push	ar3	push	ar4	push	ar5	mov	dpl,r2	mov	dph,r3	mov	dpx,r4	mov	b,r5	lcall	___fsgt	mov	r6,dpl	pop	ar5	pop	ar4	pop	ar3	pop	ar2;	genIfx 	mov	a,r6;	genIfxJump ; Peephole 109   removed ljmp by inverse jump logic	jnz  00104$00118$:;	_fs2slong.c 11;	genRet ; Peephole 182a   used 24 bit load of dptr	mov  dptr,#((0x00 << 16) + (0x00 << 8) + 0x01)	mov	b,#0x80	ljmp	00110$;	genLabel 00104$:;	_fs2slong.c 12;	genUminus ;	genUminusFloat	mov	a,r5	cpl	acc.7	mov	r1,a	mov	ar6,r2	mov	ar7,r3	mov	ar0,r4;	genCall 	push	ar2	push	ar3	push	ar4	push	ar5	mov	dpl,r6	mov	dph,r7	mov	dpx,r0	mov	b,r1	lcall	___fs2ulong	mov	r6,dpl	mov	r7,dph	mov	r0,dpx	mov	r1,b	pop	ar5	pop	ar4	pop	ar3	pop	ar2;	genUminus 	clr	c	clr	a	subb	a,r6	mov	r6,a	clr	a	subb	a,r7	mov	r7,a	clr	a	subb	a,r0	mov	r0,a	clr	a	subb	a,r1	mov	r1,a;	genRet 	mov	dpl,r6	mov	dph,r7	mov	dpx,r0	mov	b,r1	ljmp	00110$;	genLabel 00108$:;	_fs2slong.c 14;	genAssign ;	genAssign: resultIsFar = TRUE	mov	dptr,#___fslt_PARM_2; Peephole 101   removed redundant mov; Peephole 180   changed mov to clr	clr  a	movx @dptr,a	inc  dptr	movx @dptr,a	inc	dptr; Peephole 180   changed mov to clr	clr  a	movx	@dptr,a	inc	dptr	mov	a,#0x4F	movx	@dptr,a;	genCall 	push	ar2	push	ar3	push	ar4	push	ar5	mov	dpl,r2	mov	dph,r3	mov	dpx,r4	mov	b,r5	lcall	___fslt	mov	r6,dpl	pop	ar5	pop	ar4	pop	ar3	pop	ar2;	genIfx 	mov	a,r6;	genIfxJump ; Peephole 109   removed ljmp by inverse jump logic	jnz  00106$00119$:;	_fs2slong.c 15;	genRet ; Peephole 182a   used 24 bit load of dptr	mov  dptr,#((0xFF << 16) + (0xFF << 8) + 0xFF)	mov	b,#0x7F;	genLabel ; Peephole 132   changed ljmp to sjmp	sjmp 00110$00106$:;	_fs2slong.c 16;	genCall 	mov	dpl,r2	mov	dph,r3	mov	dpx,r4	mov	b,r5	lcall	___fs2ulong	mov	r2,dpl	mov	r3,dph	mov	r4,dpx	mov	r5,b;	genAssign ;	genAssign: resultIsFar = FALSE;	genRet 	mov	dpl,r2	mov	dph,r3	mov	dpx,r4	mov	b,r5;	genLabel 00110$:;	genEndFunction 	ret	.area CSEG    (CODE)

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -