1992-03-02 02:55:53 -05:00
|
|
|
/* Definitions for Sequent Intel 386 using GAS.
|
|
|
|
Copyright (C) 1992 Free Software Foundation, Inc.
|
|
|
|
|
|
|
|
/* Mostly it's like a Sequent 386 without GAS. */
|
|
|
|
|
|
|
|
#include "seq386.h"
|
|
|
|
|
|
|
|
/* A C statement or statements which output an assembler instruction
|
|
|
|
opcode to the stdio stream STREAM. The macro-operand PTR is a
|
|
|
|
variable of type `char *' which points to the opcode name in its
|
|
|
|
"internal" form--the form that is written in the machine description.
|
|
|
|
|
|
|
|
GAS version 1.38.1 doesn't understand the `repz' opcode mnemonic.
|
|
|
|
So use `repe' instead. */
|
|
|
|
|
|
|
|
#undef ASM_OUTPUT_OPCODE
|
|
|
|
#define ASM_OUTPUT_OPCODE(STREAM, PTR) \
|
|
|
|
{ \
|
|
|
|
if ((PTR)[0] == 'r' \
|
|
|
|
&& (PTR)[1] == 'e' \
|
1992-05-25 16:10:33 -04:00
|
|
|
&& (PTR)[2] == 'p') \
|
1992-03-02 02:55:53 -05:00
|
|
|
{ \
|
1992-05-25 16:10:33 -04:00
|
|
|
if ((PTR)[3] == 'z') \
|
|
|
|
{ \
|
|
|
|
fprintf (STREAM, "repe"); \
|
|
|
|
(PTR) += 4; \
|
|
|
|
} \
|
|
|
|
else if ((PTR)[3] == 'n' && (PTR)[4] == 'z') \
|
|
|
|
{ \
|
|
|
|
fprintf (STREAM, "repne"); \
|
|
|
|
(PTR) += 5; \
|
|
|
|
} \
|
1992-03-02 02:55:53 -05:00
|
|
|
} \
|
|
|
|
}
|
1992-05-11 15:53:17 -04:00
|
|
|
|
|
|
|
/* Define macro used to output shift-double opcodes when the shift
|
|
|
|
count is in %cl. Some assemblers require %cl as an argument;
|
|
|
|
some don't.
|
|
|
|
|
|
|
|
GAS requires the %cl argument, so override unx386.h. */
|
|
|
|
|
|
|
|
#undef AS3_SHIFT_DOUBLE
|
|
|
|
#define AS3_SHIFT_DOUBLE(a,b,c,d) AS3 (a,b,c,d)
|
|
|
|
|
|
|
|
/* Print opcodes the way that GAS expects them. */
|
|
|
|
#define GAS_MNEMONICS 1
|