88 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
			
		
		
	
	
			88 lines
		
	
	
	
		
			1.6 KiB
		
	
	
	
		
			ArmAsm
		
	
	
	
	
	
.define _printf
 | 
						|
.sect .text
 | 
						|
.sect .rom
 | 
						|
.sect .data
 | 
						|
.sect .bss
 | 
						|
.sect .bss
 | 
						|
_getal:
 | 
						|
	.space	12
 | 
						|
_char:
 | 
						|
	.space	1
 | 
						|
	.align  4
 | 
						|
.sect .data
 | 
						|
hexs:
 | 
						|
	.ascii	"0123456789abcdef"
 | 
						|
	.align	4
 | 
						|
.sect .text
 | 
						|
_printf:
 | 
						|
	movem.l	d0/d1/d2/a0/a1/a2/a3/a4/a5/a6, -(sp)
 | 
						|
	lea	44(sp), a6	! a6 <- address of arguments
 | 
						|
	move.l	(a6)+, a5	! a5 <- address of format
 | 
						|
next:	move.b	(a5)+, d0
 | 
						|
	beq	out
 | 
						|
	cmp.b	#'%', d0
 | 
						|
	beq	procnt
 | 
						|
put:	move.l	d0, -(sp)
 | 
						|
	jsr	_putchar	! long argument on stack
 | 
						|
	tst.l	(sp)+
 | 
						|
	bra	next
 | 
						|
 | 
						|
procnt:	move.b	(a5)+, d0
 | 
						|
	cmp.b	#'d', d0	! NOTE: %d means unsigned.
 | 
						|
	beq	digit
 | 
						|
	cmp.b	#'x', d0
 | 
						|
	beq	hex
 | 
						|
	cmp.b	#'s', d0
 | 
						|
	beq	string
 | 
						|
	cmp.b	#'%', d0	! second % has to be printed.
 | 
						|
	beq	put
 | 
						|
	tst.b	-(a5)		! normal char should be printed
 | 
						|
	bra	next
 | 
						|
 | 
						|
string:	move.l	(a6)+, a2	! a2 <- address of string
 | 
						|
sloop:	move.b	(a2)+, d0
 | 
						|
	beq	next
 | 
						|
	move.l	d0, -(sp)
 | 
						|
	jsr	_putchar	! long argument on stack
 | 
						|
	tst.l	(sp)+
 | 
						|
	bra	sloop
 | 
						|
 | 
						|
digit:	move.l	(a6)+, d1	! d1 <- integer
 | 
						|
	move.l	#_getal+12, a2	! a2 <- ptr to last part of buf
 | 
						|
	clr.b	-(a2)		! stringterminator
 | 
						|
1:	
 | 
						|
	move.l	d1,-(sp)
 | 
						|
	move.l	#10,-(sp)
 | 
						|
	jsr	.dvu		! d1 <- qotient; d0 <- remainder
 | 
						|
	add.l	#'0', d0
 | 
						|
	move.b	d0, -(a2)
 | 
						|
	tst.l	d1		! if quotient = 0 then ready
 | 
						|
	bne	1b
 | 
						|
	bra	sloop		! print digitstring.
 | 
						|
 | 
						|
hex:	move.l	(a6)+, d1	! d1 <- integer
 | 
						|
	move.l	#_getal+12, a2	! a2 <- ptr to last part of buf
 | 
						|
	clr.b	-(a2)		! stringterminator
 | 
						|
	move.l	#7, d2		! loop control
 | 
						|
1:	move.l	d1, d0
 | 
						|
	and.l	#15, d0
 | 
						|
	move.l	#hexs,a0
 | 
						|
	add.l	d0,a0
 | 
						|
	move.b	(a0), -(a2) ! hex digit
 | 
						|
	asr.l	#4, d1
 | 
						|
	dbf	d2, 1b
 | 
						|
	bra	sloop
 | 
						|
 | 
						|
out:
 | 
						|
	movem.l	(sp)+, d0/d1/d2/a0/a1/a2/a3/a4/a5/a6
 | 
						|
	rts
 | 
						|
 | 
						|
 | 
						|
_putchar:
 | 
						|
	move.l	#1, -(sp)
 | 
						|
	pea	11(sp)
 | 
						|
	move.l	#1, -(sp)
 | 
						|
	jsr	_write
 | 
						|
	lea	12(sp), sp
 | 
						|
	rts
 | 
						|
.align 2
 |