clean up search_vec usage for vdso
authorRich Felker <dalias@aerifal.cx>
Sat, 25 Aug 2012 21:31:59 +0000 (17:31 -0400)
committerRich Felker <dalias@aerifal.cx>
Sat, 25 Aug 2012 21:31:59 +0000 (17:31 -0400)
src/ldso/dynlink.c

index 7c1bd89..981288c 100644 (file)
@@ -613,6 +613,7 @@ void *__dynlink(int argc, char **argv)
        struct dso *const lib = builtin_dsos+1;
        struct dso *const vdso = builtin_dsos+2;
        char *env_preload=0;
        struct dso *const lib = builtin_dsos+1;
        struct dso *const vdso = builtin_dsos+2;
        char *env_preload=0;
+       size_t vdso_base;
 
        /* Find aux vector just past environ[] */
        for (i=argc+1; argv[i]; i++)
 
        /* Find aux vector just past environ[] */
        for (i=argc+1; argv[i]; i++)
@@ -701,8 +702,7 @@ void *__dynlink(int argc, char **argv)
        decode_dyn(app);
 
        /* Attach to vdso, if provided by the kernel */
        decode_dyn(app);
 
        /* Attach to vdso, if provided by the kernel */
-       if (search_vec(auxv, aux, AT_SYSINFO_EHDR)) {
-               size_t vdso_base = *aux;
+       if (search_vec(auxv, &vdso_base, AT_SYSINFO_EHDR)) {
                ehdr = (void *)vdso_base;
                phdr = (void *)(vdso_base + ehdr->e_phoff);
                for (i=ehdr->e_phnum; i; i--, phdr=(void *)((char *)phdr + ehdr->e_phentsize)) {
                ehdr = (void *)vdso_base;
                phdr = (void *)(vdso_base + ehdr->e_phoff);
                for (i=ehdr->e_phnum; i; i--, phdr=(void *)((char *)phdr + ehdr->e_phentsize)) {