aboutsummaryrefslogtreecommitdiff
diff options
context:
space:
mode:
-rw-r--r--gas/ChangeLog4
-rw-r--r--gas/config/tc-m68k.c89
2 files changed, 60 insertions, 33 deletions
diff --git a/gas/ChangeLog b/gas/ChangeLog
index 82d344b..4248ae1 100644
--- a/gas/ChangeLog
+++ b/gas/ChangeLog
@@ -1,5 +1,9 @@
Tue Dec 20 14:56:31 1994 Ken Raeburn <raeburn@cujo.cygnus.com>
+ * config/tc-m68k.c (md_apply_fix_2): Use offsetT and addressT
+ instead of long and unsigned long.
+ (md_apply_fix): Cast value before passing it.
+
* config/obj-aout.h, config/obj-coff.c, config/obj-elf.h,
config/obj-som.h, config/tc-h8500.c, config/tc-hppa.c,
config/tc-hppa.h, config/tc-sh.c, config/tc-z8k.c: Don't rely on
diff --git a/gas/config/tc-m68k.c b/gas/config/tc-m68k.c
index 74dc429..2b66aaf 100644
--- a/gas/config/tc-m68k.c
+++ b/gas/config/tc-m68k.c
@@ -74,6 +74,9 @@ const int md_reloc_size = 8; /* Size of relocation record */
references. */
int flag_want_pic;
+static int flag_short_refs; /* -l option */
+static int flag_long_jumps; /* -S option */
+
#ifdef REGISTER_PREFIX_OPTIONAL
int flag_reg_prefix_optional = REGISTER_PREFIX_OPTIONAL;
#else
@@ -1554,7 +1557,7 @@ main ()
printf ("Iadd: '%.*s'", 1 + thark.e_iadd - thark.b_iadd, thark.b_iadd);
printf ("\n");
}
- exit (0);
+ exit (EXIT_SUCCESS);
}
#endif
@@ -1862,7 +1865,7 @@ m68k_ip (instring)
} /* if not address register indirect */
break;
case 'B': /* FOO */
- if (opP->mode != ABSL || (flagseen['S'] && instring[0] == 'j'
+ if (opP->mode != ABSL || (flag_long_jumps && instring[0] == 'j'
&& instring[1] == 'b'
&& instring[2] == 's'
&& instring[3] == 'r'))
@@ -1903,7 +1906,7 @@ m68k_ip (instring)
losing++;
else
{
- enum _register *rp;
+ const enum _register *rp;
for (rp = control_regs; *rp; rp++)
if (*rp == opP->reg)
break;
@@ -2321,7 +2324,7 @@ m68k_ip (instring)
if (!issword (nextword)
|| (isvar (opP->con1)
&& ((opP->con1->e_siz == 0
- && flagseen['l'] == 0)
+ && flag_short_refs == 0)
|| opP->con1->e_siz == 3)))
{
@@ -2563,7 +2566,7 @@ m68k_ip (instring)
&& seg (opP->con1) == text_section
&& now_seg == text_section
&& cpu_of_arch (current_architecture) >= m68020
- && !flagseen['S']
+ && !flag_long_jumps
&& !strchr ("~%&$?", s[0]))
{
tmpreg = 0x3A; /* 7.2 */
@@ -2844,6 +2847,9 @@ m68k_ip (instring)
case DTT1:
tmpreg = 0x007;
break;
+ case BUSCR:
+ tmpreg = 0x008;
+ break;
case USP:
tmpreg = 0x800;
@@ -2869,6 +2875,9 @@ m68k_ip (instring)
case SRP:
tmpreg = 0x807;
break;
+ case PCR:
+ tmpreg = 0x808;
+ break;
default:
as_fatal ("failed sanity check.");
}
@@ -3541,6 +3550,8 @@ static const struct init_entry init_table[] =
{ "tc", TC },
{ "srp", SRP },
{ "urp", URP },
+ { "buscr", BUSCR },
+ { "pcr", PCR },
{ "ac", AC },
{ "bc", BC },
@@ -4048,19 +4059,21 @@ md_number_to_chars (buf, val, n)
static void
md_apply_fix_2 (fixP, val)
fixS *fixP;
- long val;
+ offsetT val;
{
- unsigned long upper_limit;
- long lower_limit;
+ addressT upper_limit;
+ offsetT lower_limit;
-#ifdef IBM_COMPILER_SUX
- /* This is unnecessary but it convinces the native rs6000
- compiler to generate the code we want. */
+ /* This is unnecessary but it convinces the native rs6000 compiler
+ to generate the code we want. */
char *buf = fixP->fx_frag->fr_literal;
buf += fixP->fx_where;
-#else /* IBM_COMPILER_SUX */
- char *buf = fixP->fx_where + fixP->fx_frag->fr_literal;
-#endif /* IBM_COMPILER_SUX */
+ /* end ibm compiler workaround */
+
+ if (val & 0x80000000)
+ val |= ~(addressT)0x7fffffff;
+ else
+ val &= 0x7fffffff;
switch (fixP->fx_size)
{
@@ -4081,7 +4094,7 @@ md_apply_fix_2 (fixP, val)
*buf++ = (val >> 8);
*buf++ = val;
upper_limit = 0x7fffffff;
- lower_limit = -0x80000000;
+ lower_limit = -(offsetT)0x80000000;
break;
default:
BAD_CASE (fixP->fx_size);
@@ -4094,7 +4107,8 @@ md_apply_fix_2 (fixP, val)
if (!fixP->fx_pcrel)
upper_limit = upper_limit * 2 + 1;
- if ((unsigned) val > upper_limit && (val > 0 || val < lower_limit))
+ if ((addressT) val > upper_limit
+ && (val > 0 || val < lower_limit))
as_bad_where (fixP->fx_file, fixP->fx_line, "value out of range");
/* A one byte PC-relative reloc means a short branch. We can't use
@@ -4114,7 +4128,7 @@ md_apply_fix (fixP, valp)
fixS *fixP;
long *valp;
{
- md_apply_fix_2 (fixP, *valp);
+ md_apply_fix_2 (fixP, (addressT) *valp);
return 1;
}
#else
@@ -4122,7 +4136,7 @@ void md_apply_fix (fixP, val)
fixS *fixP;
long val;
{
- md_apply_fix_2 (fixP, val);
+ md_apply_fix_2 (fixP, (addressT) val);
}
#endif
@@ -4140,17 +4154,12 @@ md_convert_frag_1 (fragP)
/* Address in object code of the displacement. */
register int object_address = fragP->fr_fix + fragP->fr_address;
-#ifdef IBM_COMPILER_SUX
- /* This is wrong but it convinces the native rs6000 compiler to
- generate the code we want. */
+ /* Address in gas core of the place to store the displacement. */
+ /* This convinces the native rs6000 compiler to generate the code we
+ want. */
register char *buffer_address = fragP->fr_literal;
buffer_address += fragP->fr_fix;
-#else /* IBM_COMPILER_SUX */
- /* Address in gas core of the place to store the displacement. */
- register char *buffer_address = fragP->fr_fix + fragP->fr_literal;
-#endif /* IBM_COMPILER_SUX */
-
- /* No longer true: know(fragP->fr_symbol); */
+ /* end ibm compiler workaround */
/* The displacement of the address, from current location. */
disp = fragP->fr_symbol ? S_GET_VALUE (fragP->fr_symbol) : 0;
@@ -4397,7 +4406,7 @@ md_estimate_size_before_relax (fragP, segment)
case TAB (FBRANCH, SZ_UNDEF):
{
- if (S_GET_SEGMENT (fragP->fr_symbol) == segment || flagseen['l'])
+ if (S_GET_SEGMENT (fragP->fr_symbol) == segment || flag_short_refs)
{
fragP->fr_subtype = TAB (FBRANCH, SHORT);
fragP->fr_var += 2;
@@ -4412,7 +4421,7 @@ md_estimate_size_before_relax (fragP, segment)
case TAB (PCREL, SZ_UNDEF):
{
- if (S_GET_SEGMENT (fragP->fr_symbol) == segment || flagseen['l'])
+ if (S_GET_SEGMENT (fragP->fr_symbol) == segment || flag_short_refs)
{
fragP->fr_subtype = TAB (PCREL, SHORT);
fragP->fr_var += 2;
@@ -4436,7 +4445,7 @@ md_estimate_size_before_relax (fragP, segment)
/* only Bcc 68000 instructions can come here */
/* change bcc into b!cc/jmp absl long */
fragP->fr_opcode[0] ^= 0x01; /* invert bcc */
- if (flagseen['l'])
+ if (flag_short_refs)
{
fragP->fr_opcode[1] = 0x04; /* branch offset = 6 */
/* JF: these were fr_opcode[2,3] */
@@ -4479,7 +4488,7 @@ md_estimate_size_before_relax (fragP, segment)
buffer_address[1] = 0x04;
buffer_address[2] = 0x60; /* put in bra pc + ... */
- if (flagseen['l'])
+ if (flag_short_refs)
{
/* JF: these were fr_opcode[5-7] */
buffer_address[3] = 0x04; /* plus 4 */
@@ -4510,7 +4519,7 @@ md_estimate_size_before_relax (fragP, segment)
case TAB (PCLEA, SZ_UNDEF):
{
- if ((S_GET_SEGMENT (fragP->fr_symbol)) == segment || flagseen['l'])
+ if ((S_GET_SEGMENT (fragP->fr_symbol)) == segment || flag_short_refs)
{
fragP->fr_subtype = TAB (PCLEA, SHORT);
fragP->fr_var += 2;
@@ -4977,10 +4986,12 @@ md_parse_option (c, arg)
{
case 'l': /* -l means keep external to 2 bit offset
rather than 16 bit one */
+ flag_short_refs = 1;
break;
case 'S': /* -S means that jbsr's always turn into
jsr's. */
+ flag_long_jumps = 1;
break;
case 'A':
@@ -4995,36 +5006,44 @@ md_parse_option (c, arg)
|| !strcmp (arg, "68008")
|| !strcmp (arg, "68302"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68000;
}
else if (!strcmp (arg, "68010"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68010;
}
else if (!strcmp (arg, "68020"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68020 | MAYBE_FLOAT_TOO;
}
else if (!strcmp (arg, "68030"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68030 | MAYBE_FLOAT_TOO;
}
else if (!strcmp (arg, "68040"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68040 | MAYBE_FLOAT_TOO;
}
else if (!strcmp (arg, "68060"))
{
+ current_architecture &=~ m68000up;
current_architecture |= m68060 | MAYBE_FLOAT_TOO;
}
#ifndef NO_68881
else if (!strcmp (arg, "68881"))
{
current_architecture |= m68881;
+ no_68881 = 0;
}
else if (!strcmp (arg, "68882"))
{
current_architecture |= m68882;
+ no_68881 = 0;
}
#endif /* NO_68881 */
/* Even if we aren't configured to support the processor,
@@ -5039,6 +5058,7 @@ md_parse_option (c, arg)
else if (!strcmp (arg, "68851"))
{
current_architecture |= m68851;
+ no_68851 = 0;
}
#endif /* NO_68851 */
else if (!strcmp (arg, "no-68851"))
@@ -5051,6 +5071,7 @@ md_parse_option (c, arg)
|| !strcmp (arg, "68333")
|| !strcmp (arg, "68340"))
{
+ current_architecture &=~ m68000up;
current_architecture |= cpu32;
}
else
@@ -5229,8 +5250,10 @@ md_pcrel_from (fixP)
}
#ifndef BFD_ASSEMBLER
+/*ARGSUSED*/
void
-tc_coff_symbol_emit_hook ()
+tc_coff_symbol_emit_hook (ignore)
+ symbolS *ignore;
{
}