aboutsummaryrefslogtreecommitdiff
path: root/gas/subsegs.c
diff options
context:
space:
mode:
Diffstat (limited to 'gas/subsegs.c')
-rw-r--r--gas/subsegs.c75
1 files changed, 65 insertions, 10 deletions
diff --git a/gas/subsegs.c b/gas/subsegs.c
index 6f5f753..0566d0a 100644
--- a/gas/subsegs.c
+++ b/gas/subsegs.c
@@ -374,9 +374,9 @@ subseg_set (seg, subseg) /* begin assembly for a new sub-segment */
#else /* BFD_ASSEMBLER */
segT
-subseg_new (segname, subseg)
+subseg_get (segname, force_new)
const char *segname;
- subsegT subseg;
+ int force_new;
{
segT secptr;
segment_info_type *seginfo;
@@ -384,13 +384,17 @@ subseg_new (segname, subseg)
? bfd_get_section_name (stdoutput, now_seg)
: 0);
- if (now_seg_name
+ if (!force_new
+ && now_seg_name
&& (now_seg_name == segname
- || !strcmp (now_seg_name, segname))
- && subseg == now_subseg)
+ || !strcmp (now_seg_name, segname)))
return now_seg;
- secptr = bfd_make_section_old_way (stdoutput, segname);
+ if (!force_new)
+ secptr = bfd_make_section_old_way (stdoutput, segname);
+ else
+ secptr = bfd_make_section_anyway (stdoutput, segname);
+
seginfo = seg_info (secptr);
if (! seginfo)
{
@@ -400,16 +404,48 @@ subseg_new (segname, subseg)
seginfo->fix_tail = 0;
seginfo->bfd_section = secptr;
bfd_set_section_userdata (stdoutput, secptr, (char *) seginfo);
- subseg_set_rest (secptr, subseg);
- seginfo->frchainP = frchain_now;
+ seginfo->frchainP = 0;
seginfo->lineno_list_head = seginfo->lineno_list_tail = 0;
seginfo->sym = 0;
seginfo->dot = 0;
seginfo->hadone = 0;
seginfo->user_stuff = 0;
+ seginfo->stabu.stab_string_size = 0;
}
- else
- subseg_set_rest (secptr, subseg);
+ return secptr;
+}
+
+segT
+subseg_new (segname, subseg)
+ const char *segname;
+ subsegT subseg;
+{
+ segT secptr;
+ segment_info_type *seginfo;
+
+ secptr = subseg_get (segname, 0);
+ subseg_set_rest (secptr, subseg);
+ seginfo = seg_info (secptr);
+ if (! seginfo->frchainP)
+ seginfo->frchainP = frchain_now;
+ return secptr;
+}
+
+/* Like subseg_new, except a new section is always created, even if
+ a section with that name already exists. */
+segT
+subseg_force_new (segname, subseg)
+ const char *segname;
+ subsegT subseg;
+{
+ segT secptr;
+ segment_info_type *seginfo;
+
+ secptr = subseg_get (segname, 1);
+ subseg_set_rest (secptr, subseg);
+ seginfo = seg_info (secptr);
+ if (! seginfo->frchainP)
+ seginfo->frchainP = frchain_now;
return secptr;
}
@@ -422,6 +458,25 @@ subseg_set (secptr, subseg)
subseg_set_rest (secptr, subseg);
}
+symbolS *
+section_symbol (sec)
+ segT sec;
+{
+ segment_info_type *seginfo = seg_info (sec);
+
+ if (seginfo == 0)
+ abort ();
+ if (seginfo->sym)
+ return seginfo->sym;
+ seginfo->sym = symbol_find (sec->name);
+ if (!seginfo->sym)
+ {
+ seginfo->sym = symbol_make (sec->name);
+ seginfo->sym->bsym = sec->symbol;
+ }
+ return seginfo->sym;
+}
+
#endif /* BFD_ASSEMBLER */
/* end of subsegs.c */