olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-rh1505492-undef-32.patch

00db10
commit 99f8dc922033821edcc13f9f8360e9fda40dfcff
00db10
Author: Siddhesh Poyarekar <siddhesh@redhat.com>
00db10
Date:   Thu Jul 3 01:28:45 2014 +0530
00db10
00db10
    Fix -Wundef warning on PAGE_COPY_THRESHOLD
00db10
    
00db10
    The PAGE_COPY_THRESHOLD macro is meant to be overridden by
00db10
    architecture-specific pagecopy.h, but it is currently done only by
00db10
    mach; all other architectures use the default.  Check to see if the
00db10
    macro is defined in addition to whether it is set to a non-zero value.
00db10
00db10
Conflicts:
00db10
	sysdeps/generic/pagecopy.h
00db10
00db10
Due to copyright header change.
00db10
00db10
diff --git a/debug/memcpy_chk.c b/debug/memcpy_chk.c
00db10
index bd43583ff4239c8a..4af85a8cb8f5c8de 100644
00db10
--- a/debug/memcpy_chk.c
00db10
+++ b/debug/memcpy_chk.c
00db10
@@ -20,7 +20,6 @@
00db10
 
00db10
 #include <string.h>
00db10
 #include <memcopy.h>
00db10
-#include <pagecopy.h>
00db10
 
00db10
 void *
00db10
 __memcpy_chk (dstpp, srcpp, len, dstlen)
00db10
diff --git a/debug/mempcpy_chk.c b/debug/mempcpy_chk.c
00db10
index 8e26953764ff1b35..9a4f0e2fbcdde951 100644
00db10
--- a/debug/mempcpy_chk.c
00db10
+++ b/debug/mempcpy_chk.c
00db10
@@ -21,7 +21,6 @@
00db10
 
00db10
 #include <string.h>
00db10
 #include <memcopy.h>
00db10
-#include <pagecopy.h>
00db10
 
00db10
 void *
00db10
 __mempcpy_chk (dstpp, srcpp, len, dstlen)
00db10
diff --git a/string/memcpy.c b/string/memcpy.c
00db10
index 3080fcb4de4cec83..fa1ec24eaca527c4 100644
00db10
--- a/string/memcpy.c
00db10
+++ b/string/memcpy.c
00db10
@@ -20,7 +20,6 @@
00db10
 
00db10
 #include <string.h>
00db10
 #include <memcopy.h>
00db10
-#include <pagecopy.h>
00db10
 
00db10
 #undef memcpy
00db10
 
00db10
diff --git a/string/memmove.c b/string/memmove.c
00db10
index c59e7a9c2a640f7d..51bff31c0530ba91 100644
00db10
--- a/string/memmove.c
00db10
+++ b/string/memmove.c
00db10
@@ -20,7 +20,6 @@
00db10
 
00db10
 #include <string.h>
00db10
 #include <memcopy.h>
00db10
-#include <pagecopy.h>
00db10
 
00db10
 /* All this is so that bcopy.c can #include
00db10
    this file after defining some things.  */
00db10
diff --git a/sysdeps/generic/memcopy.h b/sysdeps/generic/memcopy.h
00db10
index 08892a4ea33f1ca7..d0ffcd33b007ba38 100644
00db10
--- a/sysdeps/generic/memcopy.h
00db10
+++ b/sysdeps/generic/memcopy.h
00db10
@@ -40,6 +40,7 @@
00db10
 
00db10
 #include <sys/cdefs.h>
00db10
 #include <endian.h>
00db10
+#include <pagecopy.h>
00db10
 
