summaryrefslogtreecommitdiff
path: root/ld/ldlang.c
diff options
context:
space:
mode:
authorAlan Modra <amodra@bigpond.net.au>2012-06-25 01:49:07 +0000
committerAlan Modra <amodra@bigpond.net.au>2012-06-25 01:49:07 +0000
commitcf62de24b483829a634646198c87f771fb9e22ce (patch)
tree11b03e528acad2cd43ab6d5a3ad72db07c5e9055 /ld/ldlang.c
parentc4a0588076274d523b8cf9ac87032e06d8f129a7 (diff)
downloadbinutils-redhat-cf62de24b483829a634646198c87f771fb9e22ce.tar.gz
* ldlang.c (load_symbols): Close file and set flags.loaded
after parsing script file. (open_input_bfds): Don't segv on closed script.
Diffstat (limited to 'ld/ldlang.c')
-rw-r--r--ld/ldlang.c6
1 files changed, 6 insertions, 0 deletions
diff --git a/ld/ldlang.c b/ld/ldlang.c
index ddf3be22eb..7dd2fa4f50 100644
--- a/ld/ldlang.c
+++ b/ld/ldlang.c
@@ -2668,6 +2668,7 @@ load_symbols (lang_input_statement_type *entry,
{
bfd_error_type err;
struct lang_input_statement_flags save_flags;
+ extern FILE *yyin;
err = bfd_get_error ();
@@ -2715,6 +2716,9 @@ load_symbols (lang_input_statement_type *entry,
save_flags.missing_file |= input_flags.missing_file;
input_flags = save_flags;
pop_stat_ptr ();
+ fclose (yyin);
+ yyin = NULL;
+ entry->flags.loaded = TRUE;
return TRUE;
}
@@ -3224,6 +3228,7 @@ open_input_bfds (lang_statement_union_type *s, enum open_bfd_mode mode)
#endif
&& !s->input_statement.flags.whole_archive
&& s->input_statement.flags.loaded
+ && s->input_statement.the_bfd != NULL
&& bfd_check_format (s->input_statement.the_bfd,
bfd_archive))
s->input_statement.flags.loaded = FALSE;
@@ -3233,6 +3238,7 @@ open_input_bfds (lang_statement_union_type *s, enum open_bfd_mode mode)
&& plugin_insert == NULL
&& s->input_statement.flags.loaded
&& s->input_statement.flags.add_DT_NEEDED_for_regular
+ && s->input_statement.the_bfd != NULL
&& ((s->input_statement.the_bfd->flags) & DYNAMIC) != 0
&& plugin_should_reload (s->input_statement.the_bfd))
{