2017-01-02 04:36:43 +01:00
|
|
|
@c Copyright (C) 2000-2017 Free Software Foundation, Inc.
|
2000-08-01 03:57:46 +02:00
|
|
|
@c This is part of the GAS manual.
|
|
|
|
@c For copying conditions, see the file as.texinfo.
|
|
|
|
@ifset GENERIC
|
|
|
|
@page
|
|
|
|
@node i860-Dependent
|
|
|
|
@chapter Intel i860 Dependent Features
|
|
|
|
@end ifset
|
|
|
|
@ifclear GENERIC
|
|
|
|
@node Machine Dependencies
|
|
|
|
@chapter Intel i860 Dependent Features
|
|
|
|
@end ifclear
|
|
|
|
|
|
|
|
@ignore
|
|
|
|
@c FIXME: This is basically a stub for i860. There is tons more information
|
2003-08-02 05:03:52 +02:00
|
|
|
that I will add later (jle@cygnus.com).
|
2000-08-01 03:57:46 +02:00
|
|
|
@end ignore
|
|
|
|
|
|
|
|
@cindex i860 support
|
|
|
|
@menu
|
2000-08-11 01:23:23 +02:00
|
|
|
* Notes-i860:: i860 Notes
|
2000-08-01 03:57:46 +02:00
|
|
|
* Options-i860:: i860 Command-line Options
|
|
|
|
* Directives-i860:: i860 Machine Directives
|
|
|
|
* Opcodes for i860:: i860 Opcodes
|
2011-01-18 14:37:39 +01:00
|
|
|
* Syntax of i860:: i860 Syntax
|
2000-08-01 03:57:46 +02:00
|
|
|
@end menu
|
|
|
|
|
2000-08-11 01:23:23 +02:00
|
|
|
@node Notes-i860
|
2013-01-10 20:51:55 +01:00
|
|
|
@section i860 Notes
|
2000-08-11 01:23:23 +02:00
|
|
|
This is a fairly complete i860 assembler which is compatible with the
|
|
|
|
UNIX System V/860 Release 4 assembler. However, it does not currently
|
|
|
|
support SVR4 PIC (i.e., @code{@@GOT, @@GOTOFF, @@PLT}).
|
2000-08-01 03:57:46 +02:00
|
|
|
|
2000-08-11 01:23:23 +02:00
|
|
|
Like the SVR4/860 assembler, the output object format is ELF32. Currently,
|
|
|
|
this is the only supported object format. If there is sufficient interest,
|
|
|
|
other formats such as COFF may be implemented.
|
2003-08-02 05:03:52 +02:00
|
|
|
|
|
|
|
Both the Intel and AT&T/SVR4 syntaxes are supported, with the latter
|
|
|
|
being the default. One difference is that AT&T syntax requires the '%'
|
|
|
|
prefix on register names while Intel syntax does not. Another difference
|
|
|
|
is in the specification of relocatable expressions. The Intel syntax
|
|
|
|
is @code{ha%expression} whereas the SVR4 syntax is @code{[expression]@@ha}
|
|
|
|
(and similarly for the "l" and "h" selectors).
|
2000-08-11 01:23:23 +02:00
|
|
|
@node Options-i860
|
2000-08-01 03:57:46 +02:00
|
|
|
@section i860 Command-line Options
|
2013-01-10 20:51:55 +01:00
|
|
|
@subsection SVR4 compatibility options
|
2000-08-01 03:57:46 +02:00
|
|
|
@table @code
|
|
|
|
@item -V
|
|
|
|
Print assembler version.
|
|
|
|
@item -Qy
|
|
|
|
Ignored.
|
|
|
|
@item -Qn
|
|
|
|
Ignored.
|
|
|
|
@end table
|
2013-01-10 20:51:55 +01:00
|
|
|
@subsection Other options
|
2000-08-01 03:57:46 +02:00
|
|
|
@table @code
|
|
|
|
@item -EL
|
|
|
|
Select little endian output (this is the default).
|
|
|
|
@item -EB
|
|
|
|
Select big endian output. Note that the i860 always reads instructions
|
|
|
|
as little endian data, so this option only effects data and not
|
|
|
|
instructions.
|
2000-08-11 01:23:23 +02:00
|
|
|
@item -mwarn-expand
|
|
|
|
Emit a warning message if any pseudo-instruction expansions occurred.
|
|
|
|
For example, a @code{or} instruction with an immediate larger than 16-bits
|
|
|
|
will be expanded into two instructions. This is a very undesirable feature to
|
|
|
|
rely on, so this flag can help detect any code where it happens. One
|
|
|
|
use of it, for instance, has been to find and eliminate any place
|
|
|
|
where @code{gcc} may emit these pseudo-instructions.
|
2003-05-24 06:22:23 +02:00
|
|
|
@item -mxp
|
|
|
|
Enable support for the i860XP instructions and control registers. By default,
|
|
|
|
this option is disabled so that only the base instruction set (i.e., i860XR)
|
|
|
|
is supported.
|
2003-08-02 05:03:52 +02:00
|
|
|
@item -mintel-syntax
|
|
|
|
The i860 assembler defaults to AT&T/SVR4 syntax. This option enables the
|
|
|
|
Intel syntax.
|
2000-08-01 03:57:46 +02:00
|
|
|
@end table
|
|
|
|
|
|
|
|
@node Directives-i860
|
|
|
|
@section i860 Machine Directives
|
|
|
|
|
|
|
|
@cindex machine directives, i860
|
|
|
|
@cindex i860 machine directives
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@cindex @code{dual} directive, i860
|
|
|
|
@item .dual
|
|
|
|
Enter dual instruction mode. While this directive is supported, the
|
|
|
|
preferred way to use dual instruction mode is to explicitly code
|
|
|
|
the dual bit with the @code{d.} prefix.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@cindex @code{enddual} directive, i860
|
|
|
|
@item .enddual
|
|
|
|
Exit dual instruction mode. While this directive is supported, the
|
|
|
|
preferred way to use dual instruction mode is to explicitly code
|
|
|
|
the dual bit with the @code{d.} prefix.
|
|
|
|
@end table
|
|
|
|
|
|
|
|
@table @code
|
|
|
|
@cindex @code{atmp} directive, i860
|
|
|
|
@item .atmp
|
|
|
|
Change the temporary register used when expanding pseudo operations. The
|
|
|
|
default register is @code{r31}.
|
|
|
|
@end table
|
|
|
|
|
2003-08-06 01:24:06 +02:00
|
|
|
The @code{.dual}, @code{.enddual}, and @code{.atmp} directives are available only in the Intel syntax mode.
|
|
|
|
|
2003-08-07 06:05:42 +02:00
|
|
|
Both syntaxes allow for the standard @code{.align} directive. However,
|
|
|
|
the Intel syntax additionally allows keywords for the alignment
|
|
|
|
parameter: "@code{.align type}", where `type' is one of @code{.short}, @code{.long},
|
|
|
|
@code{.quad}, @code{.single}, @code{.double} representing alignments of 2, 4,
|
|
|
|
16, 4, and 8, respectively.
|
|
|
|
|
2000-08-01 03:57:46 +02:00
|
|
|
@node Opcodes for i860
|
|
|
|
@section i860 Opcodes
|
|
|
|
|
|
|
|
@cindex opcodes, i860
|
|
|
|
@cindex i860 opcodes
|
2003-05-24 06:22:23 +02:00
|
|
|
All of the Intel i860XR and i860XP machine instructions are supported. Please see
|
2000-08-11 01:23:23 +02:00
|
|
|
either @emph{i860 Microprocessor Programmer's Reference Manual} or @emph{i860 Microprocessor Architecture} for more information.
|
|
|
|
@subsection Other instruction support (pseudo-instructions)
|
|
|
|
For compatibility with some other i860 assemblers, a number of
|
|
|
|
pseudo-instructions are supported. While these are supported, they are
|
|
|
|
a very undesirable feature that should be avoided -- in particular, when
|
|
|
|
they result in an expansion to multiple actual i860 instructions. Below
|
|
|
|
are the pseudo-instructions that result in expansions.
|
|
|
|
@itemize @bullet
|
2000-08-12 18:05:46 +02:00
|
|
|
@item Load large immediate into general register:
|
2000-08-11 01:23:23 +02:00
|
|
|
|
|
|
|
The pseudo-instruction @code{mov imm,%rn} (where the immediate does
|
|
|
|
not fit within a signed 16-bit field) will be expanded into:
|
|
|
|
@smallexample
|
|
|
|
orh large_imm@@h,%r0,%rn
|
|
|
|
or large_imm@@l,%rn,%rn
|
|
|
|
@end smallexample
|
2000-08-12 18:05:46 +02:00
|
|
|
@item Load/store with relocatable address expression:
|
2000-08-11 01:23:23 +02:00
|
|
|
|
2013-01-10 20:51:55 +01:00
|
|
|
For example, the pseudo-instruction @code{ld.b addr_exp(%rx),%rn}
|
2000-08-11 01:23:23 +02:00
|
|
|
will be expanded into:
|
|
|
|
@smallexample
|
2003-08-26 04:40:43 +02:00
|
|
|
orh addr_exp@@ha,%rx,%r31
|
2000-08-11 01:23:23 +02:00
|
|
|
ld.l addr_exp@@l(%r31),%rn
|
|
|
|
@end smallexample
|
|
|
|
|
|
|
|
The analogous expansions apply to @code{ld.x, st.x, fld.x, pfld.x, fst.x}, and @code{pst.x} as well.
|
2000-08-12 18:05:46 +02:00
|
|
|
@item Signed large immediate with add/subtract:
|
|
|
|
|
2000-08-11 01:23:23 +02:00
|
|
|
If any of the arithmetic operations @code{adds, addu, subs, subu} are used
|
|
|
|
with an immediate larger than 16-bits (signed), then they will be expanded.
|
|
|
|
For instance, the pseudo-instruction @code{adds large_imm,%rx,%rn} expands to:
|
2013-01-10 20:51:55 +01:00
|
|
|
@smallexample
|
2000-08-11 01:23:23 +02:00
|
|
|
orh large_imm@@h,%r0,%r31
|
|
|
|
or large_imm@@l,%r31,%r31
|
|
|
|
adds %r31,%rx,%rn
|
|
|
|
@end smallexample
|
2000-08-12 18:05:46 +02:00
|
|
|
@item Unsigned large immediate with logical operations:
|
|
|
|
|
2000-08-11 01:23:23 +02:00
|
|
|
Logical operations (@code{or, andnot, or, xor}) also result in expansions.
|
|
|
|
The pseudo-instruction @code{or large_imm,%rx,%rn} results in:
|
|
|
|
@smallexample
|
|
|
|
orh large_imm@@h,%rx,%r31
|
|
|
|
or large_imm@@l,%r31,%rn
|
|
|
|
@end smallexample
|
2000-08-01 03:57:46 +02:00
|
|
|
|
2000-08-11 01:23:23 +02:00
|
|
|
Similarly for the others, except for @code{and} which expands to:
|
|
|
|
@smallexample
|
|
|
|
andnot (-1 - large_imm)@@h,%rx,%r31
|
|
|
|
andnot (-1 - large_imm)@@l,%r31,%rn
|
|
|
|
@end smallexample
|
|
|
|
@end itemize
|
2000-08-01 03:57:46 +02:00
|
|
|
|
2011-01-18 14:37:39 +01:00
|
|
|
@node Syntax of i860
|
|
|
|
@section i860 Syntax
|
|
|
|
@menu
|
|
|
|
* i860-Chars:: Special Characters
|
|
|
|
@end menu
|
|
|
|
|
|
|
|
@node i860-Chars
|
|
|
|
@subsection Special Characters
|
|
|
|
|
|
|
|
@cindex line comment character, i860
|
|
|
|
@cindex i860 line comment character
|
|
|
|
The presence of a @samp{#} appearing anywhere on a line indicates the
|
|
|
|
start of a comment that extends to the end of that line.
|
|
|
|
|
|
|
|
If a @samp{#} appears as the first character of a line then the whole
|
|
|
|
line is treated as a comment, but in this case the line can also be a
|
|
|
|
logical line number directive (@pxref{Comments}) or a preprocessor
|
|
|
|
control command (@pxref{Preprocessing}).
|
|
|
|
|
|
|
|
@cindex line separator, i860
|
|
|
|
@cindex statement separator, i860
|
|
|
|
@cindex i860 line separator
|
|
|
|
The @samp{;} character can be used to separate statements on the same
|
|
|
|
line.
|