aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gas/ChangeLog8
-rw-r--r--gas/config/tc-m32r.c75
2 files changed, 70 insertions, 13 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 3e544c2..af8ad92 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,3 +1,11 @@
+Mon Dec 15 15:20:32 1997 Nick Clifton <nickc@cygnus.com>
+
+ * config/tc-m32r.c (allow_m32rx): New function.
+ (enable_m32rx): New variable.
+ (md_pseudo_table): Added .m32r and .m32rx pseudo ops
+ (md_show_usage): Document new --m32rx command line option.
+ (md_parse_option): Implement new --m32rx command line option.
+
Mon Dec 15 10:32:28 1997 Jeffrey A Law (law@cygnus.com)
* config/tc-mips.c (mips_ip): Correctly insert 'P' operands into
diff --git a/gas/config/tc-m32r.c b/gas/config/tc-m32r.c
index 43bf7f7..fb85151 100644
--- a/gas/config/tc-m32r.c
+++ b/gas/config/tc-m32r.c
@@ -1,4 +1,4 @@
-/* tc-m32r.c -- Assembler for the Mitsubishi M32R.
+/* tc-m32r.c -- Assembler for the Mitsubishi M32R/X.
Copyright (C) 1996, 1997 Free Software Foundation.
This file is part of GAS, the GNU Assembler.
@@ -42,6 +42,11 @@ static int m32r_relax;
This allows runtime additions to the assembler. */
static char *m32r_cpu_desc;
+/* Non-zero if -m32rx has been specified, in which case support for the
+ extended M32RX instruction set should be enabled. */
+/* Indicates the target BFD machine number. */
+static int enable_m32rx = 0;
+
/* stuff for .scomm symbols. */
static segT sbss_section;
static asection scom_section;
@@ -79,16 +84,31 @@ struct m32r_hi_fixup
static struct m32r_hi_fixup *m32r_hi_fixup_list;
static void m32r_record_hi16 PARAMS ((int, fixS *, segT seg));
+
+
+static void
+allow_m32rx (int on)
+{
+ enable_m32rx = on;
+
+ if (stdoutput != NULL)
+ bfd_set_arch_mach (stdoutput, TARGET_ARCH, enable_m32rx ? bfd_mach_m32rx : bfd_mach_m32r);
+}
const char *md_shortopts = "";
-struct option md_longopts[] = {
+struct option md_longopts[] =
+{
+#define OPTION_M32RX (OPTION_MD_BASE)
+ {"m32rx", no_argument, NULL, OPTION_M32RX},
+
#if 0 /* not supported yet */
-#define OPTION_RELAX (OPTION_MD_BASE)
+#define OPTION_RELAX (OPTION_MD_BASE + 1)
{"relax", no_argument, NULL, OPTION_RELAX},
-#define OPTION_CPU_DESC (OPTION_MD_BASE + 1)
+#define OPTION_CPU_DESC (OPTION_MD_BASE + 2)
{"cpu-desc", required_argument, NULL, OPTION_CPU_DESC},
#endif
+
{NULL, no_argument, NULL, 0}
};
size_t md_longopts_size = sizeof(md_longopts);
@@ -100,6 +120,10 @@ md_parse_option (c, arg)
{
switch (c)
{
+ case OPTION_M32RX:
+ allow_m32rx (1);
+ break;
+
#if 0 /* not supported yet */
case OPTION_RELAX:
m32r_relax = 1;
@@ -118,14 +142,15 @@ void
md_show_usage (stream)
FILE *stream;
{
- fprintf (stream, "M32R options:\n");
+ fprintf (stream, "M32R/X options:\n");
+ fprintf (stream, "\
+--m32rx support the extended m32rx instruction set\n");
+
#if 0
fprintf (stream, "\
--relax create linker relaxable code\n");
fprintf (stream, "\
--cpu-desc provide runtime cpu description file\n");
-#else
- fprintf (stream, "[none]\n");
#endif
}
@@ -142,6 +167,8 @@ const pseudo_typeS md_pseudo_table[] =
{ "word", cons, 4 },
{ "fillinsn", fill_insn, 0 },
{ "scomm", m32r_scomm, 0 },
+ { "m32r", allow_m32rx, 0},
+ { "m32rx", allow_m32rx, 1},
{ NULL, NULL, 0 }
};
@@ -254,7 +281,7 @@ md_begin ()
/* Initialize the `cgen' interface. */
/* This is a callback from cgen to gas to parse operands. */
- cgen_asm_parse_operand_fn = cgen_asm_parse_operand;
+ cgen_parse_operand_fn = cgen_parse_operand;
/* Set the machine number and endian. */
CGEN_SYM (init_asm) (0 /* mach number */,
target_big_endian ? CGEN_ENDIAN_BIG : CGEN_ENDIAN_LITTLE);
@@ -297,6 +324,8 @@ md_begin ()
scom_symbol = *bfd_com_section.symbol;
scom_symbol.name = ".scommon";
scom_symbol.section = &scom_section;
+
+ allow_m32rx (enable_m32rx);
}
void
@@ -634,7 +663,27 @@ md_estimate_size_before_relax (fragP, segment)
/* Mark this fragment as finished. */
frag_wane (fragP);
#else
- return 2;
+ {
+ const struct cgen_insn *insn;
+ int i;
+
+ /* Update the recorded insn.
+ Fortunately we don't have to look very far.
+ FIXME: Change this to record in the instruction the next higher
+ relaxable insn to use. */
+ for (i = 0, insn = fragP->fr_cgen.insn; i < 4; i++, insn++)
+ {
+ if ((strcmp (CGEN_INSN_SYNTAX (insn)->mnemonic,
+ CGEN_INSN_SYNTAX (fragP->fr_cgen.insn)->mnemonic)
+ == 0)
+ && CGEN_INSN_ATTR (insn, CGEN_INSN_RELAX))
+ break;
+ }
+ if (i == 4)
+ abort ();
+ fragP->fr_cgen.insn = insn;
+ return 2;
+ }
#endif
}
@@ -705,19 +754,19 @@ md_convert_frag (abfd, sec, fragP)
if (S_GET_SEGMENT (fragP->fr_symbol) != sec)
{
assert (fragP->fr_subtype != 1);
- assert (fragP->fr_targ.cgen.insn != 0);
+ assert (fragP->fr_cgen.insn != 0);
cgen_record_fixup (fragP,
/* Offset of branch insn in frag. */
fragP->fr_fix + extension - 4,
- fragP->fr_targ.cgen.insn,
+ fragP->fr_cgen.insn,
4 /*length*/,
/* FIXME: quick hack */
#if 0
- CGEN_OPERAND_ENTRY (fragP->fr_targ.cgen.opindex),
+ CGEN_OPERAND_ENTRY (fragP->fr_cgen.opindex),
#else
CGEN_OPERAND_ENTRY (M32R_OPERAND_DISP24),
#endif
- fragP->fr_targ.cgen.opinfo,
+ fragP->fr_cgen.opinfo,
fragP->fr_symbol, fragP->fr_offset);
}