aboutsummaryrefslogtreecommitdiff
path: root/gas/config
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>1998-02-16 20:30:58 +0000
committerNick Clifton <nickc@redhat.com>1998-02-16 20:30:58 +0000
commitb86c0dd361625225dabd8668c163a2b0b1cba881 (patch)
tree19a4a468121b0b09239d4757d7c4d7d9983671f6 /gas/config
parent38c82baf63ae0bf01f0a2fe69eea59fc03a5b1c0 (diff)
downloadgdb-b86c0dd361625225dabd8668c163a2b0b1cba881.zip
gdb-b86c0dd361625225dabd8668c163a2b0b1cba881.tar.gz
gdb-b86c0dd361625225dabd8668c163a2b0b1cba881.tar.bz2
Only parallelise instructions when assembling for the m32rx, and when
neither instruction is relaxable.
Diffstat (limited to 'gas/config')
-rw-r--r--gas/config/tc-m32r.c25
1 files changed, 13 insertions, 12 deletions
diff --git a/gas/config/tc-m32r.c b/gas/config/tc-m32r.c
index 4df5662..786f10d 100644
--- a/gas/config/tc-m32r.c
+++ b/gas/config/tc-m32r.c
@@ -24,6 +24,7 @@
#include "subsegs.h"
#include "cgen-opc.h"
+/* Structure to hold all of the different components describing an individual instruction. */
typedef struct
{
const CGEN_INSN * insn;
@@ -773,11 +774,15 @@ md_assemble (str)
previous instruction to make one, parallel, 32 bit instruction.
If the previous instruction (potentially) changed the flow of
program control, then it cannot be combined with the current
- instruction. Also if the output of the previous instruction
- is used as an input to the current instruction then it cannot
- be combined. Otherwise call can_make_parallel() with both
- orderings of the instructions to see if they can be combined. */
- if (! writes_to_pc (& prev_insn)
+ instruction. If the current instruction is relaxable, then it
+ might be replaced with a longer version, so we cannot combine it.
+ Also if the output of the previous instruction is used as an
+ input to the current instruction then it cannot be combined.
+ Otherwise call can_make_parallel() with both orderings of the
+ instructions to see if they can be combined. */
+ if ( enable_m32rx
+ && CGEN_INSN_ATTR (insn.insn, CGEN_INSN_RELAXABLE) == 0
+ && ! writes_to_pc (& prev_insn)
&& ! first_writes_to_seconds_operands (& prev_insn, &insn, false)
)
{
@@ -819,13 +824,9 @@ md_assemble (str)
/* Swap any relaxable frags recorded for the two insns. */
if (prev_insn.frag->fr_opcode == prev_insn.addr)
- {
- prev_insn.frag->fr_opcode = insn.addr;
- }
+ prev_insn.frag->fr_opcode = insn.addr;
else if (insn.frag->fr_opcode == insn.addr)
- {
- insn.frag->fr_opcode = prev_insn.addr;
- }
+ insn.frag->fr_opcode = prev_insn.addr;
}
/* end-sanitize-phase2-m32rx */
@@ -837,7 +838,7 @@ md_assemble (str)
/* If the insn needs the following one to be on a 32 bit boundary
(e.g. subroutine calls), fill this insn's slot. */
- if (prev_insn.insn
+ if (prev_insn.insn != NULL
&& CGEN_INSN_ATTR (insn.insn, CGEN_INSN_FILL_SLOT) != 0)
fill_insn (0);