From: Jim Wilson Date: Mon, 15 Jan 2001 23:30:38 +0000 (+0000) Subject: Fix assembler segfault on gcc/crtstuff.c file. X-Git-Tag: gprof-pre-ansify-2004-05-26~7174 X-Git-Url: http://git.osdn.net/view?a=commitdiff_plain;h=b3b03a1e4e793015f32a60b9bc3d8819c833bab7;p=pf3gnuchains%2Fpf3gnuchains4x.git Fix assembler segfault on gcc/crtstuff.c file. * config/tc-ia64.c (ia64_flush_insns): Handle unwind directives not immediately followed by an instruction. --- diff --git a/gas/ChangeLog b/gas/ChangeLog index 08310c3d06..4703f253a8 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -1,3 +1,8 @@ +2001-01-15 Jim Wilson + + * config/tc-ia64.c (ia64_flush_insns): Handle unwind directives + not immediately followed by an instruction. + 2001-01-15 Kazu Hirata * config/tc-m68hc11.c: Fix formatting. diff --git a/gas/config/tc-ia64.c b/gas/config/tc-ia64.c index b0ff7ed4fc..4f761e2e83 100644 --- a/gas/config/tc-ia64.c +++ b/gas/config/tc-ia64.c @@ -909,6 +909,7 @@ ia64_flush_insns () struct label_fix *lfix; segT saved_seg; subsegT saved_subseg; + unw_rec_list *ptr; if (!md.last_text_seg) return; @@ -936,6 +937,22 @@ ia64_flush_insns () } CURR_SLOT.tag_fixups = 0; + /* In case there are unwind directives following the last instruction, + resolve those now. We only handle body and prologue directives here. + Give an error for others. */ + for (ptr = unwind.current_entry; ptr; ptr = ptr->next) + { + if (ptr->r.type == prologue || ptr->r.type == prologue_gr + || ptr->r.type == body) + { + ptr->slot_number = (unsigned long) frag_more (0); + ptr->slot_frag = frag_now; + } + else + as_bad (_("Unwind directive not followed by an instruction.")); + } + unwind.current_entry = NULL; + subseg_set (saved_seg, saved_subseg); if (md.qp.X_op == O_register)