1 2 3 4 5 6 7 8 9 10 11 12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 27 28 29 30 31 32 33 34 35 36 37 38 39 40 41 42 43 44 45 46 47 48 49 50 51 52 53 54 55 56 57 58 59 60 61 62 63 64 65 66 67 68 69 70 71 72 73 74 75 76
|
;
; int printf (const char* Format, ...);
;
; Ullrich von Bassewitz, 1.12.2000
;
.export _printf
.import _stdout, pushax, addysp, _vfprintf
.importzp sp, ptr1
.macpack generic
; ----------------------------------------------------------------------------
; Data
.bss
ParamSize: .res 1 ; Number of parameter bytes
; ----------------------------------------------------------------------------
; Code
.code
_printf:
sty ParamSize ; Number of param bytes passed in Y
; We are using a (hopefully) clever trick here to reduce code size. On entry,
; the stack pointer points to the last pushed parameter of the variable
; parameter list. Adding the number of parameter bytes, would result in a
; pointer that points *after* the Format parameter.
; Since we have to push stdout anyway, we will do that here, so
;
; * we will save the subtraction of 2 (__fixargs__) later
; * we will have the address of the Format parameter which needs to
; be pushed next.
;
lda _stdout
ldx _stdout+1
jsr pushax
; Now calculate the va_list pointer, which does points to Format
lda sp
ldx sp+1
add ParamSize
bcc @L1
inx
@L1: sta ptr1
stx ptr1+1
; Push Format
ldy #1
lda (ptr1),y
tax
dey
lda (ptr1),y
jsr pushax
; Load va_list (last and __fastcall__ parameter to vfprintf)
lda ptr1
ldx ptr1+1
; Call vfprintf
jsr _vfprintf
; Cleanup the stack. We will return what we got from vfprintf
ldy ParamSize
jmp addysp
|