(_dl_map_object, _dl_map_object_from_fd): Remove last arg ENTRY_POINT.
authorroland <roland>
Sat, 30 Sep 1995 19:50:10 +0000 (19:50 +0000)
committerroland <roland>
Sat, 30 Sep 1995 19:50:10 +0000 (19:50 +0000)
Store the entry point location in the `l_entry' member of the new map.

elf/dl-load.c

index 7319602..2a50daa 100644 (file)
@@ -104,8 +104,7 @@ open_path (const char *name, size_t namelen,
 /* Map in the shared object file NAME.  */
 
 struct link_map *
 /* Map in the shared object file NAME.  */
 
 struct link_map *
-_dl_map_object (struct link_map *loader, const char *name,
-               Elf32_Addr *entry_point)
+_dl_map_object (struct link_map *loader, const char *name)
 {
   int fd;
   char *realname;
 {
   int fd;
   char *realname;
@@ -152,7 +151,7 @@ _dl_map_object (struct link_map *loader, const char *name,
   if (fd == -1)
     _dl_signal_error (errno, name, "cannot open shared object file");
 
   if (fd == -1)
     _dl_signal_error (errno, name, "cannot open shared object file");
 
-  return _dl_map_object_from_fd (name, fd, realname, entry_point);
+  return _dl_map_object_from_fd (name, fd, realname);
 }
 
 
 }
 
 
@@ -160,8 +159,7 @@ _dl_map_object (struct link_map *loader, const char *name,
    opened on FD.  */
 
 struct link_map *
    opened on FD.  */
 
 struct link_map *
-_dl_map_object_from_fd (const char *name, int fd, char *realname, 
-                       Elf32_Addr *entry_point)
+_dl_map_object_from_fd (const char *name, int fd, char *realname)
 {
   struct link_map *l = NULL;
   const size_t pagesize = getpagesize ();
 {
   struct link_map *l = NULL;
   const size_t pagesize = getpagesize ();
@@ -256,10 +254,6 @@ _dl_map_object_from_fd (const char *name, int fd, char *realname,
     l->l_phnum = header->e_phnum;
 
     anywhere = header->e_type == ET_DYN || header->e_type == ET_REL;
     l->l_phnum = header->e_phnum;
 
     anywhere = header->e_type == ET_DYN || header->e_type == ET_REL;
-
-    if (entry_point)
-      *entry_point = header->e_entry;
-
     /* We are done reading the file's headers now.  Unmap them.  */
     munmap (file_mapping, mapping_size);
 
     /* We are done reading the file's headers now.  Unmap them.  */
     munmap (file_mapping, mapping_size);
 
@@ -375,12 +369,18 @@ _dl_map_object_from_fd (const char *name, int fd, char *realname,
        }
 
     if (l->l_ld == 0)
        }
 
     if (l->l_ld == 0)
-      LOSE ("object file has no dynamic section");
-    (Elf32_Addr) l->l_ld += l->l_addr;
+      {
+       if (header->e_type == ET_DYN)
+         LOSE ("object file has no dynamic section");
+      }
+    else
+      (Elf32_Addr) l->l_ld += l->l_addr;
 
     if (l->l_phdr == 0)
       l->l_phdr = (void *) ((const Elf32_Ehdr *) l->l_addr)->e_phoff;
     (Elf32_Addr) l->l_phdr += l->l_addr;
 
     if (l->l_phdr == 0)
       l->l_phdr = (void *) ((const Elf32_Ehdr *) l->l_addr)->e_phoff;
     (Elf32_Addr) l->l_phdr += l->l_addr;
+
+    l->l_entry = l->l_addr + header->e_entry;
   }
 
   elf_get_dynamic_info (l->l_ld, l->l_info);
   }
 
   elf_get_dynamic_info (l->l_ld, l->l_info);