00db10
 /* The macros defined in this file are:
00db10
 
00db10
@@ -144,6 +145,47 @@ extern void _wordcopy_bwd_dest_aligned (long int, long int, size_t) __THROW;
00db10
       (nbytes_left) = (nbytes) % OPSIZ;					      \
00db10
     } while (0)
00db10
 
00db10
+/* The macro PAGE_COPY_FWD_MAYBE (dstp, srcp, nbytes_left, nbytes) is invoked
00db10
+   like WORD_COPY_FWD et al.  The pointers should be at least word aligned.
00db10
+   This will check if virtual copying by pages can and should be done and do it
00db10
+   if so.  The pointers will be aligned to PAGE_SIZE bytes.  The macro requires
00db10
+   that pagecopy.h defines at least PAGE_COPY_THRESHOLD to 0.  If
00db10
+   PAGE_COPY_THRESHOLD is non-zero, the header must also define PAGE_COPY_FWD
00db10
+   and PAGE_SIZE.
00db10
+*/
00db10
+#if PAGE_COPY_THRESHOLD
00db10
+
00db10
+# include <assert.h>
00db10
+
00db10
+# define PAGE_COPY_FWD_MAYBE(dstp, srcp, nbytes_left, nbytes)		      \
00db10
+  do									      \
00db10
+    {									      \
00db10
+      if ((nbytes) >= PAGE_COPY_THRESHOLD &&				      \
00db10
+	  PAGE_OFFSET ((dstp) - (srcp)) == 0) 				      \
00db10
+	{								      \
00db10
+	  /* The amount to copy is past the threshold for copying	      \
00db10
+	     pages virtually with kernel VM operations, and the		      \
00db10
+	     source and destination addresses have the same alignment.  */    \
00db10
+	  size_t nbytes_before = PAGE_OFFSET (-(dstp));			      \
00db10
+	  if (nbytes_before != 0)					      \
00db10
+	    {								      \
00db10
+	      /* First copy the words before the first page boundary.  */     \
00db10
+	      WORD_COPY_FWD (dstp, srcp, nbytes_left, nbytes_before);	      \
00db10
+	      assert (nbytes_left == 0);				      \
00db10
+	      nbytes -= nbytes_before;					      \
00db10
+	    }								      \
00db10
+	  PAGE_COPY_FWD (dstp, srcp, nbytes_left, nbytes);		      \
00db10
+	}								      \
00db10
+    } while (0)
00db10
+
00db10
+/* The page size is always a power of two, so we can avoid modulo division.  */
00db10
+# define PAGE_OFFSET(n)	((n) & (PAGE_SIZE - 1))
00db10
+
00db10
+#else
00db10
+
00db10
+# define PAGE_COPY_FWD_MAYBE(dstp, srcp, nbytes_left, nbytes) /* nada */
00db10
+
00db10
+#endif
00db10
 
00db10
 /* Threshold value for when to enter the unrolled loops.  */
00db10
 #define	OP_T_THRES	16
00db10
diff --git a/sysdeps/generic/pagecopy.h b/sysdeps/generic/pagecopy.h
00db10
index 89f392cb43c4dcbc..3c81de1b236486bf 100644
00db10
--- a/sysdeps/generic/pagecopy.h
00db10
+++ b/sysdeps/generic/pagecopy.h
00db10
@@ -1,5 +1,5 @@
00db10
-/* Macros for copying by pages; used in memcpy, memmove.  Generic macros.
00db10
-   Copyright (C) 1995, 1997 Free Software Foundation, Inc.
00db10
+/* Macros for copying by pages; used in memcpy, memmove.
00db10
+   Copyright (C) 1995-2014 Free Software Foundation, Inc.
00db10
    This file is part of the GNU C Library.
00db10
 
00db10
    The GNU C Library is free software; you can redistribute it and/or
00db10
@@ -16,19 +16,15 @@
00db10
    License along with the GNU C Library; if not, see
00db10
    <http://www.gnu.org/licenses/>.  */
00db10
 
