31 lines
700 B
ArmAsm
31 lines
700 B
ArmAsm
.define Stil
|
|
.sect .text
|
|
.sect .rom
|
|
.sect .data
|
|
.sect .bss
|
|
.sect .text
|
|
|
|
! This subroutine stores indirect a block of bytes if
|
|
! the number of bytes is greater than four.
|
|
! The destination address is in registerpair AX.
|
|
! The lowbyte of the number of bytes is in Y,
|
|
! the highbyte is in zeropage location NBYTES+1.
|
|
|
|
|
|
Stil:
|
|
sta ADDR+3 ! destination address (highbyte)
|
|
stx ADDR+2 ! destination address (lowbyte)
|
|
sty NBYTES ! number of bytes (lowbyte)
|
|
clc
|
|
lda SP+2
|
|
sta ADDR ! source address (lowbyte)
|
|
adc NBYTES
|
|
sta SP+2 ! new stackpointer (lowbyte)
|
|
lda SP+1
|
|
sta ADDR+1 ! source address (highbyte)
|
|
adc NBYTES+1
|
|
sta SP+1 ! new stackpointer (highbyte)
|
|
inc NBYTES+1
|
|
jmp Blmnp ! do the move
|
|
|
|
|