Welcome to mirror list, hosted at ThFree Co, Russian Federation.

cygwin.com/git/newlib-cygwin.git - Unnamed repository; edit this file 'description' to name the repository.
summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorAnton Kolesov <Anton.Kolesov@synopsys.com>2015-10-23 21:24:50 +0300
committerCorinna Vinschen <corinna@vinschen.de>2015-11-12 16:14:17 +0300
commitc0a99f02933e1e58197e61d0b2c6e0b3824a2119 (patch)
tree62baf46db6e25fb589f83cb1b2aabd945f9b32ca /newlib/libc/machine/arc/strcpy-bs-arc600.S
parentacdfcb0a0af54715bc37ed1c767bfe901b679357 (diff)
Add support for ARC to newlib
newlib/ChangeLog: 2015-11-12 Anton Kolesov <Anton.Kolesov@synopsys.com> * configure.host: Add ARC support. * libc/include/machine/setjmp.h: Likewise. * libc/machine/configure: Likewise. * libc/machine/configure.in: Likewise. * libc/machine/arc/Makefile.am: Likewise. * libc/machine/arc/Makefile.in: Likewise. * libc/machine/arc/aclocal.m4: Likewise. * libc/machine/arc/asm.h: Likewise. * libc/machine/arc/configure: Likewise. * libc/machine/arc/configure.in: Likewise. * libc/machine/arc/memcmp-bs-norm.S: Likewise. * libc/machine/arc/memcmp-stub.c: Likewise. * libc/machine/arc/memcmp.S: Likewise. * libc/machine/arc/memcpy-archs.S: Likewise. * libc/machine/arc/memcpy-bs.S: Likewise. * libc/machine/arc/memcpy-stub.c: Likewise. * libc/machine/arc/memcpy.S: Likewise. * libc/machine/arc/memset-archs.S: Likewise. * libc/machine/arc/memset-bs.S: Likewise. * libc/machine/arc/memset-stub.c: Likewise. * libc/machine/arc/memset.S: Likewise. * libc/machine/arc/setjmp.S: Likewise. * libc/machine/arc/strchr-bs-norm.S: Likewise. * libc/machine/arc/strchr-bs.S: Likewise. * libc/machine/arc/strchr-stub.c: Likewise. * libc/machine/arc/strchr.S: Likewise. * libc/machine/arc/strcmp-archs.S: Likewise. * libc/machine/arc/strcmp-stub.c: Likewise. * libc/machine/arc/strcmp.S: Likewise. * libc/machine/arc/strcpy-bs-arc600.S: Likewise. * libc/machine/arc/strcpy-bs.S: Likewise. * libc/machine/arc/strcpy-stub.c: Likewise. * libc/machine/arc/strcpy.S: Likewise. * libc/machine/arc/strlen-bs-norm.S: Likewise. * libc/machine/arc/strlen-bs.S: Likewise. * libc/machine/arc/strlen-stub.c: Likewise. * libc/machine/arc/strlen.S: Likewise. * libc/machine/arc/strncpy-bs.S: Likewise. * libc/machine/arc/strncpy-stub.c: Likewise. * libc/machine/arc/strncpy.S: Likewise.
Diffstat (limited to 'newlib/libc/machine/arc/strcpy-bs-arc600.S')
-rw-r--r--newlib/libc/machine/arc/strcpy-bs-arc600.S120
1 files changed, 120 insertions, 0 deletions
diff --git a/newlib/libc/machine/arc/strcpy-bs-arc600.S b/newlib/libc/machine/arc/strcpy-bs-arc600.S
new file mode 100644
index 000000000..7b9e3fdc8
--- /dev/null
+++ b/newlib/libc/machine/arc/strcpy-bs-arc600.S
@@ -0,0 +1,120 @@
+/*
+ Copyright (c) 2015, Synopsys, Inc. All rights reserved.
+
+ Redistribution and use in source and binary forms, with or without
+ modification, are permitted provided that the following conditions are met:
+
+ 1) Redistributions of source code must retain the above copyright notice,
+ this list of conditions and the following disclaimer.
+
+ 2) Redistributions in binary form must reproduce the above copyright notice,
+ this list of conditions and the following disclaimer in the documentation
+ and/or other materials provided with the distribution.
+
+ 3) Neither the name of the Synopsys, Inc., nor the names of its contributors
+ may be used to endorse or promote products derived from this software
+ without specific prior written permission.
+
+ THIS SOFTWARE IS PROVIDED BY THE COPYRIGHT HOLDERS AND CONTRIBUTORS "AS IS"
+ AND ANY EXPRESS OR IMPLIED WARRANTIES, INCLUDING, BUT NOT LIMITED TO, THE
+ IMPLIED WARRANTIES OF MERCHANTABILITY AND FITNESS FOR A PARTICULAR PURPOSE
+ ARE DISCLAIMED. IN NO EVENT SHALL THE COPYRIGHT HOLDER OR CONTRIBUTORS BE
+ LIABLE FOR ANY DIRECT, INDIRECT, INCIDENTAL, SPECIAL, EXEMPLARY, OR
+ CONSEQUENTIAL DAMAGES (INCLUDING, BUT NOT LIMITED TO, PROCUREMENT OF
+ SUBSTITUTE GOODS OR SERVICES; LOSS OF USE, DATA, OR PROFITS; OR BUSINESS
+ INTERRUPTION) HOWEVER CAUSED AND ON ANY THEORY OF LIABILITY, WHETHER IN
+ CONTRACT, STRICT LIABILITY, OR TORT (INCLUDING NEGLIGENCE OR OTHERWISE)
+ ARISING IN ANY WAY OUT OF THE USE OF THIS SOFTWARE, EVEN IF ADVISED OF THE
+ POSSIBILITY OF SUCH DAMAGE.
+*/
+
+/* This implementation is optimized for performance. For code size a generic
+ implementation of this function from newlib/libc/string/strcpy.c will be
+ used. */
+#if !defined (__OPTIMIZE_SIZE__) && !defined (PREFER_SIZE_OVER_SPEED)
+
+#include "asm.h"
+
+#if defined (__ARC600__) && defined (__Xbarrel_shifter)
+/* If dst and src are 4 byte aligned, copy 8 bytes at a time.
+ If the src is 4, but not 8 byte aligned, we first read 4 bytes to get
+ it 8 byte aligned. Thus, we can do a little read-ahead, without
+ dereferencing a cache line that we should not touch.
+ Note that short and long instructions have been scheduled to avoid
+ branch stalls.
+ This version is optimized for the ARC600 pipeline. */
+
+ENTRY (strcpy)
+ or r2,r0,r1
+ bmsk.f 0,r2,1
+ mov r8,0x01010101
+ bne.d .Lcharloop
+ mov_s r10,r0
+ ld_l r3,[r1,0]
+ bbit0.d r1,2,.Loop_setup
+ ror r12,r8
+ sub r2,r3,r8
+ bic_s r2,r2,r3
+ and_s r2,r2,r12
+ brne_s r2,0,.Lr3z
+ st.ab r3,[r10,4]
+ ld.a r3,[r1,4]
+.Loop_setup:
+ ld.a r4,[r1,4]
+
+ sub r2,r3,r8
+ and.f r2,r2,r12
+ sub r5,r4,r8
+ and.eq.f r5,r5,r12
+ b.d .Loop_start
+ mov_s r6,r3
+ .balign 4
+.Loop:
+ ld.a r3,[r1,4]
+ st r4,[r10,4]
+ ld.a r4,[r1,4]
+ sub r2,r3,r8
+ and.f r2,r2,r12
+ sub r5,r4,r8
+ and.eq.f r5,r5,r12
+ st.ab r6,[r10,8]
+ mov r6,r3
+.Loop_start:
+ beq.d .Loop
+ bic_s r2,r2,r3
+ brne.d r2,0,.Lr3z
+ and r5,r5,r12
+ bic r5,r5,r4
+ breq.d r5,0,.Loop
+ mov_s r3,r4
+ st.ab r6,[r10,4]
+#ifdef __LITTLE_ENDIAN__
+.Lr3z: bmsk.f r1,r3,7
+.Lr3z_loop:
+ lsr_s r3,r3,8
+ stb.ab r1,[r10,1]
+ bne.d .Lr3z_loop
+ bmsk.f r1,r3,7
+ j_s [blink]
+#else
+.Lr3z: lsr.f r1,r3,24
+.Lr3z_loop:
+ asl_s r3,r3,8
+ stb.ab r1,[r10,1]
+ bne.d .Lr3z_loop
+ lsr.f r1,r3,24
+ j_s [blink]
+#endif
+
+ .balign 4
+.Lcharloop:
+ ldb.ab r3,[r1,1]
+
+
+ brne.d r3,0,.Lcharloop
+ stb.ab r3,[r10,1]
+ j [blink]
+ENDFUNC (strcpy)
+#endif /* __ARC600__ && __Xbarrel_shifter */
+
+#endif /* !__OPTIMIZE_SIZE__ && !PREFER_SIZE_OVER_SPEED */