aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorNick Clifton <nickc@redhat.com>1998-02-13 22:45:14 +0000
committerNick Clifton <nickc@redhat.com>1998-02-13 22:45:14 +0000
commitc9cec4ef98997ee7cfea4e5c1882caa799e1293d (patch)
tree531ca3a78652b2c47bde2f084b61e14c517dc963
parentbed9a23ccd09d3f2c2b917c187613cdab9eff602 (diff)
downloadbinutils-c9cec4ef98997ee7cfea4e5c1882caa799e1293d.zip
binutils-c9cec4ef98997ee7cfea4e5c1882caa799e1293d.tar.gz
binutils-c9cec4ef98997ee7cfea4e5c1882caa799e1293d.tar.bz2
Do not bother checking the operands of instructions which have no operands!
-rw-r--r--gas/ChangeLog7
-rw-r--r--gas/config/tc-m32r.c49
2 files changed, 39 insertions, 17 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index f547dc8..ddd2e37 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,10 @@
+start-sanitize-m32rx
+Fri Feb 13 14:42:16 1998 Nick Clifton <nickc@cygnus.com>
+
+ * config/tc-m32r.c (first_writes_to_seconds_operands): Do not
+ bother checking insn which have no operands.
+
+end-sanitize-m32rx
Fri Feb 13 16:41:42 1998 Ian Lance Taylor <ian@cygnus.com>
* Makefile.am (AUTOMAKE_OPTIONS): Add cygnus.
diff --git a/gas/config/tc-m32r.c b/gas/config/tc-m32r.c
index 9dd9c5f..4df5662 100644
--- a/gas/config/tc-m32r.c
+++ b/gas/config/tc-m32r.c
@@ -396,22 +396,28 @@ first_writes_to_seconds_operands (a, b, check_outputs)
m32r_insn * b;
const int check_outputs;
{
- const CGEN_OPERAND_INSTANCE * a_operands;
+ const CGEN_OPERAND_INSTANCE * a_operands = CGEN_INSN_OPERANDS (a->insn);
+ const CGEN_OPERAND_INSTANCE * b_operands = CGEN_INSN_OPERANDS (b->insn);
int a_index;
+ /* If at least one of the instructions take sno opeands, then there is
+ nothing to check. There really are instructions without operands,
+ eg 'nop'. */
+ if (a_operands == NULL || b_operands == NULL)
+ return 0;
+
/* Scan the operand list of 'a' looking for an output operand. */
- for (a_index = 0, a_operands = CGEN_INSN_OPERANDS (a->insn);
+ for (a_index = 0;
CGEN_OPERAND_INSTANCE_TYPE (a_operands) != CGEN_OPERAND_INSTANCE_END;
a_index ++, a_operands ++)
{
if (CGEN_OPERAND_INSTANCE_TYPE (a_operands) == CGEN_OPERAND_INSTANCE_OUTPUT)
{
- const CGEN_OPERAND_INSTANCE * b_operands;
- int b_index;
+ int b_index;
/* Scan operand list of 'b' looking for an operand that references
the same hardware element, and which goes in the right direction. */
- for (b_index = 0, b_operands = CGEN_INSN_OPERANDS (b->insn);
+ for (b_index = 0;
CGEN_OPERAND_INSTANCE_TYPE (b_operands) != CGEN_OPERAND_INSTANCE_END;
b_index ++, b_operands ++)
{
@@ -433,15 +439,18 @@ writes_to_pc (a)
m32r_insn * a;
{
#if 0
- const CGEN_OPERAND_INSTANCE * a_operands;
+ const CGEN_OPERAND_INSTANCE * a_operands == CGEN_INSN_OPERANDS (a->insn);
- for (a_operands = CGEN_INSN_OPERANDS (a->insn);
- CGEN_OPERAND_INSTANCE_TYPE (a_operands) != CGEN_OPERAND_INSTANCE_END;
- a_operands ++)
+ if (a_operands == NULL)
+ return 0;
+
+ while (CGEN_OPERAND_INSTANCE_TYPE (a_operands) != CGEN_OPERAND_INSTANCE_END)
{
if (CGEN_OPERAND_INSTANCE_OPERAND (a_operands) != NULL
&& CGEN_OPERAND_INDEX (CGEN_OPERAND_INSTANCE_OPERAND (a_operands)) == M32R_OPERAND_PC)
return 1;
+
+ a_operands ++;
}
#else
if (CGEN_INSN_ATTR (a->insn, CGEN_INSN_UNCOND_CTI)
@@ -571,8 +580,12 @@ assemble_parallel_insn (str, str2)
/* Get the indicies of the operands of the instruction. */
/* FIXME: CGEN_FIELDS is already recorded, but relying on that fact
doesn't seem right. Perhaps allow passing fields like we do insn. */
- if (m32r_cgen_get_insn_operands (first.insn, bfd_getb16 ((char *) first.buffer), 16,
- first.indices) == NULL)
+ /* FIXME: ALIAS insns do not have operands, so we use this function
+ to find the equivalent insn and overwrite the value stored in our
+ structure. When aliases behave differently this may have to change. */
+ first.insn = m32r_cgen_get_insn_operands (first.insn, bfd_getb16 ((char *) first.buffer), 16,
+ first.indices);
+ if (first.insn == NULL)
as_fatal ("internal error: m32r_cgen_get_insn_operands failed for first insn");
/* Parse the second instruction. */
@@ -602,8 +615,9 @@ assemble_parallel_insn (str, str2)
}
/* Get the indicies of the operands of the instruction. */
- if (m32r_cgen_get_insn_operands (second.insn, bfd_getb16 ((char *) second.buffer), 16,
- second.indices) == NULL)
+ second.insn = m32r_cgen_get_insn_operands (second.insn, bfd_getb16 ((char *) second.buffer), 16,
+ second.indices);
+ if (second.insn == NULL)
as_fatal ("internal error: m32r_cgen_get_insn_operands failed for second insn");
/* We assume that if the first instruction writes to a register that is
@@ -741,10 +755,11 @@ md_assemble (str)
abort();
/* Get the indicies of the operands of the instruction. */
- /* FIXME: CGEN_FIELDS is already recorded, but relying on that fact
- doesn't seem right. Perhaps allow passing fields like we do insn. */
- if (m32r_cgen_get_insn_operands (insn.insn, bfd_getb16 ((char *) insn.buffer), 16,
- insn.indices) == NULL)
+ insn.insn = m32r_cgen_get_insn_operands (insn.insn,
+ bfd_getb16 ((char *) insn.buffer),
+ 16,
+ insn.indices);
+ if (insn.insn == NULL)
as_fatal ("internal error: m32r_cgen_get_insn_operands failed");
/* Keep track of whether we've seen a pair of 16 bit insns.