From c7b2ac2856cd36fbe61a05a4c43f3135a1825cb0 Mon Sep 17 00:00:00 2001 From: Joern Rennecke Date: Thu, 9 Oct 1997 18:37:16 +0000 Subject: [PATCH] * config/tc-d10v.c (write_2_short): Fix bug that wouldn't allow to pair a branch and link with anything but an exe instruction. Fix for gas/13494. --- gas/ChangeLog | 5 +++++ gas/config/tc-d10v.c | 6 +++--- 2 files changed, 8 insertions(+), 3 deletions(-) diff --git a/gas/ChangeLog b/gas/ChangeLog index fd001c6316e..f7956083a1e 100644 --- a/gas/ChangeLog +++ b/gas/ChangeLog @@ -3,6 +3,11 @@ Thu Oct 9 01:44:36 1997 J"orn Rennecke * tc-d10v.h (TC_START_LABEL): Don't define. (tc_frob_label): Define. +Thu Oct 9 00:07:23 1997 J"orn Rennecke + + * config/tc-d10v.c (write_2_short): Fix bug that wouldn't allow + to pair a branch and link with anything but an exe instruction. + Wed Oct 8 16:28:53 1997 Richard Henderson * config/tc-alpha.c (load_expression): Disable the sym+const .got diff --git a/gas/config/tc-d10v.c b/gas/config/tc-d10v.c index 28519c7edd4..14ef3976acf 100644 --- a/gas/config/tc-d10v.c +++ b/gas/config/tc-d10v.c @@ -673,10 +673,10 @@ write_2_short (opcode1, insn1, opcode2, insn2, exec_type, fx) if ( (opcode1->format & LONG_OPCODE) || (opcode2->format & LONG_OPCODE)) as_fatal ("Long instructions may not be combined."); - if(opcode1->exec_type & BRANCH_LINK && opcode2->exec_type != PARONLY) + if(opcode1->exec_type & BRANCH_LINK && exec_type == 0) { - /* subroutines must be called from 32-bit boundaries */ - /* so the return address will be correct */ + /* Instructions paired with a subroutine call are executed before the + subroutine, so don't do these pairings unless explicitly requested. */ write_1_short (opcode1, insn1, fx->next); return (1); }