[Date Prev][Date Next][Thread Prev][Thread Next][Date Index][Thread Index]
[commits] r10020 - in /fsf/trunk/libc: ChangeLog elf/dl-dst.h sysdeps/unix/sysv/linux/sys/mount.h
- To: commits@xxxxxxxxxx
- Subject: [commits] r10020 - in /fsf/trunk/libc: ChangeLog elf/dl-dst.h sysdeps/unix/sysv/linux/sys/mount.h
- From: eglibc@xxxxxxxxxx
- Date: Sat, 13 Mar 2010 08:03:17 -0000
Author: eglibc
Date: Sat Mar 13 00:03:16 2010
New Revision: 10020
Log:
Import glibc-mainline for 2010-03-13
Modified:
fsf/trunk/libc/ChangeLog
fsf/trunk/libc/elf/dl-dst.h
fsf/trunk/libc/sysdeps/unix/sysv/linux/sys/mount.h
Modified: fsf/trunk/libc/ChangeLog
==============================================================================
--- fsf/trunk/libc/ChangeLog (original)
+++ fsf/trunk/libc/ChangeLog Sat Mar 13 00:03:16 2010
@@ -1,3 +1,12 @@
+2010-03-12 Ulrich Drepper <drepper@xxxxxxxxxx>
+
+ * sysdeps/unix/sysv/linux/sys/mount.h (UMOUNT_NOFOLLOW): Define.
+
+2010-03-12 Andreas Schwab <schwab@xxxxxxxxxx>
+
+ * elf/dl-dst.h: Include "trusted-dirs.h".
+ (DL_DST_REQUIRED): Take $LIB into account.
+
2010-03-11 Roland McGrath <roland@xxxxxxxxxx>
* elf/elf.h (R_X86_64_GOT64, R_X86_64_GOTPCREL64): New macros.
Modified: fsf/trunk/libc/elf/dl-dst.h
==============================================================================
--- fsf/trunk/libc/elf/dl-dst.h (original)
+++ fsf/trunk/libc/elf/dl-dst.h Sat Mar 13 00:03:16 2010
@@ -17,6 +17,8 @@
License along with the GNU C Library; if not, write to the Free
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
02111-1307 USA. */
+
+#include "trusted-dirs.h"
/* Determine the number of DST elements in the name. Only if IS_PATH is
nonzero paths are recognized (i.e., multiple, ':' separated filenames). */
@@ -39,12 +41,13 @@
\
if (__cnt > 0) \
{ \
- size_t origin_len; \
+ size_t dst_len; \
/* Now we make a guess how many extra characters on top of the \
length of S we need to represent the result. We know that \
we have CNT replacements. Each at most can use \
- MAX (strlen (ORIGIN), strlen (_dl_platform)) \
- minus 7 (which is the length of "$ORIGIN"). \
+ MAX (MAX (strlen (ORIGIN), strlen (_dl_platform)), \
+ strlen (DL_DST_LIB)) \
+ minus 4 (which is the length of "$LIB"). \
\
First get the origin string if it is not available yet. \
This can only happen for the map of the executable. */ \
@@ -53,14 +56,16 @@
{ \
assert ((l)->l_name[0] == '\0'); \
(l)->l_origin = _dl_get_origin (); \
- origin_len = ((l)->l_origin && (l)->l_origin != (char *) -1 \
+ dst_len = ((l)->l_origin && (l)->l_origin != (char *) -1 \
? strlen ((l)->l_origin) : 0); \
} \
else \
- origin_len = (l)->l_origin == (char *) -1 \
+ dst_len = (l)->l_origin == (char *) -1 \
? 0 : strlen ((l)->l_origin); \
- \
- __len += __cnt * (MAX (origin_len, GLRO(dl_platformlen)) - 7); \
+ dst_len = MAX (MAX (dst_len, GLRO(dl_platformlen)), \
+ strlen (DL_DST_LIB)); \
+ if (dst_len > 4) \
+ __len += __cnt * (dst_len - 4); \
} \
\
__len; })
@@ -72,7 +77,7 @@
if ((l) == NULL) \
{ \
const char *origin = _dl_get_origin (); \
- origin_len = (origin && origin != (char *) -1 ? strlen (origin) : 0); \
+ dst_len = (origin && origin != (char *) -1 ? strlen (origin) : 0); \
} \
else
#endif
Modified: fsf/trunk/libc/sysdeps/unix/sysv/linux/sys/mount.h
==============================================================================
--- fsf/trunk/libc/sysdeps/unix/sysv/linux/sys/mount.h (original)
+++ fsf/trunk/libc/sysdeps/unix/sysv/linux/sys/mount.h Sat Mar 13 00:03:16 2010
@@ -123,8 +123,10 @@
#define MNT_FORCE MNT_FORCE
MNT_DETACH = 2, /* Just detach from the tree. */
#define MNT_DETACH MNT_DETACH
- MNT_EXPIRE = 4 /* Mark for expiry. */
+ MNT_EXPIRE = 4, /* Mark for expiry. */
#define MNT_EXPIRE MNT_EXPIRE
+ UMOUNT_NOFOLLOW = 8 /* Don't follow symlink on umount. */
+#define UMOUNT_NOFOLLOW UMOUNT_NOFOLLOW
};