00db10
-/* This file defines the macro:
00db10
+/* The macro PAGE_COPY_FWD_MAYBE defined in memcopy.h is used in memmove if the
00db10
+   PAGE_COPY_THRESHOLD macro is set to a non-zero value.  The default is 0,
00db10
+   that is copying by pages is not implemented.
00db10
 
00db10
-   PAGE_COPY_FWD_MAYBE (dstp, srcp, nbytes_left, nbytes)
00db10
-
00db10
-   which is invoked like WORD_COPY_FWD et al.  The pointers should be at
00db10
-   least word aligned.  This will check if virtual copying by pages can and
00db10
-   should be done and do it if so.
00db10
-
00db10
-   System-specific pagecopy.h files should define these macros and then
00db10
-   #include this file:
00db10
+   System-specific pagecopy.h files that want to support page copying should
00db10
+   define these macros:
00db10
 
00db10
    PAGE_COPY_THRESHOLD
00db10
-   -- Minimum size for which virtual copying by pages is worthwhile.
00db10
+   -- A non-zero minimum size for which virtual copying by pages is worthwhile.
00db10
 
00db10
    PAGE_SIZE
00db10
    -- Size of a page.
00db10
@@ -38,37 +34,4 @@
00db10
    The pointers will be aligned to PAGE_SIZE bytes.
00db10
 */
00db10
 
00db10
-
00db10
-#if PAGE_COPY_THRESHOLD
00db10
-
00db10
-#include <assert.h>
00db10
-
00db10
-#define PAGE_COPY_FWD_MAYBE(dstp, srcp, nbytes_left, nbytes)		      \
00db10
-  do									      \
00db10
-    {									      \
00db10
-      if ((nbytes) >= PAGE_COPY_THRESHOLD &&				      \
00db10
-	  PAGE_OFFSET ((dstp) - (srcp)) == 0) 				      \
00db10
-	{								      \
00db10
-	  /* The amount to copy is past the threshold for copying	      \
00db10
-	     pages virtually with kernel VM operations, and the		      \
00db10
-	     source and destination addresses have the same alignment.  */    \
00db10
-	  size_t nbytes_before = PAGE_OFFSET (-(dstp));			      \
00db10
-	  if (nbytes_before != 0)					      \
00db10
-	    {								      \
00db10
-	      /* First copy the words before the first page boundary.  */     \
00db10
-	      WORD_COPY_FWD (dstp, srcp, nbytes_left, nbytes_before);	      \
00db10
-	      assert (nbytes_left == 0);				      \
00db10
-	      nbytes -= nbytes_before;					      \
00db10
-	    }								      \
00db10
-	  PAGE_COPY_FWD (dstp, srcp, nbytes_left, nbytes);		      \
00db10
-	}								      \
00db10
-    } while (0)
00db10
-
00db10
-/* The page size is always a power of two, so we can avoid modulo division.  */
00db10
-#define PAGE_OFFSET(n)	((n) & (PAGE_SIZE - 1))
00db10
-
00db10
-#else
00db10
-
00db10
-#define PAGE_COPY_FWD_MAYBE(dstp, srcp, nbytes_left, nbytes) /* nada */
00db10
-
00db10
-#endif
00db10
+#define PAGE_COPY_THRESHOLD 0
00db10
diff --git a/sysdeps/mach/pagecopy.h b/sysdeps/mach/pagecopy.h
00db10
index 5b212144b7b163fe..8cce76a6d76698b9 100644
00db10
--- a/sysdeps/mach/pagecopy.h
00db10
+++ b/sysdeps/mach/pagecopy.h
00db10
@@ -30,6 +30,3 @@
00db10
 				(vm_address_t) dstp) == KERN_SUCCESS	      \
00db10
 		     ? trunc_page (nbytes)				      \
00db10
 		     : 0)))
00db10
-
00db10
-/* Get the generic macro.  */
00db10
-#include <sysdeps/generic/pagecopy.h>
00db10
diff --git a/sysdeps/powerpc/memmove.c b/sysdeps/powerpc/memmove.c
00db10
index 1617ecea95620133..50734e45458352c5 100644
00db10
--- a/sysdeps/powerpc/memmove.c
00db10
+++ b/sysdeps/powerpc/memmove.c
00db10
@@ -20,7 +20,6 @@
00db10
 
00db10
 #include <string.h>
00db10
 #include <memcopy.h>
00db10
-#include <pagecopy.h>
00db10
 
00db10
 /* All this is so that bcopy.c can #include
00db10
    this file after defining some things.  */