aboutsummaryrefslogtreecommitdiff
path: root/gcc
diff options
context:
space:
mode:
authorRenlin Li <renlin.li@arm.com>2017-06-26 13:28:32 +0000
committerRenlin Li <renlin@gcc.gnu.org>2017-06-26 13:28:32 +0000
commitfa7ccca021a5943040fd4d19d88e626a9736758e (patch)
tree2b97c9a38158c9d3b994034fadc6b76adc65294d /gcc
parent5a5c2d16e7acb42f6fec1a289bad17ae4aeb4654 (diff)
downloadgcc-fa7ccca021a5943040fd4d19d88e626a9736758e.zip
gcc-fa7ccca021a5943040fd4d19d88e626a9736758e.tar.gz
gcc-fa7ccca021a5943040fd4d19d88e626a9736758e.tar.bz2
[PATCH][Testsuite]Use user defined memmove in gcc.c-torture/execute/builtins/memops-asm-lib.c
After the change r249278. bcopy is folded into memmove. And in newlib aarch64 memmove implementation, it will call memcpy in certain conditions. The memcpy defined in memops-asm-lib.c will abort when the test is running. A user defined memmove function is defined to bypass the library one. So that memcpy won't be called accidentally. gcc/testsuite/ * gcc.c-torture/execute/builtins/memops-asm-lib.c (my_memmove): New. * gcc.c-torture/execute/builtins/memops-asm.c (memmove): Declare memmove. Co-Authored-By: Szabolcs Nagy <szabolcs.nagy@arm.com> From-SVN: r249647
Diffstat (limited to 'gcc')
-rw-r--r--gcc/testsuite/ChangeLog7
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm-lib.c18
-rw-r--r--gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm.c2
3 files changed, 27 insertions, 0 deletions
diff --git a/gcc/testsuite/ChangeLog b/gcc/testsuite/ChangeLog
index 406db52..7fa3d95 100644
--- a/gcc/testsuite/ChangeLog
+++ b/gcc/testsuite/ChangeLog
@@ -1,3 +1,10 @@
+2017-06-26 Renlin Li <renlin.li@arm.com>
+ Szabolcs Nagy <szabolcs.nagy@arm.com>
+
+ * gcc.c-torture/execute/builtins/memops-asm-lib.c (my_memmove): New.
+ * gcc.c-torture/execute/builtins/memops-asm.c (memmove): Declare
+ memmove.
+
2017-06-26 Richard Biener <rguenther@suse.de>
PR target/81175
diff --git a/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm-lib.c b/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm-lib.c
index 0000529..25d4a40 100644
--- a/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm-lib.c
+++ b/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm-lib.c
@@ -37,6 +37,24 @@ my_bcopy (const void *s, void *d, size_t n)
}
}
+__attribute__ ((used))
+void
+my_memmove (void *d, const void *s, size_t n)
+{
+ char *dst = (char *) d;
+ const char *src = (const char *) s;
+ if (src >= dst)
+ while (n--)
+ *dst++ = *src++;
+ else
+ {
+ dst += n;
+ src += n;
+ while (n--)
+ *--dst = *--src;
+ }
+}
+
/* LTO code is at the present to able to track that asm alias my_bcopy on builtin
actually refers to this function. See PR47181. */
__attribute__ ((used))
diff --git a/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm.c b/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm.c
index ed2b06c..44e336c 100644
--- a/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm.c
+++ b/gcc/testsuite/gcc.c-torture/execute/builtins/memops-asm.c
@@ -12,6 +12,8 @@ extern void *memcpy (void *, const void *, size_t)
__asm (ASMNAME ("my_memcpy"));
extern void bcopy (const void *, void *, size_t)
__asm (ASMNAME ("my_bcopy"));
+extern void *memmove (void *, const void *, size_t)
+ __asm (ASMNAME ("my_memmove"));
extern void *memset (void *, int, size_t)
__asm (ASMNAME ("my_memset"));
extern void bzero (void *, size_t)