* Makefile.am (libopcodes_la_DEPENDENCIES)
[binutils.git] / gas / doc / c-m68k.texi
blobcafad4d59e6f4ccce0b1c68206cd73441ca5d417
1 @c Copyright 1991, 1992, 1993, 1994, 1995, 1996, 1997, 2000, 2003
2 @c Free Software Foundation, Inc.
3 @c This is part of the GAS manual.
4 @c For copying conditions, see the file as.texinfo.
5 @ifset GENERIC
6 @page
7 @node M68K-Dependent
8 @chapter M680x0 Dependent Features
9 @end ifset
10 @ifclear GENERIC
11 @node Machine Dependencies
12 @chapter M680x0 Dependent Features
13 @end ifclear
15 @cindex M680x0 support
16 @menu
17 * M68K-Opts::                   M680x0 Options
18 * M68K-Syntax::                 Syntax
19 * M68K-Moto-Syntax::            Motorola Syntax
20 * M68K-Float::                  Floating Point
21 * M68K-Directives::             680x0 Machine Directives
22 * M68K-opcodes::                Opcodes
23 @end menu
25 @node M68K-Opts
26 @section M680x0 Options
28 @cindex options, M680x0
29 @cindex M680x0 options
30 The Motorola 680x0 version of @code{@value{AS}} has a few machine
31 dependent options:
33 @table @samp
35 @cindex @samp{-l} option, M680x0
36 @item -l
37 You can use the @samp{-l} option to shorten the size of references to undefined
38 symbols.  If you do not use the @samp{-l} option, references to undefined
39 symbols are wide enough for a full @code{long} (32 bits).  (Since
40 @code{@value{AS}} cannot know where these symbols end up, @code{@value{AS}} can
41 only allocate space for the linker to fill in later.  Since @code{@value{AS}}
42 does not know how far away these symbols are, it allocates as much space as it
43 can.)  If you use this option, the references are only one word wide (16 bits).
44 This may be useful if you want the object file to be as small as possible, and
45 you know that the relevant symbols are always less than 17 bits away.
47 @cindex @samp{--register-prefix-optional} option, M680x0
48 @item --register-prefix-optional
49 For some configurations, especially those where the compiler normally
50 does not prepend an underscore to the names of user variables, the
51 assembler requires a @samp{%} before any use of a register name.  This
52 is intended to let the assembler distinguish between C variables and
53 functions named @samp{a0} through @samp{a7}, and so on.  The @samp{%} is
54 always accepted, but is not required for certain configurations, notably
55 @samp{sun3}.  The @samp{--register-prefix-optional} option may be used
56 to permit omitting the @samp{%} even for configurations for which it is
57 normally required.  If this is done, it will generally be impossible to
58 refer to C variables and functions with the same names as register
59 names.
61 @cindex @samp{--bitwise-or} option, M680x0
62 @item --bitwise-or
63 Normally the character @samp{|} is treated as a comment character, which
64 means that it can not be used in expressions.  The @samp{--bitwise-or}
65 option turns @samp{|} into a normal character.  In this mode, you must
66 either use C style comments, or start comments with a @samp{#} character
67 at the beginning of a line.
69 @cindex @samp{--base-size-default-16}
70 @cindex @samp{--base-size-default-32}
71 @item --base-size-default-16  --base-size-default-32 
72 If you use an addressing mode with a base register without specifying
73 the size, @code{@value{AS}} will normally use the full 32 bit value.
74 For example, the addressing mode @samp{%a0@@(%d0)} is equivalent to
75 @samp{%a0@@(%d0:l)}.  You may use the @samp{--base-size-default-16}
76 option to tell @code{@value{AS}} to default to using the 16 bit value.
77 In this case, @samp{%a0@@(%d0)} is equivalent to @samp{%a0@@(%d0:w)}.
78 You may use the @samp{--base-size-default-32} option to restore the
79 default behaviour.
81 @cindex @samp{--disp-size-default-16}
82 @cindex @samp{--disp-size-default-32}
83 @item --disp-size-default-16  --disp-size-default-32
84 If you use an addressing mode with a displacement, and the value of the
85 displacement is not known, @code{@value{AS}} will normally assume that
86 the value is 32 bits.  For example, if the symbol @samp{disp} has not
87 been defined, @code{@value{AS}} will assemble the addressing mode
88 @samp{%a0@@(disp,%d0)} as though @samp{disp} is a 32 bit value.  You may
89 use the @samp{--disp-size-default-16} option to tell @code{@value{AS}}
90 to instead assume that the displacement is 16 bits.  In this case,
91 @code{@value{AS}} will assemble @samp{%a0@@(disp,%d0)} as though
92 @samp{disp} is a 16 bit value.  You may use the
93 @samp{--disp-size-default-32} option to restore the default behaviour.
95 @cindex @samp{--pcrel}
96 @item --pcrel
97 Always keep branches PC-relative.  In the M680x0 architecture all branches
98 are defined as PC-relative.  However, on some processors they are limited
99 to word displacements maximum.  When @code{@value{AS}} needs a long branch
100 that is not available, it normally emits an absolute jump instead.  This
101 option disables this substitution.  When this option is given and no long
102 branches are available, only word branches will be emitted.  An error
103 message will be generated if a word branch cannot reach its target.  This
104 option has no effect on 68020 and other processors that have long branches.
105 @pxref{M68K-Branch,,Branch Improvement}.
107 @cindex @samp{-m68000} and related options
108 @cindex architecture options, M680x0
109 @cindex M680x0 architecture options
110 @item -m68000
111 @code{@value{AS}} can assemble code for several different members of the
112 Motorola 680x0 family.  The default depends upon how @code{@value{AS}}
113 was configured when it was built; normally, the default is to assemble
114 code for the 68020 microprocessor.  The following options may be used to
115 change the default.  These options control which instructions and
116 addressing modes are permitted.  The members of the 680x0 family are
117 very similar.  For detailed information about the differences, see the
118 Motorola manuals.
120 @table @samp
121 @item -m68000
122 @itemx -m68ec000
123 @itemx -m68hc000
124 @itemx -m68hc001
125 @itemx -m68008
126 @itemx -m68302
127 @itemx -m68306
128 @itemx -m68307
129 @itemx -m68322
130 @itemx -m68356
131 Assemble for the 68000. @samp{-m68008}, @samp{-m68302}, and so on are synonyms
132 for @samp{-m68000}, since the chips are the same from the point of view
133 of the assembler.
135 @item -m68010
136 Assemble for the 68010.
138 @item -m68020
139 @itemx -m68ec020
140 Assemble for the 68020.  This is normally the default.
142 @item -m68030
143 @itemx -m68ec030
144 Assemble for the 68030.
146 @item -m68040
147 @itemx -m68ec040
148 Assemble for the 68040.
150 @item -m68060
151 @itemx -m68ec060
152 Assemble for the 68060.
154 @item -mcpu32
155 @itemx -m68330
156 @itemx -m68331
157 @itemx -m68332
158 @itemx -m68333
159 @itemx -m68334
160 @itemx -m68336
161 @itemx -m68340
162 @itemx -m68341
163 @itemx -m68349
164 @itemx -m68360
165 Assemble for the CPU32 family of chips.
167 @item -m5200
168 @item -m5202
169 @item -m5204
170 @item -m5206
171 @item -m5206e
172 @item -m528x
173 @item -m5307
174 @item -m5407
175 @item -mcfv4
176 @item -mcfv4e
177 Assemble for the ColdFire family of chips.
179 @item -m68881
180 @itemx -m68882
181 Assemble 68881 floating point instructions.  This is the default for the
182 68020, 68030, and the CPU32.  The 68040 and 68060 always support
183 floating point instructions.
185 @item -mno-68881
186 Do not assemble 68881 floating point instructions.  This is the default
187 for 68000 and the 68010.  The 68040 and 68060 always support floating
188 point instructions, even if this option is used.
190 @item -m68851
191 Assemble 68851 MMU instructions.  This is the default for the 68020,
192 68030, and 68060.  The 68040 accepts a somewhat different set of MMU
193 instructions; @samp{-m68851} and @samp{-m68040} should not be used
194 together.
196 @item -mno-68851
197 Do not assemble 68851 MMU instructions.  This is the default for the
198 68000, 68010, and the CPU32.  The 68040 accepts a somewhat different set
199 of MMU instructions.
200 @end table
201 @end table
203 @node M68K-Syntax
204 @section Syntax
206 @cindex @sc{mit}
207 This syntax for the Motorola 680x0 was developed at @sc{mit}.
209 @cindex M680x0 syntax
210 @cindex syntax, M680x0
211 @cindex M680x0 size modifiers
212 @cindex size modifiers, M680x0
213 The 680x0 version of @code{@value{AS}} uses instructions names and
214 syntax compatible with the Sun assembler.  Intervening periods are
215 ignored; for example, @samp{movl} is equivalent to @samp{mov.l}.
217 In the following table @var{apc} stands for any of the address registers
218 (@samp{%a0} through @samp{%a7}), the program counter (@samp{%pc}), the
219 zero-address relative to the program counter (@samp{%zpc}), a suppressed
220 address register (@samp{%za0} through @samp{%za7}), or it may be omitted
221 entirely.  The use of @var{size} means one of @samp{w} or @samp{l}, and
222 it may be omitted, along with the leading colon, unless a scale is also
223 specified.  The use of @var{scale} means one of @samp{1}, @samp{2},
224 @samp{4}, or @samp{8}, and it may always be omitted along with the
225 leading colon.
227 @cindex M680x0 addressing modes
228 @cindex addressing modes, M680x0
229 The following addressing modes are understood:
230 @table @dfn
231 @item Immediate
232 @samp{#@var{number}}
234 @item Data Register
235 @samp{%d0} through @samp{%d7}
237 @item Address Register
238 @samp{%a0} through @samp{%a7}@*
239 @samp{%a7} is also known as @samp{%sp}, i.e. the Stack Pointer.  @code{%a6}
240 is also known as @samp{%fp}, the Frame Pointer.
242 @item Address Register Indirect
243 @samp{%a0@@} through @samp{%a7@@}
245 @item Address Register Postincrement
246 @samp{%a0@@+} through @samp{%a7@@+}
248 @item Address Register Predecrement
249 @samp{%a0@@-} through @samp{%a7@@-}
251 @item Indirect Plus Offset
252 @samp{@var{apc}@@(@var{number})}
254 @item Index
255 @samp{@var{apc}@@(@var{number},@var{register}:@var{size}:@var{scale})}
257 The @var{number} may be omitted.
259 @item Postindex
260 @samp{@var{apc}@@(@var{number})@@(@var{onumber},@var{register}:@var{size}:@var{scale})}
262 The @var{onumber} or the @var{register}, but not both, may be omitted.
264 @item Preindex
265 @samp{@var{apc}@@(@var{number},@var{register}:@var{size}:@var{scale})@@(@var{onumber})}
267 The @var{number} may be omitted.  Omitting the @var{register} produces
268 the Postindex addressing mode.
270 @item Absolute
271 @samp{@var{symbol}}, or @samp{@var{digits}}, optionally followed by
272 @samp{:b}, @samp{:w}, or @samp{:l}.
273 @end table
275 @node M68K-Moto-Syntax
276 @section Motorola Syntax
278 @cindex Motorola syntax for the 680x0
279 @cindex alternate syntax for the 680x0
281 The standard Motorola syntax for this chip differs from the syntax
282 already discussed (@pxref{M68K-Syntax,,Syntax}).  @code{@value{AS}} can
283 accept Motorola syntax for operands, even if @sc{mit} syntax is used for
284 other operands in the same instruction.  The two kinds of syntax are
285 fully compatible.
287 In the following table @var{apc} stands for any of the address registers
288 (@samp{%a0} through @samp{%a7}), the program counter (@samp{%pc}), the
289 zero-address relative to the program counter (@samp{%zpc}), or a
290 suppressed address register (@samp{%za0} through @samp{%za7}).  The use
291 of @var{size} means one of @samp{w} or @samp{l}, and it may always be
292 omitted along with the leading dot.  The use of @var{scale} means one of
293 @samp{1}, @samp{2}, @samp{4}, or @samp{8}, and it may always be omitted
294 along with the leading asterisk.
296 The following additional addressing modes are understood:
298 @table @dfn
299 @item Address Register Indirect
300 @samp{(%a0)} through @samp{(%a7)}@* 
301 @samp{%a7} is also known as @samp{%sp}, i.e. the Stack Pointer.  @code{%a6}
302 is also known as @samp{%fp}, the Frame Pointer.
304 @item Address Register Postincrement
305 @samp{(%a0)+} through @samp{(%a7)+}
307 @item Address Register Predecrement
308 @samp{-(%a0)} through @samp{-(%a7)}
310 @item Indirect Plus Offset
311 @samp{@var{number}(@var{%a0})} through @samp{@var{number}(@var{%a7})},
312 or @samp{@var{number}(@var{%pc})}.
314 The @var{number} may also appear within the parentheses, as in
315 @samp{(@var{number},@var{%a0})}.  When used with the @var{pc}, the
316 @var{number} may be omitted (with an address register, omitting the
317 @var{number} produces Address Register Indirect mode).
319 @item Index
320 @samp{@var{number}(@var{apc},@var{register}.@var{size}*@var{scale})}
322 The @var{number} may be omitted, or it may appear within the
323 parentheses.  The @var{apc} may be omitted.  The @var{register} and the
324 @var{apc} may appear in either order.  If both @var{apc} and
325 @var{register} are address registers, and the @var{size} and @var{scale}
326 are omitted, then the first register is taken as the base register, and
327 the second as the index register.
329 @item Postindex
330 @samp{([@var{number},@var{apc}],@var{register}.@var{size}*@var{scale},@var{onumber})}
332 The @var{onumber}, or the @var{register}, or both, may be omitted.
333 Either the @var{number} or the @var{apc} may be omitted, but not both.
335 @item Preindex
336 @samp{([@var{number},@var{apc},@var{register}.@var{size}*@var{scale}],@var{onumber})}
338 The @var{number}, or the @var{apc}, or the @var{register}, or any two of
339 them, may be omitted.  The @var{onumber} may be omitted.  The
340 @var{register} and the @var{apc} may appear in either order.  If both
341 @var{apc} and @var{register} are address registers, and the @var{size}
342 and @var{scale} are omitted, then the first register is taken as the
343 base register, and the second as the index register.
344 @end table
346 @node M68K-Float
347 @section Floating Point
349 @cindex floating point, M680x0
350 @cindex M680x0 floating point
351 Packed decimal (P) format floating literals are not supported.
352 Feel free to add the code!
354 The floating point formats generated by directives are these.
356 @table @code
357 @cindex @code{float} directive, M680x0
358 @item .float
359 @code{Single} precision floating point constants.
361 @cindex @code{double} directive, M680x0
362 @item .double
363 @code{Double} precision floating point constants.
365 @cindex @code{extend} directive M680x0
366 @cindex @code{ldouble} directive M680x0
367 @item .extend
368 @itemx .ldouble
369 @code{Extended} precision (@code{long double}) floating point constants.
370 @end table
372 @node M68K-Directives
373 @section 680x0 Machine Directives
375 @cindex M680x0 directives
376 @cindex directives, M680x0
377 In order to be compatible with the Sun assembler the 680x0 assembler
378 understands the following directives.
380 @table @code
381 @cindex @code{data1} directive, M680x0
382 @item .data1
383 This directive is identical to a @code{.data 1} directive.
385 @cindex @code{data2} directive, M680x0
386 @item .data2
387 This directive is identical to a @code{.data 2} directive.
389 @cindex @code{even} directive, M680x0
390 @item .even
391 This directive is a special case of the @code{.align} directive; it
392 aligns the output to an even byte boundary.
394 @cindex @code{skip} directive, M680x0
395 @item .skip
396 This directive is identical to a @code{.space} directive.
397 @end table
399 @need 2000
400 @node M68K-opcodes
401 @section Opcodes
403 @cindex M680x0 opcodes
404 @cindex opcodes, M680x0
405 @cindex instruction set, M680x0
406 @c doc@cygnus.com: I don't see any point in the following
407 @c                   paragraph.  Bugs are bugs; how does saying this
408 @c                   help anyone?
409 @ignore
410 Danger:  Several bugs have been found in the opcode table (and
411 fixed).  More bugs may exist.  Be careful when using obscure
412 instructions.
413 @end ignore
415 @menu
416 * M68K-Branch::                 Branch Improvement
417 * M68K-Chars::                  Special Characters
418 @end menu
420 @node M68K-Branch
421 @subsection Branch Improvement
423 @cindex pseudo-opcodes, M680x0
424 @cindex M680x0 pseudo-opcodes
425 @cindex branch improvement, M680x0
426 @cindex M680x0 branch improvement
427 Certain pseudo opcodes are permitted for branch instructions.
428 They expand to the shortest branch instruction that reach the
429 target.  Generally these mnemonics are made by substituting @samp{j} for
430 @samp{b} at the start of a Motorola mnemonic.
432 The following table summarizes the pseudo-operations.  A @code{*} flags
433 cases that are more fully described after the table:
435 @smallexample
436           Displacement
437           +------------------------------------------------------------
438           |                68020           68000/10, not PC-relative OK
439 Pseudo-Op |BYTE    WORD    LONG            ABSOLUTE LONG JUMP    **
440           +------------------------------------------------------------
441      jbsr |bsrs    bsrw    bsrl            jsr
442       jra |bras    braw    bral            jmp
443 *     jXX |bXXs    bXXw    bXXl            bNXs;jmp
444 *    dbXX | N/A    dbXXw   dbXX;bras;bral  dbXX;bras;jmp
445      fjXX | N/A    fbXXw   fbXXl            N/A
447 XX: condition
448 NX: negative of condition XX
450 @end smallexample
451 @center @code{*}---see full description below
452 @center @code{**}---this expansion mode is disallowed by @samp{--pcrel}
454 @table @code
455 @item jbsr
456 @itemx jra
457 These are the simplest jump pseudo-operations; they always map to one
458 particular machine instruction, depending on the displacement to the
459 branch target.  This instruction will be a byte or word branch is that
460 is sufficient.  Otherwise, a long branch will be emitted if available.
461 If no long branches are available and the @samp{--pcrel} option is not
462 given, an absolute long jump will be emitted instead.  If no long
463 branches are available, the @samp{--pcrel} option is given, and a word
464 branch cannot reach the target, an error message is generated.
466 In addition to standard branch operands, @code{@value{AS}} allows these
467 pseudo-operations to have all operands that are allowed for jsr and jmp,
468 substituting these instructions if the operand given is not valid for a
469 branch instruction.
471 @item j@var{XX}
472 Here, @samp{j@var{XX}} stands for an entire family of pseudo-operations,
473 where @var{XX} is a conditional branch or condition-code test.  The full
474 list of pseudo-ops in this family is:
475 @smallexample
476  jhi   jls   jcc   jcs   jne   jeq   jvc
477  jvs   jpl   jmi   jge   jlt   jgt   jle
478 @end smallexample
480 Usually, each of these pseudo-operations expands to a single branch
481 instruction.  However, if a word branch is not sufficient, no long branches
482 are available, and the @samp{--pcrel} option is not given, @code{@value{AS}}
483 issues a longer code fragment in terms of @var{NX}, the opposite condition
484 to @var{XX}.  For example, under these conditions:
485 @smallexample
486     j@var{XX} foo
487 @end smallexample
488 gives
489 @smallexample
490      b@var{NX}s oof
491      jmp foo
492  oof:
493 @end smallexample
495 @item db@var{XX}
496 The full family of pseudo-operations covered here is
497 @smallexample
498  dbhi   dbls   dbcc   dbcs   dbne   dbeq   dbvc
499  dbvs   dbpl   dbmi   dbge   dblt   dbgt   dble
500  dbf    dbra   dbt
501 @end smallexample
503 Motorola @samp{db@var{XX}} instructions allow word displacements only.  When
504 a word displacement is sufficient, each of these pseudo-operations expands
505 to the corresponding Motorola instruction.  When a word displacement is not
506 sufficient and long branches are available, when the source reads
507 @samp{db@var{XX} foo}, @code{@value{AS}} emits
508 @smallexample
509      db@var{XX} oo1
510      bras oo2
511  oo1:bral foo
512  oo2:
513 @end smallexample
515 If, however, long branches are not available and the @samp{--pcrel} option is
516 not given, @code{@value{AS}} emits
517 @smallexample
518      db@var{XX} oo1
519      bras oo2
520  oo1:jmp foo
521  oo2:
522 @end smallexample
524 @item fj@var{XX}
525 This family includes
526 @smallexample
527  fjne   fjeq   fjge   fjlt   fjgt   fjle   fjf
528  fjt    fjgl   fjgle  fjnge  fjngl  fjngle fjngt
529  fjnle  fjnlt  fjoge  fjogl  fjogt  fjole  fjolt
530  fjor   fjseq  fjsf   fjsne  fjst   fjueq  fjuge
531  fjugt  fjule  fjult  fjun
532 @end smallexample
534 Each of these pseudo-operations always expands to a single Motorola
535 coprocessor branch instruction, word or long.  All Motorola coprocessor
536 branch instructions allow both word and long displacements.
538 @end table
540 @node M68K-Chars
541 @subsection Special Characters
543 @cindex special characters, M680x0
544 @cindex M680x0 immediate character
545 @cindex immediate character, M680x0
546 @cindex M680x0 line comment character
547 @cindex line comment character, M680x0
548 @cindex comments, M680x0
549 The immediate character is @samp{#} for Sun compatibility.  The
550 line-comment character is @samp{|} (unless the @samp{--bitwise-or}
551 option is used).  If a @samp{#} appears at the beginning of a line, it
552 is treated as a comment unless it looks like @samp{# line file}, in
553 which case it is treated normally.