aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--ChangeLog1
-rw-r--r--sysdeps/i386/dl-machine.h18
2 files changed, 5 insertions, 14 deletions
diff --git a/ChangeLog b/ChangeLog
index 1a1c0ca949..38d9b02262 100644
--- a/ChangeLog
+++ b/ChangeLog
@@ -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\