aboutsummaryrefslogtreecommitdiff
path: root/binutils
diff options
context:
space:
mode:
Diffstat (limited to 'binutils')
-rw-r--r--binutils/ChangeLog7
-rw-r--r--binutils/dlltool.c20
2 files changed, 26 insertions, 1 deletions
diff --git a/binutils/ChangeLog b/binutils/ChangeLog
index a615361..4c78f79 100644
--- a/binutils/ChangeLog
+++ b/binutils/ChangeLog
@@ -1,3 +1,10 @@
+2017-02-27 Rudy Y <rudyy.id@gmail.com>
+
+ PR 20881
+ * dlltool.c (secdata): Align .idata$6 on 2 byte boundary.
+ (make_one_lib_file): Export a symbol called __nm_<symbol> for use
+ with auto-importing.
+
2017-02-25 Alan Modra <amodra@gmail.com>
* testsuite/binutils-all/dw5.S: Replace .string with .asciz.
diff --git a/binutils/dlltool.c b/binutils/dlltool.c
index 15e6d7f..88ee5a5 100644
--- a/binutils/dlltool.c
+++ b/binutils/dlltool.c
@@ -2338,7 +2338,7 @@ static sinfo secdata[NSECS] =
INIT_SEC_DATA (IDATA7, ".idata$7", SEC_HAS_CONTENTS, 2),
INIT_SEC_DATA (IDATA5, ".idata$5", SEC_HAS_CONTENTS, 2),
INIT_SEC_DATA (IDATA4, ".idata$4", SEC_HAS_CONTENTS, 2),
- INIT_SEC_DATA (IDATA6, ".idata$6", SEC_HAS_CONTENTS, 1)
+ INIT_SEC_DATA (IDATA6, ".idata$6", SEC_HAS_CONTENTS, 2)
};
#else
@@ -2543,6 +2543,18 @@ make_one_lib_file (export_type *exp, int i, int delay)
#endif
ptrs[oidx++] = exp_label;
}
+#ifndef DLLTOOL_PPC
+ else
+ {
+ /* PR 20881: Add __nm_<symbol> for the exported library.
+ FIXME: Might be needed for PowerPC, but currently unable to test this. */
+ exp_label = bfd_make_empty_symbol (abfd);
+ exp_label->name = make_imp_label ("__nm_", exp->name);
+ exp_label->section = secdata[IDATA6].sec;
+ exp_label->flags = BSF_GLOBAL;
+ exp_label->value = 0;
+ }
+#endif
/* Generate imp symbols with one underscore for Microsoft
compatibility, and with two underscores for backward
@@ -2573,6 +2585,12 @@ make_one_lib_file (export_type *exp, int i, int delay)
if (create_compat_implib)
ptrs[oidx++] = iname;
ptrs[oidx++] = iname2;
+#ifndef DLLTOOL_PPC
+ /* PR 20881:
+ According to pe-dll.c __nm_<symbol> should be add after __imp_<symbol>. */
+ if (exp->data)
+ ptrs[oidx++] = exp_label;
+#endif
iname_lab_pp = ptrs + oidx;
ptrs[oidx++] = iname_lab;