mirror of
git://sourceware.org/git/newlib-cygwin.git
synced 2025-01-15 02:09:19 +08:00
9a6831be86
* libc/machine/h8300/Makefile.am (lib_a_SOURCES): Add h8sx_strcpy.S. * libc/machine/h8300/defines.h (LEN): New macro. * libc/machine/h8300/memcpy.S: Add h8sx version. * libc/machine/h8300/memset.S: Likewise. * libc/machine/h8300/strcmp.S: Likewise. * libc/machine/h8300/setjmp.S: Use h8sx move instructions. * libc/machine/h8300/h8sx_strcpy.S: New file. 2003-06-30 Richard Sandiford <rsandifo@redhat.com> * libc/include/machine/ieeefp.h: Extend __H8300S__ handling to __H8300SX__. * libc/include/machine/setjmp.h: Likewise. * libc/include/sys/config.h: Likewise. * libc/machine/h8300/defines.h: Likewise. * libc/machine/h8300/setjmp.S: Likewise. * libc/machine/h8300/strcmp.S: Likewise. * libc/sys/h8300hms/close.S: Likewise. * libc/sys/h8300hms/fstat.S: Likewise. * libc/sys/h8300hms/lseek.S: Likewise. * libc/sys/h8300hms/read.S: Likewise. * libc/sys/h8300hms/write.S: Likewise. * libc/sys/h8300hms/crt0.S: Likewise. * libc/machine/h8300/setarch.h: Use .h8300sx or .h8300sxn if __H8300SX__ is defined. * libc/sys/h8300hms/setarch.h: Likewise.
61 lines
779 B
ArmAsm
61 lines
779 B
ArmAsm
#include "setarch.h"
|
|
|
|
#include "defines.h"
|
|
|
|
#if defined (__H8300SX__)
|
|
.global _strcmp
|
|
_strcmp:
|
|
mov.l er0,er2
|
|
loop:
|
|
mov.b @er2+,r0l
|
|
beq eos
|
|
sub.b @er1+,r0l
|
|
beq loop
|
|
exts.l #2,er0
|
|
rts
|
|
eos:
|
|
sub.b @er1,r0l
|
|
exts.l #2,er0
|
|
rts
|
|
#else
|
|
.section .text
|
|
.align 2
|
|
.global _strcmp
|
|
_strcmp:
|
|
MOVP A0P,A2P
|
|
MOVP A1P,A3P
|
|
.L5:
|
|
mov.b @A2P+,A1L
|
|
beq .L3
|
|
mov.b @A3P+,A0L
|
|
cmp.b A0L,A1L
|
|
beq .L5
|
|
#ifdef __NORMAL_MODE__
|
|
sub #1,A3P
|
|
#else
|
|
subs #1,A3P
|
|
#endif
|
|
.L3:
|
|
mov.b @(-1,A2P),A0L
|
|
mov.b @A3P,A1L
|
|
sub.b A1L,A0L
|
|
; We have to sign extend the result to 32bits just in case
|
|
; we are using 32bit integers.
|
|
#ifdef __H8300H__
|
|
exts.w r0
|
|
exts.l er0
|
|
#else
|
|
#ifdef __H8300S__
|
|
exts.w r0
|
|
exts.l er0
|
|
#else
|
|
bld #7,r0l
|
|
subx r0h,r0h
|
|
subx r1l,r1l
|
|
subx r1h,r1h
|
|
#endif
|
|
#endif
|
|
rts
|
|
.end
|
|
#endif
|