4
0
mirror of git://sourceware.org/git/newlib-cygwin.git synced 2025-01-23 23:47:22 +08:00
Jeff Johnston 82095e79cf 2003-05-28 Dhananjay Deshpande <dhananjayd@kpitcummins.com>
* newlib/libc/machine/h8300/memcpy.S: Use .h8300hn and .h8300sn for
        normal mode
        * newlib/libc/machine/h8300/memset.S: Likewise
        * newlib/lib/machine/h8300/reg_memcpy.S: Likewise
        * newlib/lib/machine/h8300/reg_memset.S: Likewise
        * newlib/lib/machine/h8300/setjmp.S: Likewise
        * newlib/lib/machine/h8300/strcmp.S: Likewise
        * newlib/lib/sys/h8300hms/crt0.S: Likewise
2003-05-28 18:00:17 +00:00

54 lines
671 B
ArmAsm

#include "defines.h"
#ifdef __H8300H__
#ifdef __NORMAL_MODE__
.h8300hn
#else
.h8300h
#endif
#endif
#ifdef __H8300S__
#ifdef __NORMAL_MODE__
.h8300sn
#else
.h8300s
#endif
#endif
.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
subs #1,A3P
.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