diff options
author | Nick Clifton <nickc@redhat.com> | 2003-04-02 17:39:24 +0000 |
---|---|---|
committer | Nick Clifton <nickc@redhat.com> | 2003-04-02 17:39:24 +0000 |
commit | 82cc02fb0c0b648393104bd6934be9007e5981cc (patch) | |
tree | 73fe4b760ec018c0b670fd9d1cf3d85a9e9fc73b /ld/pe-dll.c | |
parent | 46a10b9bf26b606e4a4005850d9294e557251480 (diff) | |
download | binutils-redhat-82cc02fb0c0b648393104bd6934be9007e5981cc.tar.gz |
pe-dll.c (pe_detail_list): arm-pe targets use underscores.
(process_def_file): Don't create an export section if there are no exports and
we're building an exe.
(pe_dll_build_sections): Ditto
(pe_dll_fill_sections): Conditionalize setting abfd->dll true on info->shared
emultempl/pe.em (gld_${EMULATION_NAME}_after_open): If i386pe or armpe, call
pe_dll_build_section() for both exe's and dll's, not just dll's. Don't call
pe_dll_build_section() if link_info.relocateable.
(gld_${EMULATION_NAME}_finish): For all targets except shpe and mipspe, call
pe_dll_fill_sections() for both exe's and dll's, not just dll's. Don't call
pe_dll_fill_sections() if link_info.relocateable.
Diffstat (limited to 'ld/pe-dll.c')
-rw-r--r-- | ld/pe-dll.c | 14 |
1 files changed, 12 insertions, 2 deletions
diff --git a/ld/pe-dll.c b/ld/pe-dll.c index 95cdd7e36c..1430754842 100644 --- a/ld/pe-dll.c +++ b/ld/pe-dll.c @@ -199,7 +199,7 @@ static pe_details_type pe_detail_list[] = 11 /* ARM_RVA32 */, PE_ARCH_arm, bfd_arch_arm, - 0 + 1 }, { "epoc-pei-arm-little", @@ -564,6 +564,12 @@ process_def_file (abfd, info) } } + /* If we are not building a DLL, when there are no exports + we do not build an export table at all. */ + if (!pe_dll_export_everything && pe_def_file->num_exports == 0 + && !(info->shared)) + return; + /* Now, maybe export everything else the default way. */ if (pe_dll_export_everything || pe_def_file->num_exports == 0) { @@ -2666,6 +2672,9 @@ pe_dll_build_sections (abfd, info) pe_dll_id_target (bfd_get_target (abfd)); process_def_file (abfd, info); + if (pe_def_file->num_exports == 0 && !(info->shared)) + return; + generate_edata (abfd, info); build_filler_bfd (1); } @@ -2707,7 +2716,8 @@ pe_dll_fill_sections (abfd, info) fill_edata (abfd, info); - pe_data (abfd)->dll = 1; + if (info->shared) + pe_data (abfd)->dll = 1; edata_s->contents = edata_d; reloc_s->contents = reloc_d; |