olga / rpms / glibc

Forked from rpms/glibc 5 years ago
Clone

Blame SOURCES/glibc-rh1505492-bounded-4.patch

c6d234
commit 3a7ac8a0f596bb73093212cd1109c1413777e1f8
c6d234
Author: Joseph Myers <joseph@codesourcery.com>
c6d234
Date:   Fri Feb 1 00:06:18 2013 +0000
c6d234
c6d234
    Remove bp-start.h and INIT_ARGV_and_ENVIRON.
c6d234
c6d234
Conflicts:
c6d234
	sysdeps/generic/bp-start.h
c6d234
c6d234
Copyright header change; file removed manually.
c6d234
c6d234
diff --git a/csu/libc-start.c b/csu/libc-start.c
c6d234
index ebf9f4ec7335f992..2fab8556a5e2cb26 100644
c6d234
--- a/csu/libc-start.c
c6d234
+++ b/csu/libc-start.c
c6d234
@@ -19,7 +19,6 @@
c6d234
 #include <stdio.h>
c6d234
 #include <unistd.h>
c6d234
 #include <ldsodefs.h>
c6d234
-#include <bp-start.h>
c6d234
 #include <bp-sym.h>
c6d234
 
c6d234
 extern void __libc_init_first (int argc, char **argv, char **envp);
c6d234
@@ -146,7 +145,7 @@ LIBC_START_MAIN (int (*main) (int, char **, char ** MAIN_AUXVEC_DECL),
c6d234
 #ifndef SHARED
c6d234
   char *__unbounded *__unbounded ubp_ev = &ubp_av[argc + 1];
c6d234
 
c6d234
-  INIT_ARGV_and_ENVIRON;
c6d234
+  __environ = ubp_ev;
c6d234
 
c6d234
   /* Store the lowest stack address.  This is done in ld.so if this is
c6d234
      the code for the DSO.  */
c6d234
diff --git a/sysdeps/generic/bp-start.h b/sysdeps/generic/bp-start.h
c6d234
deleted file mode 100644
c6d234
index 0f0339f54cba4aa8..0000000000000000
c6d234
--- a/sysdeps/generic/bp-start.h
c6d234
+++ /dev/null
c6d234
@@ -1,71 +0,0 @@
c6d234
-/* Bounded-pointer checking macros for C.
c6d234
-   Copyright (C) 2000 Free Software Foundation, Inc.
c6d234
-   This file is part of the GNU C Library.
c6d234
-   Contributed by Greg McGary <greg@mcgary.org>
c6d234
-
c6d234
-   The GNU C Library is free software; you can redistribute it and/or
c6d234
-   modify it under the terms of the GNU Lesser General Public
c6d234
-   License as published by the Free Software Foundation; either
c6d234
-   version 2.1 of the License, or (at your option) any later version.
c6d234
-
c6d234
-   The GNU C Library is distributed in the hope that it will be useful,
c6d234
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
c6d234
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
c6d234
-   Lesser General Public License for more details.
c6d234
-
c6d234
-   You should have received a copy of the GNU Lesser General Public
c6d234
-   License along with the GNU C Library; if not, see
c6d234
-   <http://www.gnu.org/licenses/>.  */
c6d234
-
c6d234
-
c6d234
-#if __BOUNDED_POINTERS__
c6d234
-
c6d234
-  /* The command-line arg vector and environment vector come to us from
c6d234
-     the OS as an unbounded pointer to an array of unbounded strings.
c6d234
-     The user's main expects argv and __environ to be bounded pointers
c6d234
-     to arrays of bounded strings.  */
c6d234
-# define INIT_ARGV_and_ENVIRON \
c6d234
-  do {									      \
c6d234
-    int envc;								      \
c6d234
-    for (envc = 0; *ubp_ev; ubp_ev++, envc++)				      \
c6d234
-      ;									      \
c6d234
-    ubp_ev -= envc;							      \
c6d234
-									      \
c6d234
-    /* GKM FIXME: we could save some space by allocating only enough for      \
c6d234
-       the additional low & high words, and destructively rewriting	      \
c6d234
-       argv in place.  */						      \
c6d234
-    __ptrvalue (argv) = __ptrlow (argv)					      \
c6d234
-      = alloca ((argc + envc + 2) * sizeof (*argv));			      \
c6d234
-    __ptrhigh (argv) = __ptrvalue (argv) + argc + 1;			      \
c6d234
-    __ptrvalue (__environ) = __ptrlow (__environ) = __ptrhigh (argv);	      \
c6d234
-    __ptrhigh (__environ) = __ptrvalue (__environ) + envc + 1;		      \
c6d234
-    boundify_vector (__environ, ubp_ev);				      \
c6d234
-    boundify_vector (argv, ubp_av);					      \
c6d234
-  } while (0)
c6d234
-
c6d234
-
c6d234
-/* Copy an unbounded vector of unbounded strings into a bounded
c6d234
-   counterpart.  */
c6d234
-
c6d234
-static void
c6d234
-boundify_vector (char **dest, char *__unbounded *__unbounded src)
c6d234
-{
c6d234
-  char *__unbounded s;
c6d234
-  for (; *src; src++, dest++)
c6d234
-    {
c6d234
-      __ptrvalue (*dest) = __ptrlow (*dest) = *src;
c6d234
-      __ptrhigh (*dest) = src[1];
c6d234
-    }
c6d234
-  *dest = 0;
c6d234
-  /* The OS lays out strings contiguously in vector order,
c6d234
-     so  */
c6d234
-  for (s = __ptrvalue (dest[-1]); *s; s++)
c6d234
-    ;
c6d234
-  __ptrhigh (dest[-1]) = ++s;
c6d234
-}
c6d234
-
c6d234
-#else
c6d234
-
c6d234
-# define INIT_ARGV_and_ENVIRON __environ = ubp_ev
c6d234
-
c6d234
-#endif
c6d234
diff --git a/sysdeps/unix/sysv/linux/powerpc/libc-start.c b/sysdeps/unix/sysv/linux/powerpc/libc-start.c
c6d234
index 98a793e0894f6936..89de1aa7e6e1df59 100644
c6d234
--- a/sysdeps/unix/sysv/linux/powerpc/libc-start.c
c6d234
+++ b/sysdeps/unix/sysv/linux/powerpc/libc-start.c
c6d234
@@ -20,7 +20,6 @@
c6d234
 #include <unistd.h>
c6d234
 #include <ldsodefs.h>
c6d234
 #include <sysdep.h>
c6d234
-#include <bp-start.h>
c6d234
 #include <bp-sym.h>
c6d234
 
c6d234