aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorSteve Chamberlain <sac@cygnus>1992-02-11 00:23:32 +0000
committerSteve Chamberlain <sac@cygnus>1992-02-11 00:23:32 +0000
commitffc500322549fb0747a8d66a0364c8964f02d3c7 (patch)
treed8d8d9d7fbde4321c3ccd26f2f592fc3c6d6348b
parentb745cf362d9701cb9d902bf3cce4281e5b188856 (diff)
downloadgdb-ffc500322549fb0747a8d66a0364c8964f02d3c7.zip
gdb-ffc500322549fb0747a8d66a0364c8964f02d3c7.tar.gz
gdb-ffc500322549fb0747a8d66a0364c8964f02d3c7.tar.bz2
* ldexp.c, ldlang.c: added new idea "abs_output_section", removes
tests for NULL pointers all over the place. * ldlang.c (lang_process): remember to relocate global symbols *after* relaxing has done it stuff.
-rw-r--r--ld/ldlang.c43
1 files changed, 34 insertions, 9 deletions
diff --git a/ld/ldlang.c b/ld/ldlang.c
index ef4fdf7..a268cbc 100644
--- a/ld/ldlang.c
+++ b/ld/ldlang.c
@@ -64,9 +64,10 @@ static size_t longest_section_name = 8;
static asection common_section;
static section_userdata_type common_section_userdata;
static lang_statement_list_type statement_list;
+
/* EXPORTS */
boolean relaxing;
-
+lang_output_section_statement_type *abs_output_section;
lang_statement_list_type *stat_ptr = &statement_list;
lang_input_statement_type *script_file = 0;
boolean option_longmap = false;
@@ -752,6 +753,12 @@ DEFUN(open_input_bfds,(statement),
static void
lang_reasonable_defaults()
{
+
+abs_output_section = lang_output_section_statement_lookup(BFD_ABS_SECTION_NAME);
+
+abs_output_section->bfd_section = &bfd_abs_section;
+
+
#if 0
lang_output_section_statement_lookup(".text");
lang_output_section_statement_lookup(".data");
@@ -1136,7 +1143,9 @@ DEFUN(print_padding_statement,(s),
print_space();
print_fill(s->fill);
print_nl();
+
print_dot = s->output_offset + s->output_section->vma + s->size;
+
}
static void
@@ -1463,7 +1472,7 @@ DEFUN(lang_size_sections,(s, output_section_statement, prev, fill,
dot,
&newdot);
- if (newdot != dot)
+ if (newdot != dot && )
/* We've been moved ! so insert a pad */
{
lang_statement_union_type *new =
@@ -1540,7 +1549,7 @@ DEFUN(lang_size_sections,(s, output_section_statement, prev, fill,
else {
etree_value_type r ;
r = exp_fold_tree(os->addr_tree,
- (lang_output_section_statement_type *)NULL,
+ abs_output_section,
lang_allocating_phase_enum,
dot, &dot);
if (r.valid == false) {
@@ -1575,6 +1584,19 @@ DEFUN(lang_size_sections,(s, output_section_statement, prev, fill,
if (os->addr_tree == (etree_type *)NULL
&& os->region !=(lang_memory_region_type*)NULL ) {
os->region->current = dot;
+ /* Make sure this isn't silly */
+ if (os->region->current >
+ os->region->origin +
+ os->region->length)
+ {
+ einfo("%X%P: Region %s is full (%B section %s)\n",
+ os->region->name,
+ os->bfd_section->owner,
+ os->bfd_section->name);
+ /* Reset the region pointer */
+ os->region->current = 0;
+ }
+
}
}
@@ -1656,7 +1678,7 @@ had_relax |= relax_section(prev);
dot,
&newdot);
- if (newdot != dot)
+ if (newdot != dot && !relax)
/* We've been moved ! so insert a pad */
{
lang_statement_union_type *new =
@@ -2300,17 +2322,17 @@ DEFUN_VOID(lang_process)
/* Size up the sections */
lang_size_sections(statement_list.head,
- (lang_output_section_statement_type *)NULL,
+ abs_output_section,
&(statement_list.head), 0, (bfd_vma)0, false);
- /* Move the global symbols around */
- lang_relocate_globals();
-
/* Now run around and relax if we can */
if (command_line.relax)
{
reset_memory_regions();
+
+ /* Move the global symbols around */
+ lang_relocate_globals();
had_relax = true;
while (had_relax)
@@ -2342,10 +2364,13 @@ DEFUN_VOID(lang_process)
of all the symbols */
lang_do_assignments(statement_list.head,
- (lang_output_section_statement_type *)NULL,
+ abs_output_section,
0, (bfd_vma)0);
+ /* Move the global symbols around */
+ lang_relocate_globals();
+
/* Make sure that we're not mixing architectures */
lang_check();