diff options
-rw-r--r-- | ld/ChangeLog | 7 | ||||
-rw-r--r-- | ld/emultempl/elf32.em | 11 |
2 files changed, 13 insertions, 5 deletions
diff --git a/ld/ChangeLog b/ld/ChangeLog index 3b0724f..45cb574 100644 --- a/ld/ChangeLog +++ b/ld/ChangeLog @@ -1,3 +1,10 @@ +2001-08-13 Alan Modra <amodra@bigpond.net.au> + + * emultempl/elf32.em (gld${EMULATION_NAME}_place_orphan): Return + `true' for SEC_EXCLUDE sections so that the generic code doesn't + needlessly create an output_section_statement. Treat a correctly + named output_section_statement with NULL bfd_section as compatible. + 2001-08-13 Hans-Peter Nilsson <hp@bitrange.com> * emultempl/generic.em: Support EXTRA_EM_FILE. diff --git a/ld/emultempl/elf32.em b/ld/emultempl/elf32.em index fff17f6..d6d4729 100644 --- a/ld/emultempl/elf32.em +++ b/ld/emultempl/elf32.em @@ -1079,11 +1079,12 @@ gld${EMULATION_NAME}_place_orphan (file, s) os = lang_output_section_find (secname); if (os != NULL - && os->bfd_section != NULL - && ((s->flags ^ os->bfd_section->flags) - & (SEC_LOAD | SEC_ALLOC)) == 0) + && (os->bfd_section == NULL + || ((s->flags ^ os->bfd_section->flags) + & (SEC_LOAD | SEC_ALLOC)) == 0)) { - /* We have already placed a section with this name. */ + /* We already have an output section statement with this + name, and its bfd section has compatible flags. */ wild_doit (&os->children, s, os, file); return true; } @@ -1112,7 +1113,7 @@ gld${EMULATION_NAME}_place_orphan (file, s) (hold.os != NULL || (hold.os = lang_output_section_find (name)) != NULL) if (s->flags & SEC_EXCLUDE) - return false; + return true; place = NULL; if ((s->flags & SEC_ALLOC) == 0) |