URL
https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk
Only display areas with differences |
Details |
Blame |
View Log
Rev 207 |
Rev 345 |
#include "setarch.h"
|
#include "setarch.h"
|
|
|
#include "defines.h"
|
#include "defines.h"
|
|
|
; dst A0
|
; dst A0
|
; src A1
|
; src A1
|
; len A2
|
; len A2
|
.global ___reg_memcpy
|
.global ___reg_memcpy
|
___reg_memcpy:
|
___reg_memcpy:
|
|
|
MOVP A0P,A3P ; keep copy of result
|
MOVP A0P,A3P ; keep copy of result
|
ADDP A2P,A0P ; point to end of dst
|
ADDP A2P,A0P ; point to end of dst
|
ADDP A2P,A1P ; point to end of src
|
ADDP A2P,A1P ; point to end of src
|
CMPP A0P,A3P ; see if anything to do
|
CMPP A0P,A3P ; see if anything to do
|
beq quit
|
beq quit
|
|
|
loop:
|
loop:
|
#ifdef __NORMAL_MODE__
|
#ifdef __NORMAL_MODE__
|
sub #1,A1P ; point to byte
|
sub #1,A1P ; point to byte
|
#else
|
#else
|
subs #1,A1P ; point to byte
|
subs #1,A1P ; point to byte
|
#endif
|
#endif
|
mov.b @A1P,A2L ; get byte
|
mov.b @A1P,A2L ; get byte
|
mov.b A2L,@-A0P ; save byte
|
mov.b A2L,@-A0P ; save byte
|
CMPP A0P,A3P ; at the front again ?
|
CMPP A0P,A3P ; at the front again ?
|
bne loop
|
bne loop
|
|
|
; return with A0 pointing to dst
|
; return with A0 pointing to dst
|
quit: rts
|
quit: rts
|
|
|
|
|
© copyright 1999-2024
OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.