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: newlib-1_9_0~80 X-Git-Url: http://git.ipfire.org/cgi-bin/gitweb.cgi?a=commitdiff_plain;h=b44b1b85f3bf4d213f9735a542bf0ba107b9a00b;p=thirdparty%2Fbinutils-gdb.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 08310c3d06d..4703f253a8a 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 b0ff7ed4fc4..4f761e2e836 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)