2013-10-14 Richard Sandiford <rdsandiford@googlemail.com>
[platform/upstream/binutils.git] / gas / doc / c-mmix.texi
1 @c Copyright 2001, 2002, 2003, 2006, 2011 Free Software Foundation, Inc.
2 @c This is part of the GAS manual.
3 @c For copying conditions, see the file as.texinfo.
4 @c MMIX description by Hans-Peter Nilsson, hp@bitrange.com
5 @ifset GENERIC
6 @page
7 @node MMIX-Dependent
8 @chapter MMIX Dependent Features
9 @end ifset
10 @ifclear GENERIC
11 @node Machine Dependencies
12 @chapter MMIX Dependent Features
13 @end ifclear
14
15 @cindex MMIX support
16 @menu
17 * MMIX-Opts::              Command-line Options
18 * MMIX-Expand::            Instruction expansion
19 * MMIX-Syntax::            Syntax
20 * MMIX-mmixal::            Differences to @code{mmixal} syntax and semantics
21 @end menu
22
23 @node MMIX-Opts
24 @section Command-line Options
25
26 @cindex options, MMIX
27 @cindex MMIX options
28 The MMIX version of @code{@value{AS}} has some machine-dependent options.
29
30 @cindex @samp{--fixed-special-register-names} command line option, MMIX
31 When @samp{--fixed-special-register-names} is specified, only the register
32 names specified in @ref{MMIX-Regs} are recognized in the instructions
33 @code{PUT} and @code{GET}.
34
35 @cindex @samp{--globalize-symbols} command line option, MMIX
36 You can use the @samp{--globalize-symbols} to make all symbols global.
37 This option is useful when splitting up a @code{mmixal} program into
38 several files.
39
40 @cindex @samp{--gnu-syntax} command line option, MMIX
41 The @samp{--gnu-syntax} turns off most syntax compatibility with
42 @code{mmixal}.  Its usability is currently doubtful.
43
44 @cindex @samp{--relax} command line option, MMIX
45 The @samp{--relax} option is not fully supported, but will eventually make
46 the object file prepared for linker relaxation.
47
48 @cindex @samp{--no-predefined-syms} command line option, MMIX
49 If you want to avoid inadvertently calling a predefined symbol and would
50 rather get an error, for example when using @code{@value{AS}} with a
51 compiler or other machine-generated code, specify
52 @samp{--no-predefined-syms}.  This turns off built-in predefined
53 definitions of all such symbols, including rounding-mode symbols, segment
54 symbols, @samp{BIT} symbols, and @code{TRAP} symbols used in @code{mmix}
55 ``system calls''.  It also turns off predefined special-register names,
56 except when used in @code{PUT} and @code{GET} instructions.
57
58 @cindex @samp{--no-expand} command line option, MMIX
59 By default, some instructions are expanded to fit the size of the operand
60 or an external symbol (@pxref{MMIX-Expand}).  By passing
61 @samp{--no-expand}, no such expansion will be done, instead causing errors
62 at link time if the operand does not fit.
63
64 @cindex @samp{--no-merge-gregs} command line option, MMIX
65 The @code{mmixal} documentation (@pxref{mmixsite}) specifies that global
66 registers allocated with the @samp{GREG} directive (@pxref{MMIX-greg}) and
67 initialized to the same non-zero value, will refer to the same global
68 register.  This isn't strictly enforceable in @code{@value{AS}} since the
69 final addresses aren't known until link-time, but it will do an effort
70 unless the @samp{--no-merge-gregs} option is specified.  (Register merging
71 isn't yet implemented in @code{@value{LD}}.)
72
73 @cindex @samp{-x} command line option, MMIX
74 @code{@value{AS}} will warn every time it expands an instruction to fit an
75 operand unless the option @samp{-x} is specified.  It is believed that
76 this behaviour is more useful than just mimicking @code{mmixal}'s
77 behaviour, in which instructions are only expanded if the @samp{-x} option
78 is specified, and assembly fails otherwise, when an instruction needs to
79 be expanded.  It needs to be kept in mind that @code{mmixal} is both an
80 assembler and linker, while @code{@value{AS}} will expand instructions
81 that at link stage can be contracted.  (Though linker relaxation isn't yet
82 implemented in @code{@value{LD}}.)  The option @samp{-x} also imples
83 @samp{--linker-allocated-gregs}.
84
85 @cindex @samp{--no-pushj-stubs} command line option, MMIX
86 @cindex @samp{--no-stubs} command line option, MMIX
87 If instruction expansion is enabled, @code{@value{AS}} can expand a
88 @samp{PUSHJ} instruction into a series of instructions.  The shortest
89 expansion is to not expand it, but just mark the call as redirectable to a
90 stub, which @code{@value{LD}} creates at link-time, but only if the
91 original @samp{PUSHJ} instruction is found not to reach the target.  The
92 stub consists of the necessary instructions to form a jump to the target.
93 This happens if @code{@value{AS}} can assert that the @samp{PUSHJ}
94 instruction can reach such a stub.  The option @samp{--no-pushj-stubs}
95 disables this shorter expansion, and the longer series of instructions is
96 then created at assembly-time.  The option @samp{--no-stubs} is a synonym,
97 intended for compatibility with future releases, where generation of stubs
98 for other instructions may be implemented.
99
100 @cindex @samp{--linker-allocated-gregs} command line option, MMIX
101 Usually a two-operand-expression (@pxref{GREG-base}) without a matching
102 @samp{GREG} directive is treated as an error by @code{@value{AS}}.  When
103 the option @samp{--linker-allocated-gregs} is in effect, they are instead
104 passed through to the linker, which will allocate as many global registers
105 as is needed.
106
107 @node MMIX-Expand
108 @section Instruction expansion
109
110 @cindex instruction expansion, MMIX
111 When @code{@value{AS}} encounters an instruction with an operand that is
112 either not known or does not fit the operand size of the instruction,
113 @code{@value{AS}} (and @code{@value{LD}}) will expand the instruction into
114 a sequence of instructions semantically equivalent to the operand fitting
115 the instruction.  Expansion will take place for the following
116 instructions:
117
118 @table @asis
119 @item @samp{GETA}
120 Expands to a sequence of four instructions: @code{SETL}, @code{INCML},
121 @code{INCMH} and @code{INCH}.  The operand must be a multiple of four.
122 @item Conditional branches
123 A branch instruction is turned into a branch with the complemented
124 condition and prediction bit over five instructions; four instructions
125 setting @code{$255} to the operand value, which like with @code{GETA} must
126 be a multiple of four, and a final @code{GO $255,$255,0}.
127 @item @samp{PUSHJ}
128 Similar to expansion for conditional branches; four instructions set
129 @code{$255} to the operand value, followed by a @code{PUSHGO $255,$255,0}.
130 @item @samp{JMP}
131 Similar to conditional branches and @code{PUSHJ}.  The final instruction
132 is @code{GO $255,$255,0}.
133 @end table
134
135 The linker @code{@value{LD}} is expected to shrink these expansions for
136 code assembled with @samp{--relax} (though not currently implemented).
137
138 @node MMIX-Syntax
139 @section Syntax
140
141 The assembly syntax is supposed to be upward compatible with that
142 described in Sections 1.3 and 1.4 of @samp{The Art of Computer
143 Programming, Volume 1}.  Draft versions of those chapters as well as other
144 MMIX information is located at
145 @anchor{mmixsite}@url{http://www-cs-faculty.stanford.edu/~knuth/mmix-news.html}.
146 Most code examples from the mmixal package located there should work
147 unmodified when assembled and linked as single files, with a few
148 noteworthy exceptions (@pxref{MMIX-mmixal}).
149
150 Before an instruction is emitted, the current location is aligned to the
151 next four-byte boundary.  If a label is defined at the beginning of the
152 line, its value will be the aligned value.
153
154 In addition to the traditional hex-prefix @samp{0x}, a hexadecimal number
155 can also be specified by the prefix character @samp{#}.
156
157 After all operands to an MMIX instruction or directive have been
158 specified, the rest of the line is ignored, treated as a comment.
159
160 @menu
161 * MMIX-Chars::                  Special Characters
162 * MMIX-Symbols::                Symbols
163 * MMIX-Regs::                   Register Names
164 * MMIX-Pseudos::                Assembler Directives
165 @end menu
166
167 @node MMIX-Chars
168 @subsection Special Characters
169 @cindex line comment characters, MMIX
170 @cindex MMIX line comment characters
171
172 The characters @samp{*} and @samp{#} are line comment characters; each
173 start a comment at the beginning of a line, but only at the beginning of a
174 line.  A @samp{#} prefixes a hexadecimal number if found elsewhere on a
175 line.  If a @samp{#} appears at the start of a line the whole line is
176 treated as a comment, but the line can also act as a logical line
177 number directive (@pxref{Comments}) or a preprocessor control command
178 (@pxref{Preprocessing}).
179
180 Two other characters, @samp{%} and @samp{!}, each start a comment anywhere
181 on the line.  Thus you can't use the @samp{modulus} and @samp{not}
182 operators in expressions normally associated with these two characters.
183
184 A @samp{;} is a line separator, treated as a new-line, so separate
185 instructions can be specified on a single line.
186
187 @node MMIX-Symbols
188 @subsection Symbols
189 The character @samp{:} is permitted in identifiers.  There are two
190 exceptions to it being treated as any other symbol character: if a symbol
191 begins with @samp{:}, it means that the symbol is in the global namespace
192 and that the current prefix should not be prepended to that symbol
193 (@pxref{MMIX-prefix}).  The @samp{:} is then not considered part of the
194 symbol.  For a symbol in the label position (first on a line), a @samp{:}
195 at the end of a symbol is silently stripped off.  A label is permitted,
196 but not required, to be followed by a @samp{:}, as with many other
197 assembly formats.
198
199 The character @samp{@@} in an expression, is a synonym for @samp{.}, the
200 current location.
201
202 In addition to the common forward and backward local symbol formats
203 (@pxref{Symbol Names}), they can be specified with upper-case @samp{B} and
204 @samp{F}, as in @samp{8B} and @samp{9F}.  A local label defined for the
205 current position is written with a @samp{H} appended to the number:
206 @smallexample
207 3H LDB $0,$1,2
208 @end smallexample
209 This and traditional local-label formats cannot be mixed: a label must be
210 defined and referred to using the same format.
211
212 There's a minor caveat: just as for the ordinary local symbols, the local
213 symbols are translated into ordinary symbols using control characters are
214 to hide the ordinal number of the symbol.  Unfortunately, these symbols
215 are not translated back in error messages.  Thus you may see confusing
216 error messages when local symbols are used.  Control characters
217 @samp{\003} (control-C) and @samp{\004} (control-D) are used for the
218 MMIX-specific local-symbol syntax.
219
220 The symbol @samp{Main} is handled specially; it is always global.
221
222 By defining the symbols @samp{__.MMIX.start..text} and
223 @samp{__.MMIX.start..data}, the address of respectively the @samp{.text}
224 and @samp{.data} segments of the final program can be defined, though when
225 linking more than one object file, the code or data in the object file
226 containing the symbol is not guaranteed to be start at that position; just
227 the final executable.  @xref{MMIX-loc}.
228
229 @node MMIX-Regs
230 @subsection Register names
231 @cindex register names, MMIX
232 @cindex MMIX register names
233
234 Local and global registers are specified as @samp{$0} to @samp{$255}.
235 The recognized special register names are @samp{rJ}, @samp{rA}, @samp{rB},
236 @samp{rC}, @samp{rD}, @samp{rE}, @samp{rF}, @samp{rG}, @samp{rH},
237 @samp{rI}, @samp{rK}, @samp{rL}, @samp{rM}, @samp{rN}, @samp{rO},
238 @samp{rP}, @samp{rQ}, @samp{rR}, @samp{rS}, @samp{rT}, @samp{rU},
239 @samp{rV}, @samp{rW}, @samp{rX}, @samp{rY}, @samp{rZ}, @samp{rBB},
240 @samp{rTT}, @samp{rWW}, @samp{rXX}, @samp{rYY} and @samp{rZZ}.  A leading
241 @samp{:} is optional for special register names.
242
243 Local and global symbols can be equated to register names and used in
244 place of ordinary registers.
245
246 Similarly for special registers, local and global symbols can be used.
247 Also, symbols equated from numbers and constant expressions are allowed in
248 place of a special register, except when either of the options
249 @code{--no-predefined-syms} and @code{--fixed-special-register-names} are
250 specified.  Then only the special register names above are allowed for the
251 instructions having a special register operand; @code{GET} and @code{PUT}.
252
253 @node MMIX-Pseudos
254 @subsection Assembler Directives
255 @cindex assembler directives, MMIX
256 @cindex pseudo-ops, MMIX
257 @cindex MMIX assembler directives
258 @cindex MMIX pseudo-ops
259
260 @table @code
261 @item LOC
262 @cindex assembler directive LOC, MMIX
263 @cindex pseudo-op LOC, MMIX
264 @cindex MMIX assembler directive LOC
265 @cindex MMIX pseudo-op LOC
266
267 @anchor{MMIX-loc}
268 The @code{LOC} directive sets the current location to the value of the
269 operand field, which may include changing sections.  If the operand is a
270 constant, the section is set to either @code{.data} if the value is
271 @code{0x2000000000000000} or larger, else it is set to @code{.text}.
272 Within a section, the current location may only be changed to
273 monotonically higher addresses.  A LOC expression must be a previously
274 defined symbol or a ``pure'' constant.
275
276 An example, which sets the label @var{prev} to the current location, and
277 updates the current location to eight bytes forward:
278 @smallexample
279 prev LOC @@+8
280 @end smallexample
281
282 When a LOC has a constant as its operand, a symbol
283 @code{__.MMIX.start..text} or @code{__.MMIX.start..data} is defined
284 depending on the address as mentioned above.  Each such symbol is
285 interpreted as special by the linker, locating the section at that
286 address.  Note that if multiple files are linked, the first object file
287 with that section will be mapped to that address (not necessarily the file
288 with the LOC definition).
289
290 @item LOCAL
291 @cindex assembler directive LOCAL, MMIX
292 @cindex pseudo-op LOCAL, MMIX
293 @cindex MMIX assembler directive LOCAL
294 @cindex MMIX pseudo-op LOCAL
295
296 @anchor{MMIX-local}
297 Example:
298 @smallexample
299  LOCAL external_symbol
300  LOCAL 42
301  .local asymbol
302 @end smallexample
303
304 This directive-operation generates a link-time assertion that the operand
305 does not correspond to a global register.  The operand is an expression
306 that at link-time resolves to a register symbol or a number.  A number is
307 treated as the register having that number.  There is one restriction on
308 the use of this directive: the pseudo-directive must be placed in a
309 section with contents, code or data.
310
311 @item IS
312 @cindex assembler directive IS, MMIX
313 @cindex pseudo-op IS, MMIX
314 @cindex MMIX assembler directive IS
315 @cindex MMIX pseudo-op IS
316
317 @anchor{MMIX-is}
318 The @code{IS} directive:
319 @smallexample
320 asymbol IS an_expression
321 @end smallexample
322 sets the symbol @samp{asymbol} to @samp{an_expression}.  A symbol may not
323 be set more than once using this directive.  Local labels may be set using
324 this directive, for example:
325 @smallexample
326 5H IS @@+4
327 @end smallexample
328
329 @item GREG
330 @cindex assembler directive GREG, MMIX
331 @cindex pseudo-op GREG, MMIX
332 @cindex MMIX assembler directive GREG
333 @cindex MMIX pseudo-op GREG
334
335 @anchor{MMIX-greg}
336 This directive reserves a global register, gives it an initial value and
337 optionally gives it a symbolic name.  Some examples:
338
339 @smallexample
340 areg GREG
341 breg GREG data_value
342      GREG data_buffer
343      .greg creg, another_data_value
344 @end smallexample
345
346 The symbolic register name can be used in place of a (non-special)
347 register.  If a value isn't provided, it defaults to zero.  Unless the
348 option @samp{--no-merge-gregs} is specified, non-zero registers allocated
349 with this directive may be eliminated by @code{@value{AS}}; another
350 register with the same value used in its place.
351 Any of the instructions
352 @samp{CSWAP},
353 @samp{GO},
354 @samp{LDA},
355 @samp{LDBU},
356 @samp{LDB},
357 @samp{LDHT},
358 @samp{LDOU},
359 @samp{LDO},
360 @samp{LDSF},
361 @samp{LDTU},
362 @samp{LDT},
363 @samp{LDUNC},
364 @samp{LDVTS},
365 @samp{LDWU},
366 @samp{LDW},
367 @samp{PREGO},
368 @samp{PRELD},
369 @samp{PREST},
370 @samp{PUSHGO},
371 @samp{STBU},
372 @samp{STB},
373 @samp{STCO},
374 @samp{STHT},
375 @samp{STOU},
376 @samp{STSF},
377 @samp{STTU},
378 @samp{STT},
379 @samp{STUNC},
380 @samp{SYNCD},
381 @samp{SYNCID},
382 can have a value nearby @anchor{GREG-base}an initial value in place of its
383 second and third operands.  Here, ``nearby'' is defined as within the
384 range 0@dots{}255 from the initial value of such an allocated register.
385
386 @smallexample
387 buffer1 BYTE 0,0,0,0,0
388 buffer2 BYTE 0,0,0,0,0
389  @dots{}
390  GREG buffer1
391  LDOU $42,buffer2
392 @end smallexample
393 In the example above, the @samp{Y} field of the @code{LDOUI} instruction
394 (LDOU with a constant Z) will be replaced with the global register
395 allocated for @samp{buffer1}, and the @samp{Z} field will have the value
396 5, the offset from @samp{buffer1} to @samp{buffer2}.  The result is
397 equivalent to this code:
398 @smallexample
399 buffer1 BYTE 0,0,0,0,0
400 buffer2 BYTE 0,0,0,0,0
401  @dots{}
402 tmpreg GREG buffer1
403  LDOU $42,tmpreg,(buffer2-buffer1)
404 @end smallexample
405
406 Global registers allocated with this directive are allocated in order
407 higher-to-lower within a file.  Other than that, the exact order of
408 register allocation and elimination is undefined.  For example, the order
409 is undefined when more than one file with such directives are linked
410 together.  With the options @samp{-x} and @samp{--linker-allocated-gregs},
411 @samp{GREG} directives for two-operand cases like the one mentioned above
412 can be omitted.  Sufficient global registers will then be allocated by the
413 linker.
414
415 @item BYTE
416 @cindex assembler directive BYTE, MMIX
417 @cindex pseudo-op BYTE, MMIX
418 @cindex MMIX assembler directive BYTE
419 @cindex MMIX pseudo-op BYTE
420
421 @anchor{MMIX-byte}
422 The @samp{BYTE} directive takes a series of operands separated by a comma.
423 If an operand is a string (@pxref{Strings}), each character of that string
424 is emitted as a byte.  Other operands must be constant expressions without
425 forward references, in the range 0@dots{}255.  If you need operands having
426 expressions with forward references, use @samp{.byte} (@pxref{Byte}).  An
427 operand can be omitted, defaulting to a zero value.
428
429 @item WYDE
430 @itemx TETRA
431 @itemx OCTA
432 @cindex assembler directive WYDE, MMIX
433 @cindex pseudo-op WYDE, MMIX
434 @cindex MMIX assembler directive WYDE
435 @cindex MMIX pseudo-op WYDE
436 @cindex assembler directive TETRA, MMIX
437 @cindex pseudo-op TETRA, MMIX
438 @cindex MMIX assembler directive TETRA
439 @cindex MMIX pseudo-op TETRA
440 @cindex assembler directive OCTA, MMIX
441 @cindex pseudo-op OCTA, MMIX
442 @cindex MMIX assembler directive OCTA
443 @cindex MMIX pseudo-op OCTA
444
445 @anchor{MMIX-constants}
446 The directives @samp{WYDE}, @samp{TETRA} and @samp{OCTA} emit constants of
447 two, four and eight bytes size respectively.  Before anything else happens
448 for the directive, the current location is aligned to the respective
449 constant-size boundary.  If a label is defined at the beginning of the
450 line, its value will be that after the alignment.  A single operand can be
451 omitted, defaulting to a zero value emitted for the directive.  Operands
452 can be expressed as strings (@pxref{Strings}), in which case each
453 character in the string is emitted as a separate constant of the size
454 indicated by the directive.
455
456 @item PREFIX
457 @cindex assembler directive PREFIX, MMIX
458 @cindex pseudo-op PREFIX, MMIX
459 @cindex MMIX assembler directive PREFIX
460 @cindex MMIX pseudo-op PREFIX
461
462 @anchor{MMIX-prefix}
463 The @samp{PREFIX} directive sets a symbol name prefix to be prepended to
464 all symbols (except local symbols, @pxref{MMIX-Symbols}), that are not
465 prefixed with @samp{:}, until the next @samp{PREFIX} directive.  Such
466 prefixes accumulate.  For example,
467 @smallexample
468  PREFIX a
469  PREFIX b
470 c IS 0
471 @end smallexample
472 defines a symbol @samp{abc} with the value 0.
473
474 @item BSPEC
475 @itemx ESPEC
476 @cindex assembler directive BSPEC, MMIX
477 @cindex pseudo-op BSPEC, MMIX
478 @cindex MMIX assembler directive BSPEC
479 @cindex MMIX pseudo-op BSPEC
480 @cindex assembler directive ESPEC, MMIX
481 @cindex pseudo-op ESPEC, MMIX
482 @cindex MMIX assembler directive ESPEC
483 @cindex MMIX pseudo-op ESPEC
484
485 @anchor{MMIX-spec}
486 A pair of @samp{BSPEC} and @samp{ESPEC} directives delimit a section of
487 special contents (without specified semantics).  Example:
488 @smallexample
489  BSPEC 42
490  TETRA 1,2,3
491  ESPEC
492 @end smallexample
493 The single operand to @samp{BSPEC} must be number in the range
494 0@dots{}255.  The @samp{BSPEC} number 80 is used by the GNU binutils
495 implementation.
496 @end table
497
498 @node MMIX-mmixal
499 @section Differences to @code{mmixal}
500 @cindex mmixal differences
501 @cindex differences, mmixal
502
503 The binutils @code{@value{AS}} and @code{@value{LD}} combination has a few
504 differences in function compared to @code{mmixal} (@pxref{mmixsite}).
505
506 The replacement of a symbol with a GREG-allocated register
507 (@pxref{GREG-base}) is not handled the exactly same way in
508 @code{@value{AS}} as in @code{mmixal}.  This is apparent in the
509 @code{mmixal} example file @code{inout.mms}, where different registers
510 with different offsets, eventually yielding the same address, are used in
511 the first instruction.  This type of difference should however not affect
512 the function of any program unless it has specific assumptions about the
513 allocated register number.
514
515 Line numbers (in the @samp{mmo} object format) are currently not
516 supported.
517
518 Expression operator precedence is not that of mmixal: operator precedence
519 is that of the C programming language.  It's recommended to use
520 parentheses to explicitly specify wanted operator precedence whenever more
521 than one type of operators are used.
522
523 The serialize unary operator @code{&}, the fractional division operator
524 @samp{//}, the logical not operator @code{!} and the modulus operator
525 @samp{%} are not available.
526
527 Symbols are not global by default, unless the option
528 @samp{--globalize-symbols} is passed.  Use the @samp{.global} directive to
529 globalize symbols (@pxref{Global}).
530
531 Operand syntax is a bit stricter with @code{@value{AS}} than
532 @code{mmixal}.  For example, you can't say @code{addu 1,2,3}, instead you
533 must write @code{addu $1,$2,3}.
534
535 You can't LOC to a lower address than those already visited
536 (i.e., ``backwards'').
537
538 A LOC directive must come before any emitted code.
539
540 Predefined symbols are visible as file-local symbols after use.  (In the
541 ELF file, that is---the linked mmo file has no notion of a file-local
542 symbol.)
543
544 Some mapping of constant expressions to sections in LOC expressions is
545 attempted, but that functionality is easily confused and should be avoided
546 unless compatibility with @code{mmixal} is required.  A LOC expression to
547 @samp{0x2000000000000000} or higher, maps to the @samp{.data} section and
548 lower addresses map to the @samp{.text} section (@pxref{MMIX-loc}).
549
550 The code and data areas are each contiguous.  Sparse programs with
551 far-away LOC directives will take up the same amount of space as a
552 contiguous program with zeros filled in the gaps between the LOC
553 directives.  If you need sparse programs, you might try and get the wanted
554 effect with a linker script and splitting up the code parts into sections
555 (@pxref{Section}).  Assembly code for this, to be compatible with
556 @code{mmixal}, would look something like:
557 @smallexample
558  .if 0
559  LOC away_expression
560  .else
561  .section away,"ax"
562  .fi
563 @end smallexample
564 @code{@value{AS}} will not execute the LOC directive and @code{mmixal}
565 ignores the lines with @code{.}.  This construct can be used generally to
566 help compatibility.
567
568 Symbols can't be defined twice--not even to the same value.
569
570 Instruction mnemonics are recognized case-insensitive, though the
571 @samp{IS} and @samp{GREG} pseudo-operations must be specified in
572 upper-case characters.
573
574 There's no unicode support.
575
576 The following is a list of programs in @samp{mmix.tar.gz}, available at
577 @url{http://www-cs-faculty.stanford.edu/~knuth/mmix-news.html}, last
578 checked with the version dated 2001-08-25 (md5sum
579 c393470cfc86fac040487d22d2bf0172) that assemble with @code{mmixal} but do
580 not assemble with @code{@value{AS}}:
581
582 @table @code
583 @item silly.mms
584 LOC to a previous address.
585 @item sim.mms
586 Redefines symbol @samp{Done}.
587 @item test.mms
588 Uses the serial operator @samp{&}.
589 @end table