2003-06-25 03:43:58 +08:00
|
|
|
#include "setarch.h"
|
2000-02-18 03:39:52 +08:00
|
|
|
|
2003-06-25 03:43:58 +08:00
|
|
|
#include "defines.h"
|
2000-02-18 03:39:52 +08:00
|
|
|
|
|
|
|
.global _memcpy
|
|
|
|
_memcpy:
|
|
|
|
; MOVP @(2/4,r7),A0P ; dst
|
|
|
|
; MOVP @(4/8,r7),A1P ; src
|
|
|
|
; MOVP @(6/12,r7),A2P ; len
|
|
|
|
|
|
|
|
MOVP A0P,A3P ; keep copy of final dst
|
|
|
|
ADDP A2P,A0P ; point to end of dst
|
|
|
|
CMPP A0P,A3P ; see if anything to do
|
|
|
|
beq quit
|
|
|
|
|
|
|
|
ADDP A2P,A1P ; point to end of src
|
|
|
|
|
|
|
|
; lets see if we can do this in words
|
|
|
|
or A0L,A2L ; or in the dst address
|
|
|
|
or A3L,A2L ; or the length
|
|
|
|
or A1L,A2L ; or the src address
|
|
|
|
btst #0,A2L ; see if the lsb is zero
|
|
|
|
bne byteloop
|
|
|
|
|
|
|
|
wordloop:
|
2003-11-21 03:59:03 +08:00
|
|
|
#ifdef __NORMAL_MODE__
|
|
|
|
sub #2,A1P
|
|
|
|
#else
|
2000-02-18 03:39:52 +08:00
|
|
|
subs #2,A1P ; point to word
|
2003-11-21 03:59:03 +08:00
|
|
|
#endif
|
2000-02-18 03:39:52 +08:00
|
|
|
mov.w @A1P,A2 ; get word
|
|
|
|
mov.w A2,@-A0P ; save word
|
|
|
|
CMPP A0P,A3P ; at the front again ?
|
|
|
|
bne wordloop
|
|
|
|
rts
|
|
|
|
|
|
|
|
byteloop:
|
2003-11-21 03:59:03 +08:00
|
|
|
#ifdef __NORMAL_MODE__
|
|
|
|
sub #1,A1P
|
|
|
|
#else
|
2000-02-18 03:39:52 +08:00
|
|
|
subs #1,A1P ; point to byte
|
2003-11-21 03:59:03 +08:00
|
|
|
#endif
|
2000-02-18 03:39:52 +08:00
|
|
|
mov.b @A1P,A2L ; get byte
|
|
|
|
mov.b A2L,@-A0P ; save byte
|
|
|
|
CMPP A0P,A3P ; at the front again ?
|
|
|
|
bne byteloop
|
|
|
|
|
|
|
|
; return with A0 pointing to dst
|
|
|
|
quit: rts
|
|
|
|
|