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

📄 _divuint.asm

📁 很少见的源码公开的msc51和z80的c编译器。
💻 ASM
字号:
;--------------------------------------------------------; File Created by SDCC : FreeWare ANSI-C Compiler; Version 2.3.0 Thu Sep 20 10:57:33 2001;--------------------------------------------------------	.module _divuint	.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 __divuint_PARM_2	.globl __divuint;--------------------------------------------------------; 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)__divuint_c_1_1::	.ds 1;--------------------------------------------------------; external ram data;--------------------------------------------------------	.area XSEG    (XDATA)__divuint_PARM_2::	.ds 2;--------------------------------------------------------; global & static initialisations;--------------------------------------------------------	.area GSINIT  (CODE)	.area GSFINAL (CODE)	.area GSINIT  (CODE);--------------------------------------------------------; Home;--------------------------------------------------------	.area HOME	 (CODE)	.area CSEG    (CODE);--------------------------------------------------------; code;--------------------------------------------------------	.area CSEG    (CODE);	_divuint.c 28;	genFunction ;	-----------------------------------------;	 function _divuint;	-----------------------------------------__divuint:	ar2 = 0x02	ar3 = 0x03	ar4 = 0x04	ar5 = 0x05	ar6 = 0x06	ar7 = 0x07	ar0 = 0x00	ar1 = 0x01;	_divuint.c 53;	genReceive 	mov	r2,dpl	mov	r3,dph;	_divuint.c 30;	genAssign ;	genAssign: resultIsFar = TRUE	mov	r4,#0x00	mov	r5,#0x00;	_divuint.c 38;	genAssign ;	genAssign: resultIsFar = TRUE	mov	r6,#0x10;	genLabel 00105$:;	_divuint.c 40;	genGetHbit 	mov	a,r3	rl	a	anl	a,#0x01	mov	r7,a;	genCast ;	_divuint.c 41;	genLeftShift ;	genLeftShiftLiteral (1), size 2;	left (iTemp0) is 2;		aka __divuint_a_1_1;	result (iTemp5) is 2;	genlshTwo 	mov	ar0,r2	mov	a,r3	xch	a,r0	add	a,acc	xch	a,r0	rlc	a	mov	r1,a;	genAssign ;	genAssign: resultIsFar = TRUE	mov	ar2,r0	mov	ar3,r1;	_divuint.c 42;	genLeftShift ;	genLeftShiftLiteral (1), size 2;	left (iTemp1) is 2;		aka __divuint_reste_1_1;	result (iTemp6) is 2;	genlshTwo 	mov	ar0,r4	mov	a,r5	xch	a,r0	add	a,acc	xch	a,r0	rlc	a	mov	r1,a;	genAssign ;	genAssign: resultIsFar = TRUE	mov	ar4,r0	mov	ar5,r1;	_divuint.c 43;	genIfx 	mov	a,r7;	genIfxJump ; Peephole 110   removed ljmp by inverse jump logic	jz  00102$00114$:;	_divuint.c 44;	genOr 	orl	ar4,#0x01;	genLabel 00102$:;	_divuint.c 46;	genCmpLt 	mov	dptr,#__divuint_PARM_2;	genCmp	clr	c;	genCmp #1: 1/0/0	mov	a,r4;	genCmp #2;	genCmp #4;	genCmp #4.1	xch	a, b	movx	a,@dptr	xch	a, b	subb	a,b;	genCmp #1: 0/0/1	mov	a,r5;	genCmp #2;	genCmp #4;	genCmp #4.1	xch	a, b	inc	dptr	movx	a,@dptr	xch	a, b	subb	a,b;	genIfxJump ; Peephole 132   changed ljmp to sjmp; Peephole 160   removed sjmp by inverse jump logic	jc   00106$00115$:;	_divuint.c 47;	genMinus 	mov	dps, #0x01	mov	dptr, #__divuint_PARM_2	dec	dps	clr	c	mov	a,r4	xch	a, ap	inc	dps	movx	a,@dptr	xch	a, ap	subb	a,ap	mov	r7,a	mov	a,r5	xch	a, ap	inc	dptr	movx	a,@dptr	xch	a, ap	subb	a,ap	mov	r0,a	mov	dps, #0x00;	genAssign ;	genAssign: resultIsFar = TRUE	mov	ar4,r7	mov	ar5,r0;	_divuint.c 49;	genOr 	orl	ar2,#0x01;	genLabel 00106$:;	_divuint.c 51;	genDjnz	djnz	ar6,00116$	sjmp	00117$00116$:	ljmp	00105$00117$:;	_divuint.c 53;	genRet 	mov	dpl,r2	mov	dph,r3;	genLabel 00108$:;	genEndFunction 	ret	.area CSEG    (CODE)

⌨️ 快捷键说明

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