diff options
-rw-r--r-- | ChangeLog | 1 | ||||
-rw-r--r-- | sysdeps/i386/dl-machine.h | 18 |
2 files changed, 5 insertions, 14 deletions
@@ -4,6 +4,7 @@ * elf/Versions: Remove _dl_preinit. * elf/dl-preinit.c: Removed. Move content into... * elf/dl-init.c: ...here. + * sysdeps/i386/dl-machine.h (RTLD_START): Remove call to _dl_preinit. * sysdeps/generic/bits/shm.h (struct shmid_ds): Correct names of with size of dynamic sectionelements. diff --git a/sysdeps/i386/dl-machine.h b/sysdeps/i386/dl-machine.h index 1256fbcdc0..2680b05a6c 100644 --- a/sysdeps/i386/dl-machine.h +++ b/sysdeps/i386/dl-machine.h @@ -218,27 +218,17 @@ _dl_start_user:\n\ movl (%eax), %eax\n\ # Pop the original argument count.\n\ popl %esi\n\ - # Subtract _dl_skip_args from it.\n\ - subl %eax, %esi\n\ # Adjust the stack pointer to skip _dl_skip_args words.\n\ leal (%esp,%eax,4), %esp\n\ - # Move the argv pointer in a register.\n\ - leal 4(%esp,%esi,4), %edx\n\ - movl %esp, %ecx\n\ - pushl %edx\n\ - movl %esi, %edx\n\ - # Get the searchlist of the main object as argument for\n\ - # _dl_preinit and _dl_init calls below.\n\ - movl _dl_loaded@GOT(%ebx), %ebp\n\ - movl (%ebp), %eax\n\ - # Call the function to run the pre-initializers.\n\ - call _dl_preinit@PLT\n\ + # Subtract _dl_skip_args from it.\n\ + subl %eax, %esi\n\ # Load the parameters again.\n\ leal 4(%esp,%esi,4), %edx\n\ movl %esp, %ecx\n\ pushl %edx\n\ movl %esi, %edx\n\ - movl (%ebp), %eax\n\ + movl _dl_loaded@GOT(%ebx), %eax\n\ + movl (%eax), %eax\n\ # Call the function to run the initializers.\n\ call _dl_init@PLT\n\ # Push argc back on the stack.\n\ |