2005-09-09 David Daney <ddaney@avtrex.com>
* gcc.c-torture/execute/
20010124-1.c: Removed and split into two new
files which are ...
* gcc.c-torture/execute/builtins/
20010124-1: ... here and ...
* gcc.c-torture/execute/builtins/
20010124-1-lib.c: ... here.
From-SVN: r104116
+2005-09-09 David Daney <ddaney@avtrex.com>
+
+ * gcc.c-torture/execute/20010124-1.c: Removed and split into two new
+ files which are ...
+ * gcc.c-torture/execute/builtins/20010124-1: ... here and ...
+ * gcc.c-torture/execute/builtins/20010124-1-lib.c: ... here.
+
2005-09-09 Francois-Xavier Coudert <coudert@clipper.ens.fr>
* gfortran.dg/iostat_2.f90: New test.
+++ /dev/null
-/* Verify that structure return doesn't invoke memcpy on
- overlapping objects. */
-
-extern void abort (void);
-typedef __SIZE_TYPE__ size_t;
-
-struct S {
- char stuff[1024];
-};
-
-union U {
- struct {
- int space;
- struct S s;
- } a;
- struct {
- struct S s;
- int space;
- } b;
-};
-
-static struct S f(struct S *);
-static void g(union U *);
-
-int main()
-{
- union U u;
- u.b.s = f(&u.a.s);
- u.a.s = f(&u.b.s);
- g(&u);
- return 0;
-}
-
-static struct S f(struct S *p)
-{
- return *p;
-}
-
-static void g(union U *p)
-{
-}
-
-static void *memcpy(void *a, const void *b, size_t len)
-{
- if (a < b && a+len > b)
- abort ();
- if (b < a && b+len > a)
- abort ();
- return a;
-}
--- /dev/null
+/* Verify that structure return doesn't invoke memcpy on
+ overlapping objects. */
+
+extern void abort (void);
+extern int inside_main;
+typedef __SIZE_TYPE__ size_t;
+
+struct S {
+ char stuff[1024];
+};
+
+union U {
+ struct {
+ int space;
+ struct S s;
+ } a;
+ struct {
+ struct S s;
+ int space;
+ } b;
+};
+
+struct S f(struct S *p)
+{
+ return *p;
+}
+
+void g(union U *p)
+{
+}
+
+void *memcpy(void *a, const void *b, size_t len)
+{
+ if (inside_main)
+ {
+ if (a < b && a+len > b)
+ abort ();
+ if (b < a && b+len > a)
+ abort ();
+ return a;
+ }
+ else
+ {
+ char *dst = (char *) a;
+ const char *src = (const char *) b;
+ while (len--)
+ *dst++ = *src++;
+ return a;
+ }
+}
--- /dev/null
+/* Verify that structure return doesn't invoke memcpy on
+ overlapping objects. */
+
+extern void abort (void);
+
+struct S {
+ char stuff[1024];
+};
+
+union U {
+ struct {
+ int space;
+ struct S s;
+ } a;
+ struct {
+ struct S s;
+ int space;
+ } b;
+};
+
+struct S f(struct S *);
+void g(union U *);
+
+void main_test(void)
+{
+ union U u;
+ u.b.s = f(&u.a.s);
+ u.a.s = f(&u.b.s);
+ g(&u);
+}