Applied a patch from Roman Zippel to fix jump table addressing in the M68k
codegen. Taken from the gcc mailing list January 2007: http://gcc.gnu.org/ml/gcc-patches/2007-01/msg02476.html 2007-01-30 Roman Zippel <zippel@linux-m68k.org> * config/m68k/m68k.c (output_move_himode) config/m68k/m68k.md: remove jump table recognition * config/m68k/m68k.c (ASM_OUTPUT_CASE_FETCH): use simple pc relative addressing Approved by Christos Zoulas, Alistair Crooks and Matthew Green.
This commit is contained in:
parent
53e6514de6
commit
1872c0f94c
33
gnu/dist/gcc4/gcc/config/m68k/m68k.c
vendored
33
gnu/dist/gcc4/gcc/config/m68k/m68k.c
vendored
@ -1791,25 +1791,6 @@ output_move_himode (rtx *operands)
|
||||
}
|
||||
else if (CONSTANT_P (operands[1]))
|
||||
return "move%.l %1,%0";
|
||||
/* Recognize the insn before a tablejump, one that refers
|
||||
to a table of offsets. Such an insn will need to refer
|
||||
to a label on the insn. So output one. Use the label-number
|
||||
of the table of offsets to generate this label. This code,
|
||||
and similar code below, assumes that there will be at most one
|
||||
reference to each table. */
|
||||
if (GET_CODE (operands[1]) == MEM
|
||||
&& GET_CODE (XEXP (operands[1], 0)) == PLUS
|
||||
&& GET_CODE (XEXP (XEXP (operands[1], 0), 1)) == LABEL_REF
|
||||
&& GET_CODE (XEXP (XEXP (operands[1], 0), 0)) != PLUS)
|
||||
{
|
||||
rtx labelref = XEXP (XEXP (operands[1], 0), 1);
|
||||
if (MOTOROLA)
|
||||
asm_fprintf (asm_out_file, "\t.set %LLI%d,.+2\n",
|
||||
CODE_LABEL_NUMBER (XEXP (labelref, 0)));
|
||||
else
|
||||
(*targetm.asm_out.internal_label) (asm_out_file, "LI",
|
||||
CODE_LABEL_NUMBER (XEXP (labelref, 0)));
|
||||
}
|
||||
return "move%.w %1,%0";
|
||||
}
|
||||
|
||||
@ -2726,16 +2707,6 @@ print_operand (FILE *file, rtx op, int letter)
|
||||
It is possible for PIC to generate a (plus (label_ref...) (reg...))
|
||||
and we handle that just like we would a (plus (symbol_ref...) (reg...)).
|
||||
|
||||
Some SGS assemblers have a bug such that "Lnnn-LInnn-2.b(pc,d0.l*2)"
|
||||
fails to assemble. Luckily "Lnnn(pc,d0.l*2)" produces the results
|
||||
we want. This difference can be accommodated by using an assembler
|
||||
define such "LDnnn" to be either "Lnnn-LInnn-2.b", "Lnnn", or any other
|
||||
string, as necessary. This is accomplished via the ASM_OUTPUT_CASE_END
|
||||
macro. See m68k/sgs.h for an example; for versions without the bug.
|
||||
Some assemblers refuse all the above solutions. The workaround is to
|
||||
emit "K(pc,d0.l*2)" with K being a small constant known to give the
|
||||
right behavior.
|
||||
|
||||
They also do not like things like "pea 1.w", so we simple leave off
|
||||
the .w on small constants.
|
||||
|
||||
@ -2746,10 +2717,10 @@ print_operand (FILE *file, rtx op, int letter)
|
||||
|
||||
#if MOTOROLA
|
||||
# define ASM_OUTPUT_CASE_FETCH(file, labelno, regname)\
|
||||
asm_fprintf (file, "%LL%d-%LLI%d.b(%Rpc,%s.", labelno, labelno, regname)
|
||||
asm_fprintf (file, "%LL%d(%Rpc,%s.", labelno, regname)
|
||||
#else /* !MOTOROLA */
|
||||
# define ASM_OUTPUT_CASE_FETCH(file, labelno, regname)\
|
||||
asm_fprintf (file, "%Rpc@(%LL%d-%LLI%d-2:b,%s:", labelno, labelno, regname)
|
||||
asm_fprintf (file, "%Rpc@(%LL%d,%s:", labelno, regname)
|
||||
#endif /* !MOTOROLA */
|
||||
|
||||
void
|
||||
|
21
gnu/dist/gcc4/gcc/config/m68k/m68k.md
vendored
21
gnu/dist/gcc4/gcc/config/m68k/m68k.md
vendored
@ -6360,26 +6360,7 @@
|
||||
[(set (match_operand:SI 0 "nonimmediate_operand" "=a")
|
||||
(match_operand:QI 1 "address_operand" "p"))]
|
||||
""
|
||||
{
|
||||
/* Recognize an insn that refers to a table of offsets. Such an insn will
|
||||
need to refer to a label on the insn. So output one. Use the
|
||||
label-number of the table of offsets to generate this label. This code,
|
||||
and similar code above, assumes that there will be at most one reference
|
||||
to each table. */
|
||||
if (GET_CODE (operands[1]) == PLUS
|
||||
&& GET_CODE (XEXP (operands[1], 1)) == LABEL_REF
|
||||
&& GET_CODE (XEXP (operands[1], 0)) != PLUS)
|
||||
{
|
||||
rtx labelref = XEXP (operands[1], 1);
|
||||
if (MOTOROLA)
|
||||
asm_fprintf (asm_out_file, "\\t.set %LLI%d,.+2\\n",
|
||||
CODE_LABEL_NUMBER (XEXP (labelref, 0)));
|
||||
else
|
||||
(*targetm.asm_out.internal_label) (asm_out_file, "LI",
|
||||
CODE_LABEL_NUMBER (XEXP (labelref, 0)));
|
||||
}
|
||||
return "lea %a1,%0";
|
||||
})
|
||||
"lea %a1,%0")
|
||||
|
||||
;; This is the first machine-dependent peephole optimization.
|
||||
;; It is useful when a floating value is returned from a function call
|
||||
|
2
gnu/dist/gcc4/gcc/version.c
vendored
2
gnu/dist/gcc4/gcc/version.c
vendored
@ -8,7 +8,7 @@
|
||||
in parentheses. You may also wish to include a number indicating
|
||||
the revision of your modified compiler. */
|
||||
|
||||
#define VERSUFFIX " (NetBSD nb1 20080202)"
|
||||
#define VERSUFFIX " (NetBSD nb2 20081120)"
|
||||
|
||||
/* This is the location of the online document giving instructions for
|
||||
reporting bugs. If you distribute a modified version of GCC,
|
||||
|
Loading…
x
Reference in New Issue
Block a user