diff options
author | Andreas Schwab <schwab@redhat.com> | 2010-03-12 07:57:19 -0800 |
---|---|---|
committer | Petr Baudis <pasky@suse.cz> | 2011-02-03 20:47:43 +0100 |
commit | 47968f8ba80aaa0d3f1a9f55bf0876a684f880be (patch) | |
tree | 9354a509c9f8983772cda79218fba9345d155ba2 | |
parent | bbfacbc5eacc1394bedce108cafff7baebecae7e (diff) | |
download | glibc-47968f8ba80aaa0d3f1a9f55bf0876a684f880be.tar.gz glibc-47968f8ba80aaa0d3f1a9f55bf0876a684f880be.tar.xz glibc-47968f8ba80aaa0d3f1a9f55bf0876a684f880be.zip |
Don't underestimate length of DST substitution
(cherry picked from commit 4c35fb65c9ea221561bc5698358944a73383b3d6)
-rw-r--r-- | ChangeLog | 5 | ||||
-rw-r--r-- | elf/dl-dst.h | 21 |
2 files changed, 18 insertions, 8 deletions
diff --git a/ChangeLog b/ChangeLog index d66e3db717..aaf1b4cfca 100644 --- a/ChangeLog +++ b/ChangeLog @@ -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. + 2011-01-10 Paul Pluzhnikov <ppluzhnikov@google.com> * sysdeps/i386/Makefile: stdlib/cxa_finalize.c needs 16-byte stack diff --git a/elf/dl-dst.h b/elf/dl-dst.h index 76076a6036..ae8d119c0d 100644 --- a/elf/dl-dst.h +++ b/elf/dl-dst.h @@ -18,6 +18,8 @@ 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). */ #define DL_DST_COUNT(name, is_path) \ @@ -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 |