summaryrefslogtreecommitdiffstats
path: root/newlib/libc/machine/rx/mempcpy.S
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>2015-04-09 09:20:00 +0100
committerCorinna Vinschen <corinna@vinschen.de>2015-04-23 21:57:13 +0200
commitcd0d45913525ef09f0494a2f0c8e3d6fe8fface2 (patch)
treedcbb6a0c97dc45cc7df625cbeb4d1a99f503d247 /newlib/libc/machine/rx/mempcpy.S
parent45d0b17928067ee848aae2cd5bd332129ca35c42 (diff)
downloadcygnal-cd0d45913525ef09f0494a2f0c8e3d6fe8fface2.tar.gz
cygnal-cd0d45913525ef09f0494a2f0c8e3d6fe8fface2.tar.bz2
cygnal-cd0d45913525ef09f0494a2f0c8e3d6fe8fface2.zip
For the RX port, avoid using string instructions when __RX_DISALLOW_STRING_INSNS__ is defined.
* rx/crt0.S (_start): If string instructions are not allowed, avoid using SMOVF. * libc/machine/rx/memchr.S: Add non-string insn using version. * libc/machine/rx/memcpy.S: Likewise. * libc/machine/rx/memmove.S: Likewise. * libc/machine/rx/mempcpy.S: Likewise. * libc/machine/rx/strcat.S: Likewise. * libc/machine/rx/strcmp.S: Likewise. * libc/machine/rx/strcpy.S: Likewise. * libc/machine/rx/strlen.S: Likewise. * libc/machine/rx/strncat.S: Likewise. * libc/machine/rx/strncmp.S: Likewise. * libc/machine/rx/strncpy.S: Likewise.
Diffstat (limited to 'newlib/libc/machine/rx/mempcpy.S')
-rw-r--r--newlib/libc/machine/rx/mempcpy.S17
1 files changed, 17 insertions, 0 deletions
diff --git a/newlib/libc/machine/rx/mempcpy.S b/newlib/libc/machine/rx/mempcpy.S
index c679d04ce..f82452462 100644
--- a/newlib/libc/machine/rx/mempcpy.S
+++ b/newlib/libc/machine/rx/mempcpy.S
@@ -4,5 +4,22 @@
.global _mempcpy
.type _mempcpy,@function
_mempcpy:
+#ifdef __RX_DISALLOW_STRING_INSNS__
+ /* Do not use the string instructions - they might prefetch
+ bytes from outside of valid memory. This is particularly
+ dangerous in I/O space. */
+
+ cmp #0, r3 ; If the count is zero, do nothing
+ beq 2f
+
+1: mov.b [r2+], r5
+ mov.b r5, [r1+]
+ sub #1, r3
+ bne 1b
+
+2: rts
+#else
smovf
rts
+#endif
+ .size _mempcpy, . - _mempcpy