* pe-dll.c (pe_bfd_is_dll): New function.
authorChristopher Faylor <me+cygwin@cgf.cx>
Mon, 18 Dec 2006 22:38:53 +0000 (22:38 +0000)
committerChristopher Faylor <me+cygwin@cgf.cx>
Mon, 18 Dec 2006 22:38:53 +0000 (22:38 +0000)
* pe-dll.h (pe_bfd_is_dll): Declare.
* emultempl/pe.em (gld_${EMULATION_NAME}_recognized_file): Recognize dlls using
pe_bfd_is_dll instead of using the filename extension.

ld/ChangeLog
ld/emultempl/pe.em
ld/pe-dll.c
ld/pe-dll.h
ld/testsuite/ChangeLog

index a9a4b85..34ff9cd 100644 (file)
@@ -1,3 +1,10 @@
+2006-12-18  Pedro Alves  <pedro_alves@portugalmail.pt>
+
+       * pe-dll.c (pe_bfd_is_dll): New function.
+       * pe-dll.h (pe_bfd_is_dll): Declare.
+       * emultempl/pe.em (gld_${EMULATION_NAME}_recognized_file): Recognize
+       dlls using pe_bfd_is_dll instead of using the filename extension.
+
 2006-12-15  Ulrich Weigand  <uweigand@de.ibm.com>
 
        * configure.tgt (NATIVE_LIB_DIRS): Specify for spu-*-elf*.
index 5416fac..1396e98 100644 (file)
@@ -1415,19 +1415,8 @@ gld_${EMULATION_NAME}_recognized_file (lang_input_statement_type *entry ATTRIBUT
 #ifdef TARGET_IS_arm_wince_pe
   pe_dll_id_target ("pei-arm-wince-little");
 #endif
-  if (bfd_get_format (entry->the_bfd) == bfd_object)
-    {
-      char fbuf[LD_PATHMAX + 1];
-      const char *ext;
-
-      if (REALPATH (entry->filename, fbuf) == NULL)
-       strncpy (fbuf, entry->filename, sizeof (fbuf));
-
-      ext = fbuf + strlen (fbuf) - 4;
-
-      if (strcmp (ext, ".dll") == 0 || strcmp (ext, ".DLL") == 0)
-       return pe_implied_import_dll (fbuf);
-    }
+  if (pe_bfd_is_dll (entry->the_bfd))
+    return pe_implied_import_dll (entry->filename);
 #endif
   return FALSE;
 }
index 43caa0c..0f0f2e0 100644 (file)
@@ -2830,3 +2830,11 @@ pe_exe_fill_sections (bfd *abfd, struct bfd_link_info *info)
     }
   reloc_s->contents = reloc_d;
 }
+
+bfd_boolean
+pe_bfd_is_dll (bfd *abfd)
+{
+  return (bfd_get_format (abfd) == bfd_object
+          && obj_pe (abfd)
+          && pe_data (abfd)->dll);
+}
index c79e563..eb24a8a 100644 (file)
@@ -59,4 +59,7 @@ extern void pe_walk_relocs_of_symbol
   (struct bfd_link_info *, const char *, int (*) (arelent *, asection *));
 extern void pe_create_import_fixup
   (arelent * rel, asection *, int);
+extern bfd_boolean pe_bfd_is_dll
+  (bfd *);
+
 #endif /* PE_DLL_H */
index d333608..9a9daf8 100644 (file)
@@ -1,3 +1,9 @@
+2006-12-18  Pedro Alves  <pedro_alves@portugalmail.pt>
+
+       * ld-pe/direct.exp: New file.
+       * ld-pe/direct_client.c: Likewise.
+       * ld-pe/direct_dll.c: Likewise.
+
 2006-12-13  Dave Brolley  <brolley@redhat.com>
 
        * lib/ld-lib.exp (big_or_little_endian): Accept -meb and