aboutsummaryrefslogtreecommitdiff
path: root/ld/relax.c
diff options
context:
space:
mode:
authorSteve Chamberlain <sac@cygnus>1992-11-05 19:35:38 +0000
committerSteve Chamberlain <sac@cygnus>1992-11-05 19:35:38 +0000
commit85c838d6131ea51bfdb76f158bcef7b34f748b32 (patch)
treeec20420625e127aa0ee386c41dd1c64fb25ff97f /ld/relax.c
parentcd98a82fc1a8a15cdcd1ccdbd8540f03d4203f15 (diff)
downloadgdb-85c838d6131ea51bfdb76f158bcef7b34f748b32.zip
gdb-85c838d6131ea51bfdb76f158bcef7b34f748b32.tar.gz
gdb-85c838d6131ea51bfdb76f158bcef7b34f748b32.tar.bz2
* relax.c (build_it): re-enable the processing of data_statements
in scripts, makes counted contructor lists work again.
Diffstat (limited to 'ld/relax.c')
-rw-r--r--ld/relax.c175
1 files changed, 88 insertions, 87 deletions
diff --git a/ld/relax.c b/ld/relax.c
index 5738b5b..ea156e3 100644
--- a/ld/relax.c
+++ b/ld/relax.c
@@ -28,116 +28,117 @@ DEFUN(build_it,(statement),
{
switch (statement->header.type) {
#if 0
- {
-
- bfd_byte play_area[SHORT_SIZE];
- unsigned int i;
- bfd_putshort(output_bfd, statement->fill_statement.fill, play_area);
- /* Write out all entire shorts */
- for (i = 0;
- i < statement->fill_statement.size - SHORT_SIZE + 1;
- i+= SHORT_SIZE)
- {
- bfd_set_section_contents(output_bfd,
- statement->fill_statement.output_section,
- play_area,
- statement->data_statement.output_offset +i,
- SHORT_SIZE);
-
- }
-
- /* Now write any remaining byte */
- if (i < statement->fill_statement.size)
- {
- bfd_set_section_contents(output_bfd,
- statement->fill_statement.output_section,
- play_area,
- statement->data_statement.output_offset +i,
- 1);
-
- }
-
- abort();
- }
+ {
+
+ bfd_byte play_area[SHORT_SIZE];
+ unsigned int i;
+ bfd_putshort(output_bfd, statement->fill_statement.fill, play_area);
+ /* Write out all entire shorts */
+ for (i = 0;
+ i < statement->fill_statement.size - SHORT_SIZE + 1;
+ i+= SHORT_SIZE)
+ {
+ bfd_set_section_contents(output_bfd,
+ statement->fill_statement.output_section,
+ play_area,
+ statement->data_statement.output_offset +i,
+ SHORT_SIZE);
+
+ }
+
+ /* Now write any remaining byte */
+ if (i < statement->fill_statement.size)
+ {
+ bfd_set_section_contents(output_bfd,
+ statement->fill_statement.output_section,
+ play_area,
+ statement->data_statement.output_offset +i,
+ 1);
+
+ }
+
+ abort();
+ }
break;
#endif
- case lang_data_statement_enum:
-#if 0
- {
+ case lang_data_statement_enum:
+
+ {
- bfd_vma value = statement->data_statement.value;
- bfd_byte play_area[LONG_SIZE];
- unsigned int size = 0;
- switch (statement->data_statement.type) {
+ bfd_vma value = statement->data_statement.value;
+ bfd_byte play_area[LONG_SIZE];
+ unsigned int size = 0;
+ asection * output_section = statement->data_statement.output_section;
+ switch (statement->data_statement.type) {
case LONG:
- bfd_put_32(output_bfd, value, play_area);
- size = LONG_SIZE;
- break;
+ bfd_put_32(output_section->owner, value, play_area);
+ size = LONG_SIZE;
+ break;
case SHORT:
- bfd_put_16(output_bfd, value, play_area);
- size = SHORT_SIZE;
- break;
+ bfd_put_16(output_section->owner, value, play_area);
+ size = SHORT_SIZE;
+ break;
case BYTE:
- bfd_put_8(output_bfd, value, play_area);
- size = BYTE_SIZE;
- break;
- }
+ bfd_put_8(output_section->owner, value, play_area);
+ size = BYTE_SIZE;
+ break;
+ }
- bfd_set_section_contents(output_bfd,
- statement->data_statement.output_section,
- play_area,
- statement->data_statement.output_vma,
- size);
+ bfd_set_section_contents(output_section->owner,
+ statement->data_statement.output_section,
+ play_area,
+ statement->data_statement.output_vma,
+ size);
- }
-#endif
+ }
+
break;
- case lang_input_section_enum:
- {
- /* Create a new seclet in the output section with this
- attached */
- if (statement->input_section.ifile->just_syms_flag == false)
- {
- asection *i = statement->input_section.section;
-
- asection *output_section = i->output_section;
+ case lang_input_section_enum:
+ {
+ /* Create a new seclet in the output section with this
+ attached */
+ if (statement->input_section.ifile->just_syms_flag == false)
+ {
+ asection *i = statement->input_section.section;
+
+ asection *output_section = i->output_section;
- bfd_seclet_type *seclet = bfd_new_seclet(output_section->owner,output_section);
+ bfd_seclet_type *seclet = bfd_new_seclet(output_section->owner,output_section);
- seclet->type = bfd_indirect_seclet;
- seclet->u.indirect.section = i;
- seclet->u.indirect.symbols = statement->input_section.ifile->asymbols;
- seclet->size = i->_cooked_size;
- seclet->offset = i->output_offset;
- seclet->next = 0;
- }
+ seclet->type = bfd_indirect_seclet;
+ seclet->u.indirect.section = i;
+ seclet->u.indirect.symbols = statement->input_section.ifile->asymbols;
+ seclet->size = i->_cooked_size;
+ seclet->offset = i->output_offset;
+ seclet->next = 0;
+ }
- }
+ }
break;
- case lang_padding_statement_enum:
+ case lang_padding_statement_enum:
/* Make a new seclet with the right filler */
- {
- /* Create a new seclet in the output section with this
- attached */
+ {
+ /* Create a new seclet in the output section with this
+ attached */
- bfd_seclet_type *seclet =
- bfd_new_seclet(statement->padding_statement.output_section->owner,
- statement->padding_statement.output_section);
+ bfd_seclet_type *seclet =
+ bfd_new_seclet(statement->padding_statement.output_section->owner,
+ statement->padding_statement.output_section);
- seclet->type = bfd_fill_seclet;
- seclet->size = statement->padding_statement.size;
- seclet->offset = statement->padding_statement.output_offset;
- seclet->u.fill.value = statement->padding_statement.fill;
- seclet->next = 0;
- }
+ seclet->type = bfd_fill_seclet;
+ seclet->size = statement->padding_statement.size;
+ seclet->offset = statement->padding_statement.output_offset;
+ seclet->u.fill.value = statement->padding_statement.fill;
+ seclet->next = 0;
+ }
break;
break;
- default:
+ default:
/* All the other ones fall through */
;