From: Rudy Y Date: Thu, 1 Dec 2016 14:43:36 +0000 (+0000) Subject: Fix generation of IDATA[6] for PE files. X-Git-Tag: users/ARM/embedded-binutils-master-2016q4~57 X-Git-Url: http://git.ipfire.org/?a=commitdiff_plain;h=4ee1d7e401a8c1aedfdc86aac7faa8267eab1e5c;p=thirdparty%2Fbinutils-gdb.git Fix generation of IDATA[6] for PE files. PR ld/20880 * pe-dll.c (make_one): Use the hint if the ordinal is -1. --- diff --git a/ld/ChangeLog b/ld/ChangeLog index 446a4afa9a3..65c2854e9da 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,8 @@ +2016-12-01 Rudy Y + + PR ld/20880 + * pe-dll.c (make_one): Use the hint if the ordinal is -1. + 2016-12-01 Yury Norov PR ld/20868 diff --git a/ld/pe-dll.c b/ld/pe-dll.c index 055a6cf32c0..9d87cd2306a 100644 --- a/ld/pe-dll.c +++ b/ld/pe-dll.c @@ -2266,6 +2266,8 @@ make_one (def_file_export *exp, bfd *parent, bfd_boolean include_jmp_stub) } else { + int ord; + /* { short, asciz } */ if (exp->its_name) len = 2 + strlen (exp->its_name) + 1; @@ -2277,8 +2279,13 @@ make_one (def_file_export *exp, bfd *parent, bfd_boolean include_jmp_stub) d6 = xmalloc (len); id6->contents = d6; memset (d6, 0, len); - d6[0] = exp->hint & 0xff; - d6[1] = exp->hint >> 8; + + /* PR 20880: Use exp->hint as a backup, just in case exp->ordinal + contains an invalid value (-1). */ + ord = (exp->ordinal >= 0) ? exp->ordinal : exp->hint; + d6[0] = ord; + d6[1] = ord >> 8; + if (exp->its_name) strcpy ((char*) d6 + 2, exp->its_name); else