mirror of
https://sourceware.org/git/glibc.git
synced 2024-12-23 03:10:05 +00:00
Don't underestimate length of DST substitution
This commit is contained in:
parent
4bf7d39245
commit
4c35fb65c9
@ -1,3 +1,8 @@
|
|||||||
|
2010-03-12 Andreas Schwab <schwab@redhat.com>
|
||||||
|
|
||||||
|
* elf/dl-dst.h: Include "trusted-dirs.h".
|
||||||
|
(DL_DST_REQUIRED): Take $LIB into account.
|
||||||
|
|
||||||
2010-03-11 Roland McGrath <roland@redhat.com>
|
2010-03-11 Roland McGrath <roland@redhat.com>
|
||||||
|
|
||||||
* elf/elf.h (R_X86_64_GOT64, R_X86_64_GOTPCREL64): New macros.
|
* elf/elf.h (R_X86_64_GOT64, R_X86_64_GOTPCREL64): New macros.
|
||||||
|
21
elf/dl-dst.h
21
elf/dl-dst.h
@ -18,6 +18,8 @@
|
|||||||
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
|
||||||
02111-1307 USA. */
|
02111-1307 USA. */
|
||||||
|
|
||||||
|
#include "trusted-dirs.h"
|
||||||
|
|
||||||
/* Determine the number of DST elements in the name. Only if IS_PATH is
|
/* Determine the number of DST elements in the name. Only if IS_PATH is
|
||||||
nonzero paths are recognized (i.e., multiple, ':' separated filenames). */
|
nonzero paths are recognized (i.e., multiple, ':' separated filenames). */
|
||||||
#define DL_DST_COUNT(name, is_path) \
|
#define DL_DST_COUNT(name, is_path) \
|
||||||
@ -39,12 +41,13 @@
|
|||||||
\
|
\
|
||||||
if (__cnt > 0) \
|
if (__cnt > 0) \
|
||||||
{ \
|
{ \
|
||||||
size_t origin_len; \
|
size_t dst_len; \
|
||||||
/* Now we make a guess how many extra characters on top of the \
|
/* 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 \
|
length of S we need to represent the result. We know that \
|
||||||
we have CNT replacements. Each at most can use \
|
we have CNT replacements. Each at most can use \
|
||||||
MAX (strlen (ORIGIN), strlen (_dl_platform)) \
|
MAX (MAX (strlen (ORIGIN), strlen (_dl_platform)), \
|
||||||
minus 7 (which is the length of "$ORIGIN"). \
|
strlen (DL_DST_LIB)) \
|
||||||
|
minus 4 (which is the length of "$LIB"). \
|
||||||
\
|
\
|
||||||
First get the origin string if it is not available yet. \
|
First get the origin string if it is not available yet. \
|
||||||
This can only happen for the map of the executable. */ \
|
This can only happen for the map of the executable. */ \
|
||||||
@ -53,14 +56,16 @@
|
|||||||
{ \
|
{ \
|
||||||
assert ((l)->l_name[0] == '\0'); \
|
assert ((l)->l_name[0] == '\0'); \
|
||||||
(l)->l_origin = _dl_get_origin (); \
|
(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); \
|
? strlen ((l)->l_origin) : 0); \
|
||||||
} \
|
} \
|
||||||
else \
|
else \
|
||||||
origin_len = (l)->l_origin == (char *) -1 \
|
dst_len = (l)->l_origin == (char *) -1 \
|
||||||
? 0 : strlen ((l)->l_origin); \
|
? 0 : strlen ((l)->l_origin); \
|
||||||
\
|
dst_len = MAX (MAX (dst_len, GLRO(dl_platformlen)), \
|
||||||
__len += __cnt * (MAX (origin_len, GLRO(dl_platformlen)) - 7); \
|
strlen (DL_DST_LIB)); \
|
||||||
|
if (dst_len > 4) \
|
||||||
|
__len += __cnt * (dst_len - 4); \
|
||||||
} \
|
} \
|
||||||
\
|
\
|
||||||
__len; })
|
__len; })
|
||||||
@ -72,7 +77,7 @@
|
|||||||
if ((l) == NULL) \
|
if ((l) == NULL) \
|
||||||
{ \
|
{ \
|
||||||
const char *origin = _dl_get_origin (); \
|
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
|
else
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
Reference in New Issue
Block a user