Document BR 2887108 in changes.src
[platform/upstream/nasm.git] / doc / changes.src
1 \#
2 \# NASM revision history in nasmdoc format
3 \#
4
5 \H{cl-2.xx} NASM 2 Series
6
7 The NASM 2 series support x86-64, and is the production version of NASM
8 since 2007.
9
10
11 \S{cl-2.08rc2} Version 2.08rc2
12
13 \b A number of enhancements/fixes in macros area.
14
15 \b Support for arbitrarily terminating macro expansions \c{%exitmacro}.
16   See \k{exitmacro}.
17
18 \b Support for recursive macro expansion \c{%rmacro/irmacro}.
19   See \k{mlrmacro}.
20
21 \b Support for converting strings to tokens.  See \k{deftok}.
22
23 \b Fuzzy operand size logic introduced.
24
25 \b Fix Macho-O alignment bug.
26
27 \b Fix crashes with -fwin32 on file with many exports.
28
29 \b Fix stack overrun for too long [DEBUG id].
30
31 \b Fix incorrect sbyte usage in IMUL (hit only if optimization
32   flag passed).
33
34 \b Append ending token for \c{.stabs} records in the ELF output format.
35
36 \b New NSIS script which uses ModernUI and MultiUser approach.
37
38 \b Visual Studio 2008 NASM integration (rules file).
39
40 \b Warn a user if a constant too long (and as a result will be stripped).
41
42
43 \S{cl-2.07} Version 2.07
44
45 \b NASM is now under the 2-clause BSD license.  See \k{legal}.
46
47 \b Fix the section type for the \c{.strtab} section in the \c{elf64}
48   output format.
49
50 \b Fix the handling of \c{COMMON} directives in the \c{obj} output format.
51
52 \b New \c{ith} and \c{srec} output formats; these are variants of the
53   \c{bin} output format which output Intel hex and Motorola S-records,
54   respectively.  See \k{ithfmt} and \k{srecfmt}.
55
56 \b \c{rdf2ihx} replaced with an enhanced \c{rdf2bin}, which can output
57   binary, COM, Intel hex or Motorola S-records.
58
59 \b The Windows installer now puts the NASM directory first in the
60   \c{PATH} of the "NASM Shell".
61
62 \b Revert the early expansion behavior of \c{%+} to pre-2.06 behavior:
63   \c{%+} is only expanded late.
64
65 \b Yet another Mach-O alignment fix.
66
67 \b Don't delete the list file on errors.  Also, include error and
68   warning information in the list file.
69
70 \b Support for 64-bit Mach-O output, see \k{machofmt}.
71
72 \b Fix assert failure on certain operations that involve strings with
73   high-bit bytes.
74
75
76 \S{cl-2.06} Version 2.06
77
78 \b This release is dedicated to the memory of Charles A. Crayne, long
79   time NASM developer as well as moderator of \c{comp.lang.asm.x86} and
80   author of the book \e{Serious Assembler}.  We miss you, Chuck.
81
82 \b Support for indirect macro expansion (\c{%[...]}).  See \k{indmacro}.
83
84 \b \c{%pop} can now take an argument, see \k{pushpop}.
85
86 \b The argument to \c{%use} is no longer macro-expanded.  Use
87   \c{%[...]} if macro expansion is desired.
88
89 \b Support for thread-local storage in ELF32 and ELF64.  See \k{elftls}.
90
91 \b Fix crash on \c{%ifmacro} without an argument.
92
93 \b Correct the arguments to the \c{POPCNT} instruction.
94
95 \b Fix section alignment in the Mach-O format.
96
97 \b Update AVX support to version 5 of the Intel specification.
98
99 \b Fix the handling of accesses to context-local macros from higher
100   levels in the context stack.
101
102 \b Treat \c{WAIT} as a prefix rather than as an instruction, thereby
103   allowing constructs like \c{O16 FSAVE} to work correctly.
104
105 \b Support for structures with a non-zero base offset. See \k{struc}.
106
107 \b Correctly handle preprocessor token concatenation (see \k{concat})
108    involving floating-point numbers.
109
110 \b The \c{PINSR} series of instructions have been corrected and
111    rationalized.
112
113 \b Removed AMD SSE5, replaced with the new XOP/FMA4/CVT16 (rev 3.03)
114    spec.
115
116 \b The ELF backends no longer automatically generate a \c{.comment} section.
117
118 \b Add additional "well-known" ELF sections with default attributes.  See
119    \k{elfsect}.
120
121
122 \S{cl-2.05.01} Version 2.05.01
123
124 \b Fix the \c{-w}/\c{-W} option parsing, which was broken in NASM 2.05.
125
126
127 \S{cl-2.05} Version 2.05
128
129 \b Fix redundant REX.W prefix on \c{JMP reg64}.
130
131 \b Make the behaviour of \c{-O0} match NASM 0.98 legacy behavior.
132   See \k{opt-O}.
133
134 \b \c{-w-user} can be used to suppress the output of \c{%warning} directives.
135   See \k{opt-w}.
136
137 \b Fix bug where \c{ALIGN} would issue a full alignment datum instead of
138   zero bytes.
139
140 \b Fix offsets in list files.
141
142 \b Fix \c{%include} inside multi-line macros or loops.
143
144 \b Fix error where NASM would generate a spurious warning on valid
145   optimizations of immediate values.
146
147 \b Fix arguments to a number of the \c{CVT} SSE instructions.
148
149 \b Fix RIP-relative offsets when the instruction carries an immediate.
150
151 \b Massive overhaul of the ELF64 backend for spec compliance.
152
153 \b Fix the Geode \c{PFRCPV} and \c{PFRSQRTV} instruction.
154
155 \b Fix the SSE 4.2 \c{CRC32} instruction.
156
157
158 \S{cl-2.04} Version 2.04
159
160 \b Sanitize macro handing in the \c{%error} directive.
161
162 \b New \c{%warning} directive to issue user-controlled warnings.
163
164 \b \c{%error} directives are now deferred to the final assembly phase.
165
166 \b New \c{%fatal} directive to immediately terminate assembly.
167
168 \b New \c{%strcat} directive to join quoted strings together.
169
170 \b New \c{%use} macro directive to support standard macro directives.  See
171   \k{use}.
172
173 \b Excess default parameters to \c{%macro} now issues a warning by default.
174   See \k{mlmacro}.
175
176 \b Fix \c{%ifn} and \c{%elifn}.
177
178 \b Fix nested \c{%else} clauses.
179
180 \b Correct the handling of nested \c{%rep}s.
181
182 \b New \c{%unmacro} directive to undeclare a multi-line macro.
183   See \k{unmacro}.
184
185 \b Builtin macro \c{__PASS__} which expands to the current assembly pass.
186   See \k{pass_macro}.
187
188 \b \c{__utf16__} and \c{__utf32__} operators to generate UTF-16 and UTF-32
189   strings.  See \k{unicode}.
190
191 \b Fix bug in case-insensitive matching when compiled on platforms that
192   don't use the \c{configure} script.  Of the official release binaries,
193   that only affected the OS/2 binary.
194
195 \b Support for x87 packed BCD constants.  See \k{bcdconst}.
196
197 \b Correct the \c{LTR} and \c{SLDT} instructions in 64-bit mode.
198
199 \b Fix unnecessary REX.W prefix on indirect jumps in 64-bit mode.
200
201 \b Add AVX versions of the AES instructions (\c{VAES}...).
202
203 \b Fix the 256-bit FMA instructions.
204
205 \b Add 256-bit AVX stores per the latest AVX spec.
206
207 \b VIA XCRYPT instructions can now be written either with or without
208   \c{REP}, apparently different versions of the VIA spec wrote them
209   differently.
210
211 \b Add missing 64-bit \c{MOVNTI} instruction.
212
213 \b Fix the operand size of \c{VMREAD} and \c{VMWRITE}.
214
215 \b Numerous bug fixes, especially to the AES, AVX and VTX instructions.
216
217 \b The optimizer now always runs until it converges.  It also runs even
218   when disabled, but doesn't optimize.  This allows most forward references
219   to be resolved properly.
220
221 \b \c{%push} no longer needs a context identifier; omitting the context
222   identifier results in an anonymous context.
223
224
225 \S{cl-2.03.01} Version 2.03.01
226
227 \b Fix buffer overflow in the listing module.
228
229 \b Fix the handling of hexadecimal escape codes in `...` strings.
230
231 \b The Postscript/PDF documentation has been reformatted.
232
233 \b The \c{-F} option now implies \c{-g}.
234
235
236 \S{cl-2.03} Version 2.03
237
238 \b Add support for Intel AVX, CLMUL and FMA instructions,
239 including YMM registers.
240
241 \b \c{dy}, \c{resy} and \c{yword} for 32-byte operands.
242
243 \b Fix some SSE5 instructions.
244
245 \b Intel \c{INVEPT}, \c{INVVPID} and \c{MOVBE} instructions.
246
247 \b Fix checking for critical expressions when the optimizer is enabled.
248
249 \b Support the DWARF debugging format for ELF targets.
250
251 \b Fix optimizations of signed bytes.
252
253 \b Fix operation on bigendian machines.
254
255 \b Fix buffer overflow in the preprocessor.
256
257 \b \c{SAFESEH} support for Win32, \c{IMAGEREL} for Win64 (SEH).
258
259 \b \c{%?} and \c{%??} to refer to the name of a macro itself.  In particular,
260 \c{%idefine keyword $%?} can be used to make a keyword "disappear".
261
262 \b New options for dependency generation: \c{-MD}, \c{-MF},
263 \c{-MP}, \c{-MT}, \c{-MQ}.
264
265 \b New preprocessor directives \c{%pathsearch} and \c{%depend}; INCBIN
266 reimplemented as a macro.
267
268 \b \c{%include} now resolves macros in a sane manner.
269
270 \b \c{%substr} can now be used to get other than one-character substrings.
271
272 \b New type of character/string constants, using backquotes (\c{`...`}),
273 which support C-style escape sequences.
274
275 \b \c{%defstr} and \c{%idefstr} to stringize macro definitions before
276 creation.
277
278 \b Fix forward references used in \c{EQU} statements.
279
280
281 \S{cl-2.02} Version 2.02
282
283 \b Additional fixes for MMX operands with explicit \c{qword}, as well as
284   (hopefully) SSE operands with \c{oword}.
285
286 \b Fix handling of truncated strings with \c{DO}.
287
288 \b Fix segfaults due to memory overwrites when floating-point constants
289   were used.
290
291 \b Fix segfaults due to missing include files.
292
293 \b Fix OpenWatcom Makefiles for DOS and OS/2.
294
295 \b Add autogenerated instruction list back into the documentation.
296
297 \b ELF: Fix segfault when generating stabs, and no symbols have been
298   defined.
299
300 \b ELF: Experimental support for DWARF debugging information.
301
302 \b New compile date and time standard macros.
303
304 \b \c{%ifnum} now returns true for negative numbers.
305
306 \b New \c{%iftoken} test for a single token.
307
308 \b New \c{%ifempty} test for empty expansion.
309
310 \b Add support for the \c{XSAVE} instruction group.
311
312 \b Makefile for Netware/gcc.
313
314 \b Fix issue with some warnings getting emitted way too many times.
315
316 \b Autogenerated instruction list added to the documentation.
317
318
319 \S{cl-2.01} Version 2.01
320
321 \b Fix the handling of MMX registers with explicit \c{qword} tags on
322   memory (broken in 2.00 due to 64-bit changes.)
323
324 \b Fix the PREFETCH instructions.
325
326 \b Fix the documentation.
327
328 \b Fix debugging info when using \c{-f elf}
329 (backwards compatibility alias for \c{-f elf32}).
330
331 \b Man pages for rdoff tools (from the Debian project.)
332
333 \b ELF: handle large numbers of sections.
334
335 \b Fix corrupt output when the optimizer runs out of passes.
336
337
338 \S{cl-2.00} Version 2.00
339
340 \b Added c99 data-type compliance.
341
342 \b Added general x86-64 support.
343
344 \b Added win64 (x86-64 COFF) output format.
345
346 \b Added \c{__BITS__} standard macro.
347
348 \b Renamed the \c{elf} output format to \c{elf32} for clarity.
349
350 \b Added \c{elf64} and \c{macho} (MacOS X) output formats.
351
352 \b Added Numeric constants in \c{dq} directive.
353
354 \b Added \c{oword}, \c{do} and \c{reso} pseudo operands.
355
356 \b Allow underscores in numbers.
357
358 \b Added 8-, 16- and 128-bit floating-point formats.
359
360 \b Added binary, octal and hexadecimal floating-point.
361
362 \b Correct the generation of floating-point constants.
363
364 \b Added floating-point option control.
365
366 \b Added Infinity and NaN floating point support.
367
368 \b Added ELF Symbol Visibility support.
369
370 \b Added setting OSABI value in ELF header directive.
371
372 \b Added Generate Makefile Dependencies option.
373
374 \b Added Unlimited Optimization Passes option.
375
376 \b Added \c{%IFN} and \c{%ELIFN} support.
377
378 \b Added Logical Negation Operator.
379
380 \b Enhanced Stack Relative Preprocessor Directives.
381
382 \b Enhanced ELF Debug Formats.
383
384 \b Enhanced Send Errors to a File option.
385
386 \b Added SSSE3, SSE4.1, SSE4.2, SSE5 support.
387
388 \b Added a large number of additional instructions.
389
390 \b Significant performance improvements.
391
392 \b \c{-w+warning} and \c{-w-warning} can now be written as -Wwarning and
393  -Wno-warning, respectively.  See \k{opt-w}.
394
395 \b Add \c{-w+error} to treat warnings as errors.  See \k{opt-w}.
396
397 \b Add \c{-w+all} and \c{-w-all} to enable or disable all suppressible
398  warnings.  See \k{opt-w}.
399
400
401 \H{cl-0.98.xx} NASM 0.98 Series
402
403 The 0.98 series was the production versions of NASM from 1999 to 2007.
404
405
406 \S{cl-0.98.39} Version 0.98.39
407
408 \b fix buffer overflow
409
410 \b fix outas86's \c{.bss} handling
411
412 \b "make spotless" no longer deletes config.h.in.
413
414 \b \c{%(el)if(n)idn} insensitivity to string quotes difference (#809300).
415
416 \b (nasm.c)\c{__OUTPUT_FORMAT__} changed to string value instead of symbol.
417
418 \S{cl-0.98.38} Version 0.98.38
419
420
421 \b Add Makefile for 16-bit DOS binaries under OpenWatcom, and modify
422   \c{mkdep.pl} to be able to generate completely pathless dependencies, as
423   required by OpenWatcom wmake (it supports path searches, but not
424   explicit paths.)
425
426 \b Fix the \c{STR} instruction.
427
428 \b Fix the ELF output format, which was broken under certain
429   circumstances due to the addition of stabs support.
430
431 \b Quick-fix Borland format debug-info for \c{-f obj}
432
433 \b Fix for \c{%rep} with no arguments (#560568)
434
435 \b Fix concatenation of preprocessor function call (#794686)
436
437 \b Fix long label causes coredump (#677841)
438
439 \b Use autoheader as well as autoconf to keep configure from generating
440   ridiculously long command lines.
441
442 \b Make sure that all of the formats which support debugging output
443   actually will suppress debugging output when \c{-g} not specified.
444
445 \S{cl-0.98.37} Version 0.98.37
446
447
448 \b Paths given in \c{-I} switch searched for \c{incbin}-ed as
449   well as \c{%include}-ed files.
450
451 \b Added stabs debugging for the ELF output format, patch from
452   Martin Wawro.
453
454 \b Fix \c{output/outbin.c} to allow origin > 80000000h.
455
456 \b Make \c{-U} switch work.
457
458 \b Fix the use of relative offsets with explicit prefixes, e.g.
459 \c{a32 loop foo}.
460
461 \b Remove \c{backslash()}.
462
463 \b Fix the \c{SMSW} and \c{SLDT} instructions.
464
465 \b \c{-O2} and \c{-O3} are no longer aliases for \c{-O10} and \c{-O15}.
466 If you mean the latter, please say so! :)
467
468 \S{cl-0.98.36} Version 0.98.36
469
470
471 \b Update rdoff - librarian/archiver - common rec - docs!
472
473 \b Fix signed/unsigned problems.
474
475 \b Fix \c{JMP FAR label} and \c{CALL FAR label}.
476
477 \b Add new multisection support - map files - fix align bug
478
479 \b Fix sysexit, movhps/movlps reg,reg bugs in insns.dat
480
481 \b \c{Q} or \c{O} suffixes indicate octal
482
483 \b Support Prescott new instructions (PNI).
484
485 \b Cyrix \c{XSTORE} instruction.
486
487
488 \S{cl-0.98.35} Version 0.98.35
489
490 \b Fix build failure on 16-bit DOS (Makefile.bc3 workaround for compiler bug.)
491
492 \b Fix dependencies and compiler warnings.
493
494 \b Add "const" in a number of places.
495
496 \b Add -X option to specify error reporting format (use -Xvc to
497   integrate with Microsoft Visual Studio.)
498
499 \b Minor changes for code legibility.
500
501 \b Drop use of tmpnam() in rdoff (security fix.)
502
503
504 \S{cl-0.98.34} Version 0.98.34
505
506 \b Correct additional address-size vs. operand-size confusions.
507
508 \b Generate dependencies for all Makefiles automatically.
509
510 \b Add support for unimplemented (but theoretically available)
511   registers such as tr0 and cr5.  Segment registers 6 and 7 are called
512   segr6 and segr7 for the operations which they can be represented.
513
514 \b Correct some disassembler bugs related to redundant address-size prefixes.
515   Some work still remains in this area.
516
517 \b Correctly generate an error for things like "SEG eax".
518
519 \b Add the JMPE instruction, enabled by "CPU IA64".
520
521 \b Correct compilation on newer gcc/glibc platforms.
522
523 \b Issue an error on things like "jmp far eax".
524
525
526 \S{cl-0.98.33} Version 0.98.33
527
528 \b New __NASM_PATCHLEVEL__ and __NASM_VERSION_ID__ standard macros to
529   round out the version-query macros.  version.pl now understands
530   X.YYplWW or X.YY.ZZplWW as a version number, equivalent to
531   X.YY.ZZ.WW (or X.YY.0.WW, as appropriate).
532
533 \b New keyword "strict" to disable the optimization of specific
534   operands.
535
536 \b Fix the handing of size overrides with JMP instructions
537   (instructions such as "jmp dword foo".)
538
539 \b Fix the handling of "ABSOLUTE label", where "label" points into a
540   relocatable segment.
541
542 \b Fix OBJ output format with lots of externs.
543
544 \b More documentation updates.
545
546 \b Add -Ov option to get verbose information about optimizations.
547
548 \b Undo a braindead change which broke \c{%elif} directives.
549
550 \b Makefile updates.
551
552
553 \S{cl-0.98.32} Version 0.98.32
554
555 \b Fix NASM crashing when \c{%macro} directives were left unterminated.
556
557 \b Lots of documentation updates.
558
559 \b Complete rewrite of the PostScript/PDF documentation generator.
560
561 \b The MS Visual C++ Makefile was updated and corrected.
562
563 \b Recognize .rodata as a standard section name in ELF.
564
565 \b Fix some obsolete Perl4-isms in Perl scripts.
566
567 \b Fix configure.in to work with autoconf 2.5x.
568
569 \b Fix a couple of "make cleaner" misses.
570
571 \b Make the normal "./configure && make" work with Cygwin.
572
573
574 \S{cl-0.98.31} Version 0.98.31
575
576 \b Correctly build in a separate object directory again.
577
578 \b Derive all references to the version number from the version file.
579
580 \b New standard macros __NASM_SUBMINOR__ and __NASM_VER__ macros.
581
582 \b Lots of Makefile updates and bug fixes.
583
584 \b New \c{%ifmacro} directive to test for multiline macros.
585
586 \b Documentation updates.
587
588 \b Fixes for 16-bit OBJ format output.
589
590 \b Changed the NASM environment variable to NASMENV.
591
592
593 \S{cl-0.98.30} Version 0.98.30
594
595 \b Changed doc files a lot: completely removed old READMExx and
596   Wishlist files, incorporating all information in CHANGES and TODO.
597
598 \b I waited a long time to rename zoutieee.c to (original) outieee.c
599
600 \b moved all output modules to output/ subdirectory.
601
602 \b Added 'make strip' target to strip debug info from nasm & ndisasm.
603
604 \b Added INSTALL file with installation instructions.
605
606 \b Added -v option description to nasm man.
607
608 \b Added dist makefile target to produce source distributions.
609
610 \b 16-bit support for ELF output format (GNU extension, but useful.)
611
612
613 \S{cl-0.98.28} Version 0.98.28
614
615 \b Fastcooked this for Debian's Woody release:
616 Frank applied the INCBIN bug patch to 0.98.25alt and called
617 it 0.98.28 to not confuse poor little apt-get.
618
619
620 \S{cl-0.98.26} Version 0.98.26
621
622 \b Reorganised files even better from 0.98.25alt
623
624
625 \S{cl-0.98.25alt} Version 0.98.25alt
626
627 \b Prettified the source tree. Moved files to more reasonable places.
628
629 \b Added findleak.pl script to misc/ directory.
630
631 \b Attempted to fix doc.
632
633
634 \S{cl-0.98.25} Version 0.98.25
635
636 \b Line continuation character \c{\\}.
637
638 \b Docs inadvertantly reverted - "dos packaging".
639
640
641 \S{cl-0.98.24p1} Version 0.98.24p1
642
643 \b FIXME: Someone, document this please.
644
645
646 \S{cl-0.98.24} Version 0.98.24
647
648 \b Documentation - Ndisasm doc added to Nasm.doc.
649
650
651 \S{cl-0.98.23} Version 0.98.23
652
653 \b Attempted to remove rdoff version1
654
655 \b Lino Mastrodomenico's patches to preproc.c (%$$ bug?).
656
657
658 \S{cl-0.98.22} Version 0.98.22
659
660 \b Update rdoff2 - attempt to remove v1.
661
662
663 \S{cl-0.98.21} Version 0.98.21
664
665 \b Optimization fixes.
666
667
668 \S{cl-0.98.20} Version 0.98.20
669
670 \b Optimization fixes.
671
672
673 \S{cl-0.98.19} Version 0.98.19
674
675 \b H. J. Lu's patch back out.
676
677
678 \S{cl-0.98.18} Version 0.98.18
679
680 \b Added ".rdata" to "-f win32".
681
682
683 \S{cl-0.98.17} Version 0.98.17
684
685 \b H. J. Lu's "bogus elf" patch. (Red Hat problem?)
686
687
688 \S{cl-0.98.16} Version 0.98.16
689
690 \b Fix whitespace before "[section ..." bug.
691
692
693 \S{cl-0.98.15} Version 0.98.15
694
695 \b Rdoff changes (?).
696
697 \b Fix fixes to memory leaks.
698
699
700 \S{cl-0.98.14} Version 0.98.14
701
702 \b Fix memory leaks.
703
704
705 \S{cl-0.98.13} Version 0.98.13
706
707 \b There was no 0.98.13
708
709
710 \S{cl-0.98.12} Version 0.98.12
711
712 \b Update optimization (new function of "-O1")
713
714 \b Changes to test/bintest.asm (?).
715
716
717 \S{cl-0.98.11} Version 0.98.11
718
719 \b Optimization changes.
720
721 \b Ndisasm fixed.
722
723
724 \S{cl-0.98.10} Version 0.98.10
725
726 \b There was no 0.98.10
727
728
729 \S{cl-0.98.09} Version 0.98.09
730
731 \b Add multiple sections support to "-f bin".
732
733 \b Changed GLOBAL_TEMP_BASE in outelf.c from 6 to 15.
734
735 \b Add "-v" as an alias to the "-r" switch.
736
737 \b Remove "#ifdef" from Tasm compatibility options.
738
739 \b Remove redundant size-overrides on "mov ds, ex", etc.
740
741 \b Fixes to SSE2, other insns.dat (?).
742
743 \b Enable uppercase "I" and "P" switches.
744
745 \b Case insinsitive "seg" and "wrt".
746
747 \b Update install.sh (?).
748
749 \b Allocate tokens in blocks.
750
751 \b Improve "invalid effective address" messages.
752
753
754 \S{cl-0.98.08} Version 0.98.08
755
756 \b Add "\c{%strlen}" and "\c{%substr}" macro operators
757
758 \b Fixed broken c16.mac.
759
760 \b Unterminated string error reported.
761
762 \b Fixed bugs as per 0.98bf
763
764
765 \S{cl-0.98.09b with John Coffman patches released 28-Oct-2001} Version 0.98.09b with John Coffman patches released 28-Oct-2001
766
767 Changes from 0.98.07 release to 98.09b as of 28-Oct-2001
768
769 \b More closely compatible with 0.98 when -O0 is implied
770 or specified.  Not strictly identical, since backward 
771 branches in range of short offsets are recognized, and signed
772 byte values with no explicit size specification will be
773 assembled as a single byte.
774
775 \b More forgiving with the PUSH instruction.  0.98 requires
776 a size to be specified always.  0.98.09b will imply the size
777 from the current BITS setting (16 or 32).
778
779 \b Changed definition of the optimization flag:
780
781         -O0     strict two-pass assembly, JMP and Jcc are
782                 handled more like 0.98, except that back-
783                 ward JMPs are short, if possible.
784
785         -O1     strict two-pass assembly, but forward
786                 branches are assembled with code guaranteed
787                 to reach; may produce larger code than
788                 -O0, but will produce successful assembly
789                 more often if branch offset sizes are not
790                 specified.
791
792         -O2     multi-pass optimization, minimize branch
793                 offsets; also will minimize signed immed-
794                 iate bytes, overriding size specification.
795
796         -O3     like -O2, but more passes taken, if needed
797
798
799 \S{cl-0.98.07 released 01/28/01} Version 0.98.07 released 01/28/01
800
801 \b       Added Stepane Denis' SSE2 instructions to a *working*
802         version of the code - some earlier versions were based on
803         broken code - sorry 'bout that. version "0.98.07"
804
805
806 01/28/01
807
808
809 \b       Cosmetic modifications to nasm.c, nasm.h,
810         AUTHORS, MODIFIED
811
812
813 \S{cl-0.98.06f released 01/18/01} Version 0.98.06f released 01/18/01
814
815
816 \b       - Add "metalbrain"s jecxz bug fix in insns.dat
817         - alter nasmdoc.src to match - version "0.98.06f"
818
819
820 \S{cl-0.98.06e released 01/09/01} Version 0.98.06e released 01/09/01
821
822
823 \b       Removed the "outforms.h" file - it appears to be
824         someone's old backup of "outform.h". version "0.98.06e" 
825
826 01/09/01
827
828 \b fbk - finally added the fix for the "multiple %includes bug",
829         known since 7/27/99 - reported originally (?) and sent to
830         us by Austin Lunnen - he reports that John Fine had a fix
831         within the day. Here it is...
832
833 \b Nelson Rush resigns from the group. Big thanks to Nelson for
834   his leadership and enthusiasm in getting these changes
835   incorporated into Nasm!
836
837 \b fbk - [list +], [list -] directives - ineptly implemented, should
838         be re-written or removed, perhaps.
839
840 \b Brian Raiter / fbk - "elfso bug" fix - applied to aoutb format
841                        as well - testing might be desirable...
842
843 08/07/00
844
845 \b James Seter - -postfix, -prefix command line switches.
846
847 \b Yuri Zaporogets - rdoff utility changes.
848
849
850 \S{cl-0.98p1} Version 0.98p1
851
852 \b GAS-like palign (Panos Minos)
853
854 \b FIXME: Someone, fill this in with details
855
856
857 \S{cl-0.98bf (bug-fixed)} Version 0.98bf (bug-fixed)
858
859 \b Fixed - elf and aoutb bug - shared libraries
860         - multiple "%include" bug in "-f obj"   
861         - jcxz, jecxz bug
862         - unrecognized option bug in ndisasm 
863
864 \S{cl-0.98.03 with John Coffman's changes released 27-Jul-2000} Version 0.98.03 with John Coffman's changes released 27-Jul-2000
865
866 \b Added signed byte optimizations for the 0x81/0x83 class
867 of instructions: ADC, ADD, AND, CMP, OR, SBB, SUB, XOR:
868 when used as 'ADD reg16,imm' or 'ADD reg32,imm.'  Also
869 optimization of signed byte form of 'PUSH imm' and 'IMUL
870 reg,imm'/'IMUL reg,reg,imm.'  No size specification is needed.
871
872 \b Added multi-pass JMP and Jcc offset optimization.  Offsets
873 on forward references will preferentially use the short form,
874 without the need to code a specific size (short or near) for
875 the branch.  Added instructions for 'Jcc label' to use the
876 form 'Jnotcc $+3/JMP label', in cases where a short offset
877 is out of bounds.  If compiling for a 386 or higher CPU, then
878 the 386 form of Jcc will be used instead.
879
880 This feature is controlled by a new command-line switch: "O",
881 (upper case letter O).  "-O0" reverts the assembler to no
882 extra optimization passes, "-O1" allows up to 5 extra passes,
883 and "-O2"(default), allows up to 10 extra optimization passes.
884
885 \b Added a new directive:  'cpu XXX', where XXX is any of: 
886 8086, 186, 286, 386, 486, 586, pentium, 686, PPro, P2, P3 or
887 Katmai.  All are case insensitive.  All instructions will
888 be selected only if they apply to the selected cpu or lower.
889 Corrected a couple of bugs in cpu-dependence in 'insns.dat'.
890
891 \b Added to 'standard.mac', the "use16" and "use32" forms of
892 the "bits 16/32" directive. This is nothing new, just conforms
893 to a lot of other assemblers. (minor)
894
895 \b Changed label allocation from 320/32 (10000 labels @ 200K+) 
896 to 32/37 (1000 labels); makes running under DOS much easier.
897 Since additional label space is allocated dynamically, this
898 should have no effect on large programs with lots of labels.
899 The 37 is a prime, believed to be better for hashing. (minor)
900
901
902 \S{cl-0.98.03} Version 0.98.03
903
904 "Integrated patchfile 0.98-0.98.01.  I call this version 0.98.03 for
905 historical reasons: 0.98.02 was trashed." --John Coffman
906 <johninsd@san.rr.com>, 27-Jul-2000
907
908 \b Kendall Bennett's SciTech MGL changes
909
910 \b Note that you must define "TASM_COMPAT" at compile-time
911 to get the Tasm Ideal Mode compatibility.
912
913 \b All changes can be compiled in and out using the TASM_COMPAT macros,
914 and when compiled without TASM_COMPAT defined we get the exact same
915 binary as the unmodified 0.98 sources.
916
917 \b standard.mac, macros.c: Added macros to ignore TASM directives before
918 first include
919
920 \b nasm.h: Added extern declaration for tasm_compatible_mode
921
922 \b nasm.c: Added global variable tasm_compatible_mode
923
924 \b Added command line switch for TASM compatible mode (-t)
925
926 \b Changed version command line to reflect when compiled with TASM additions
927
928 \b Added response file processing to allow all arguments on a single
929 line (response file is @resp rather than -@resp for NASM format).
930
931 \b labels.c: Changes islocal() macro to support TASM style @@local labels.
932
933 \b Added islocalchar() macro to support TASM style @@local labels.
934
935 \b parser.c: Added support for TASM style memory references (ie: mov
936 [DWORD eax],10 rather than the NASM style mov DWORD [eax],10).
937
938 \b preproc.c: Added new directives, \c{%arg}, \c{%local}, \c{%stacksize} to directives
939 table
940
941 \b Added support for TASM style directives without a leading % symbol.
942
943 \b Integrated a block of changes from Andrew Zabolotny <bit@eltech.ru>:
944
945 \b A new keyword \c{%xdefine} and its case-insensitive counterpart \c{%ixdefine}.
946 They work almost the same way as \c{%define} and \c{%idefine} but expand
947 the definition immediately, not on the invocation. Something like a cross
948 between \c{%define} and \c{%assign}. The "x" suffix stands for "eXpand", so
949 "xdefine" can be deciphered as "expand-and-define". Thus you can do
950 things like this:
951
952 \c      %assign ofs     0
953 \c
954 \c      %macro  arg     1
955 \c              %xdefine %1 dword [esp+ofs]
956 \c              %assign ofs ofs+4
957 \c      %endmacro
958
959 \b Changed the place where the expansion of %$name macros are expanded.
960 Now they are converted into ..@ctxnum.name form when detokenizing, so
961 there are no quirks as before when using %$name arguments to macros,
962 in macros etc. For example:
963
964 \c      %macro  abc     1
965 \c              %define %1 hello
966 \c      %endm
967 \c
968 \c      abc     %$here
969 \c      %$here
970
971     Now last line will be expanded into "hello" as expected. This also allows
972     for lots of goodies, a good example are extended "proc" macros included
973     in this archive.
974
975 \b Added a check for "cstk" in smacro_defined() before calling get_ctx() -
976     this allows for things like:
977
978 \c      %ifdef %$abc
979 \c      %endif
980
981     to work without warnings even in no context.
982
983 \b Added a check for "cstk" in %if*ctx and %elif*ctx directives -
984     this allows to use \c{%ifctx} without excessive warnings. If there is
985     no active context, \c{%ifctx} goes through "false" branch.
986
987 \b Removed "user error: " prefix with \c{%error} directive: it just clobbers the
988     output and has absolutely no functionality. Besides, this allows to write
989     macros that does not differ from built-in functions in any way.
990
991 \b Added expansion of string that is output by \c{%error} directive. Now you
992     can do things like:
993
994 \c      %define hello(x) Hello, x!
995 \c
996 \c      %define %$name andy
997 \c      %error "hello(%$name)"
998
999     Same happened with \c{%include} directive.
1000
1001 \b Now all directives that expect an identifier will try to expand and
1002     concatenate everything without whitespaces in between before usage.
1003     For example, with "unfixed" nasm the commands
1004
1005 \c      %define %$abc hello
1006 \c      %define __%$abc goodbye
1007 \c      __%$abc
1008
1009     would produce "incorrect" output: last line will expand to
1010
1011 \c      hello goodbyehello
1012
1013     Not quite what you expected, eh? :-) The answer is that preprocessor
1014     treats the \c{%define} construct as if it would be
1015
1016 \c      %define __ %$abc goodbye
1017
1018     (note the white space between __ and %$abc). After my "fix" it
1019     will "correctly" expand into
1020
1021 \c      goodbye
1022
1023     as expected. Note that I use quotes around words "correct", "incorrect"
1024     etc because this is rather a feature not a bug; however current behaviour
1025     is more logical (and allows more advanced macro usage :-).
1026
1027     Same change was applied to:
1028         \c{%push},\c{%macro},\c{%imacro},\c{%define},\c{%idefine},\c{%xdefine},\c{%ixdefine},
1029         \c{%assign},\c{%iassign},\c{%undef}
1030
1031 \b A new directive [WARNING {+|-}warning-id] have been added. It works only
1032     if the assembly phase is enabled (i.e. it doesn't work with nasm -e).
1033
1034 \b A new warning type: macro-selfref. By default this warning is disabled;
1035     when enabled NASM warns when a macro self-references itself; for example
1036     the following source:
1037
1038 \c        [WARNING macro-selfref]
1039 \c
1040 \c        %macro          push    1-*
1041 \c                %rep    %0
1042 \c                        push    %1
1043 \c                        %rotate 1
1044 \c                %endrep
1045 \c        %endmacro
1046 \c
1047 \c                        push    eax,ebx,ecx
1048
1049     will produce a warning, but if we remove the first line we won't see it
1050     anymore (which is The Right Thing To Do {tm} IMHO since C preprocessor
1051     eats such constructs without warnings at all).
1052
1053 \b Added a "error" routine to preprocessor which always will set ERR_PASS1
1054     bit in severity_code. This removes annoying repeated errors on first
1055     and second passes from preprocessor.
1056
1057 \b Added the %+ operator in single-line macros for concatenating two
1058     identifiers. Usage example:
1059
1060 \c        %define _myfunc _otherfunc
1061 \c        %define cextern(x) _ %+ x
1062 \c        cextern (myfunc)
1063
1064     After first expansion, third line will become "_myfunc". After this
1065     expansion is performed again so it becomes "_otherunc".
1066
1067 \b Now if preprocessor is in a non-emitting state, no warning or error
1068     will be emitted. Example:
1069
1070 \c        %if 1
1071 \c                mov     eax,ebx
1072 \c        %else
1073 \c                put anything you want between these two brackets,
1074 \c                even macro-parameter references %1 or local
1075 \c                labels %$zz or macro-local labels %%zz - no
1076 \c                warning will be emitted.
1077 \c        %endif
1078
1079 \b Context-local variables on expansion as a last resort are looked up
1080     in outer contexts. For example, the following piece:
1081
1082 \c        %push   outer
1083 \c        %define %$a [esp]
1084 \c
1085 \c                %push   inner
1086 \c                %$a
1087 \c                %pop
1088 \c        %pop
1089
1090     will expand correctly the fourth line to [esp]; if we'll define another
1091     %$a inside the "inner" context, it will take precedence over outer
1092     definition. However, this modification has been applied only to
1093     expand_smacro and not to smacro_define: as a consequence expansion
1094     looks in outer contexts, but \c{%ifdef} won't look in outer contexts.
1095
1096     This behaviour is needed because we don't want nested contexts to
1097     act on already defined local macros. Example:
1098
1099 \c        %define %$arg1  [esp+4]
1100 \c        test    eax,eax
1101 \c        if      nz
1102 \c                mov     eax,%$arg1
1103 \c        endif
1104
1105     In this example the "if" mmacro enters into the "if" context, so %$arg1
1106     is not valid anymore inside "if". Of course it could be worked around
1107     by using explicitely %$$arg1 but this is ugly IMHO.
1108
1109 \b Fixed memory leak in \c{%undef}. The origline wasn't freed before
1110     exiting on success.
1111
1112 \b Fixed trap in preprocessor when line expanded to empty set of tokens.
1113     This happens, for example, in the following case:
1114
1115 \c        #define SOMETHING
1116 \c        SOMETHING
1117
1118
1119 \S{cl-0.98} Version 0.98
1120
1121 All changes since NASM 0.98p3 have been produced by H. Peter Anvin <hpa@zytor.com>.
1122
1123 \b The documentation comment delimiter is \# not #.
1124
1125 \b Allow EQU definitions to refer to external labels; reported by
1126   Pedro Gimeno.
1127
1128 \b Re-enable support for RDOFF v1; reported by Pedro Gimeno.
1129
1130 \b Updated License file per OK from Simon and Julian.
1131
1132
1133 \S{cl-0.98p9} Version 0.98p9
1134
1135 \b Update documentation (although the instruction set reference will
1136   have to wait; I don't want to hold up the 0.98 release for it.)
1137
1138 \b Verified that the NASM implementation of the PEXTRW and PMOVMSKB
1139   instructions is correct.  The encoding differs from what the Intel
1140   manuals document, but the Pentium III behaviour matches NASM, not
1141   the Intel manuals.
1142
1143 \b Fix handling of implicit sizes in PSHUFW and PINSRW, reported by
1144   Stefan Hoffmeister.
1145
1146 \b Resurrect the -s option, which was removed when changing the
1147   diagnostic output to stdout.
1148
1149
1150 \S{cl-0.98p8} Version 0.98p8
1151
1152 \b Fix for "DB" when NASM is running on a bigendian machine.
1153
1154 \b Invoke insns.pl once for each output script, making Makefile.in
1155   legal for "make -j".
1156
1157 \b Improve the Unix configure-based makefiles to make package
1158   creation easier.
1159
1160 \b Included an RPM .spec file for building RPM (RedHat Package Manager)
1161   packages on Linux or Unix systems.
1162
1163 \b Fix Makefile dependency problems.
1164
1165 \b Change src/rdsrc.pl to include sectioning information in info
1166   output; required for install-info to work.
1167
1168 \b Updated the RDOFF distribution to version 2 from Jules; minor
1169   massaging to make it compile in my environment.
1170
1171 \b Split doc files that can be built by anyone with a Perl interpreter off
1172   into a separate archive.
1173
1174 \b "Dress rehearsal" release!
1175
1176
1177 \S{cl-0.98p7} Version 0.98p7
1178
1179 \b Fixed opcodes with a third byte-sized immediate argument to not
1180   complain if given "byte" on the immediate.
1181
1182 \b Allow \c{%undef} to remove single-line macros with arguments.  This
1183   matches the behaviour of #undef in the C preprocessor.
1184
1185 \b Allow -d, -u, -i and -p to be specified as -D, -U, -I and -P for
1186   compatibility with most C compilers and preprocessors.  This allows
1187   Makefile options to be shared between cc and nasm, for example.
1188
1189 \b Minor cleanups.
1190
1191 \b Went through the list of Katmai instructions and hopefully fixed the
1192   (rather few) mistakes in it.
1193
1194 \b (Hopefully) fixed a number of disassembler bugs related to ambiguous
1195   instructions (disambiguated by -p) and SSE instructions with REP.
1196
1197 \b Fix for bug reported by Mark Junger: "call dword 0x12345678" should
1198   work and may add an OSP (affected CALL, JMP, Jcc).
1199
1200 \b Fix for environments when "stderr" isn't a compile-time constant.
1201
1202
1203 \S{cl-0.98p6} Version 0.98p6
1204
1205
1206 \b Took officially over coordination of the 0.98 release; so drop
1207   the p3.x notation. Skipped p4 and p5 to avoid confusion with John
1208   Fine's J4 and J5 releases.
1209
1210 \b Update the documentation; however, it still doesn't include
1211   documentation for the various new instructions.  I somehow wonder if
1212   it makes sense to have an instruction set reference in the assembler
1213   manual when Intel et al have PDF versions of their manuals online.
1214
1215 \b Recognize "idt" or "centaur" for the -p option to ndisasm.
1216
1217 \b Changed error messages back to stderr where they belong, but add an
1218   -E option to redirect them elsewhere (the DOS shell cannot redirect
1219   stderr.)
1220
1221 \b -M option to generate Makefile dependencies (based on code from Alex
1222   Verstak.)
1223
1224 \b \c{%undef} preprocessor directive, and -u option, that undefines a
1225   single-line macro.
1226
1227 \b OS/2 Makefile (Mkfiles/Makefile.os2) for Borland under OS/2; from
1228   Chuck Crayne.
1229
1230 \b Various minor bugfixes (reported by):
1231   - Dangling \c{%s} in preproc.c (Martin Junker)
1232
1233 \b THERE ARE KNOWN BUGS IN SSE AND THE OTHER KATMAI INSTRUCTIONS.  I am
1234   on a trip and didn't bring the Katmai instruction reference, so I
1235   can't work on them right now.
1236
1237 \b Updated the License file per agreement with Simon and Jules to
1238   include a GPL distribution clause.
1239
1240
1241 \S{cl-0.98p3.7} Version 0.98p3.7
1242
1243 \b (Hopefully) fixed the canned Makefiles to include the outrdf2 and
1244   zoutieee modules.
1245
1246 \b Renamed changes.asm to changed.asm.
1247
1248
1249 \S{cl-0.98p3.6} Version 0.98p3.6
1250
1251 \b Fixed a bunch of instructions that were added in 0.98p3.5 which had
1252   memory operands, and the address-size prefix was missing from the
1253   instruction pattern.
1254
1255
1256 \S{cl-0.98p3.5} Version 0.98p3.5
1257
1258 \b Merged in changes from John S. Fine's 0.98-J5 release.  John's based
1259   0.98-J5 on my 0.98p3.3 release; this merges the changes.
1260
1261 \b Expanded the instructions flag field to a long so we can fit more
1262   flags; mark SSE (KNI) and AMD or Katmai-specific instructions as
1263   such.
1264
1265 \b Fix the "PRIV" flag on a bunch of instructions, and create new
1266   "PROT" flag for protected-mode-only instructions (orthogonal to if
1267   the instruction is privileged!) and new "SMM" flag for SMM-only
1268   instructions.
1269
1270 \b Added AMD-only SYSCALL and SYSRET instructions.
1271
1272 \b Make SSE actually work, and add new Katmai MMX instructions.
1273
1274 \b Added a -p (preferred vendor) option to ndisasm so that it can
1275   distinguish e.g. Cyrix opcodes also used in SSE.  For example:
1276
1277 \c      ndisasm -p cyrix aliased.bin
1278 \c      00000000  670F514310        paddsiw mm0,[ebx+0x10]
1279 \c      00000005  670F514320        paddsiw mm0,[ebx+0x20]
1280 \c      ndisasm -p intel aliased.bin
1281 \c      00000000  670F514310        sqrtps xmm0,[ebx+0x10]
1282 \c      00000005  670F514320        sqrtps xmm0,[ebx+0x20]
1283
1284 \b Added a bunch of Cyrix-specific instructions.
1285
1286
1287 \S{cl-0.98p3.4} Version 0.98p3.4
1288
1289 \b Made at least an attempt to modify all the additional Makefiles (in
1290   the Mkfiles directory).  I can't test it, but this was the best I
1291   could do.
1292
1293 \b DOS DJGPP+"Opus Make" Makefile from John S. Fine.
1294
1295 \b changes.asm changes from John S. Fine.
1296
1297
1298 \S{cl-0.98p3.3} Version 0.98p3.3
1299
1300 \b Patch from Conan Brink to allow nesting of \c{%rep} directives.
1301
1302 \b If we're going to allow INT01 as an alias for INT1/ICEBP (one of
1303   Jules 0.98p3 changes), then we should allow INT03 as an alias for INT3
1304   as well.
1305
1306 \b Updated changes.asm to include the latest changes.
1307
1308 \b Tried to clean up the <CR>s that had snuck in from a DOS/Windows
1309   environment into my Unix environment, and try to make sure than
1310   DOS/Windows users get them back.
1311
1312 \b We would silently generate broken tools if insns.dat wasn't sorted
1313   properly.  Change insns.pl so that the order doesn't matter.
1314
1315 \b Fix bug in insns.pl (introduced by me) which would cause conditional
1316   instructions to have an extra "cc" in disassembly, e.g. "jnz"
1317   disassembled as "jccnz".
1318
1319
1320 \S{cl-0.98p3.2} Version 0.98p3.2
1321
1322 \b Merged in John S. Fine's changes from his 0.98-J4 prerelease; see
1323   http://www.csoft.net/cz/johnfine/
1324
1325 \b Changed previous "spotless" Makefile target (appropriate for distribution)
1326   to "distclean", and added "cleaner" target which is same as "clean"
1327   except deletes files generated by Perl scripts; "spotless" is union.
1328
1329 \b Removed BASIC programs from distribution.  Get a Perl interpreter
1330   instead (see below.)
1331
1332 \b Calling this "pre-release 3.2" rather than "p3-hpa2" because of
1333   John's contributions.
1334
1335 \b Actually link in the IEEE output format (zoutieee.c); fix a bunch of
1336   compiler warnings in that file.  Note I don't know what IEEE output
1337   is supposed to look like, so these changes were made "blind".
1338
1339
1340 \S{cl-0.98p3-hpa} Version 0.98p3-hpa
1341
1342 \b Merged nasm098p3.zip with nasm-0.97.tar.gz to create a fully
1343   buildable version for Unix systems (Makefile.in updates, etc.)
1344
1345 \b Changed insns.pl to create the instruction tables in nasm.h and
1346   names.c, so that a new instruction can be added by adding it *only*
1347   to insns.dat.
1348
1349 \b Added the following new instructions: SYSENTER, SYSEXIT, FXSAVE,
1350   FXRSTOR, UD1, UD2 (the latter two are two opcodes that Intel
1351   guarantee will never be used; one of them is documented as UD2 in
1352   Intel documentation, the other one just as "Undefined Opcode" --
1353   calling it UD1 seemed to make sense.)
1354
1355 \b MAX_SYMBOL was defined to be 9, but LOADALL286 and LOADALL386 are 10
1356   characters long.  Now MAX_SYMBOL is derived from insns.dat.
1357
1358 \b A note on the BASIC programs included: forget them.  insns.bas is
1359   already out of date.  Get yourself a Perl interpreter for your
1360   platform of choice at
1361   \W{http://www.cpan.org/ports/index.html}{http://www.cpan.org/ports/index.html}.
1362
1363
1364 \S{cl-0.98p3} Version 0.98 pre-release 3
1365
1366 \b added response file support, improved command line handling, new layout
1367 help screen
1368
1369 \b fixed limit checking bug, 'OUT byte nn, reg' bug, and a couple of rdoff
1370 related bugs, updated Wishlist; 0.98 Prerelease 3.
1371
1372
1373 \S{cl-0.98p2} Version 0.98 pre-release 2
1374
1375 \b fixed bug in outcoff.c to do with truncating section names longer
1376 than 8 characters, referencing beyond end of string; 0.98 pre-release 2
1377
1378
1379 \S{cl-0.98p1} Version 0.98 pre-release 1
1380
1381 \b Fixed a bug whereby STRUC didn't work at all in RDF.
1382
1383 \b Fixed a problem with group specification in PUBDEFs in OBJ.
1384
1385 \b Improved ease of adding new output formats. Contribution due to
1386 Fox Cutter.
1387
1388 \b Fixed a bug in relocations in the `bin' format: was showing up when
1389 a relocatable reference crossed an 8192-byte boundary in any output
1390 section.
1391
1392 \b Fixed a bug in local labels: local-label lookups were inconsistent
1393 between passes one and two if an EQU occurred between the definition
1394 of a global label and the subsequent use of a local label local to
1395 that global.
1396
1397 \b Fixed a seg-fault in the preprocessor (again) which happened when
1398 you use a blank line as the first line of a multi-line macro
1399 definition and then defined a label on the same line as a call to
1400 that macro.
1401
1402 \b Fixed a stale-pointer bug in the handling of the NASM environment
1403 variable. Thanks to Thomas McWilliams.
1404
1405 \b ELF had a hard limit on the number of sections which caused
1406 segfaults when transgressed. Fixed.
1407
1408 \b Added ability for ndisasm to read from stdin by using `-' as the
1409 filename.
1410
1411 \b ndisasm wasn't outputting the TO keyword. Fixed.
1412
1413 \b Fixed error cascade on bogus expression in \c{%if} - an error in
1414 evaluation was causing the entire \c{%if} to be discarded, thus creating
1415 trouble later when the \c{%else} or \c{%endif} was encountered.
1416
1417 \b Forward reference tracking was instruction-granular not operand-
1418 granular, which was causing 286-specific code to be generated
1419 needlessly on code of the form `shr word [forwardref],1'. Thanks to
1420 Jim Hague for sending a patch.
1421
1422 \b All messages now appear on stdout, as sending them to stderr serves
1423 no useful purpose other than to make redirection difficult.
1424
1425 \b Fixed the problem with EQUs pointing to an external symbol - this
1426 now generates an error message.
1427
1428 \b Allowed multiple size prefixes to an operand, of which only the first
1429 is taken into account.
1430
1431 \b Incorporated John Fine's changes, including fixes of a large number
1432 of preprocessor bugs, some small problems in OBJ, and a reworking of
1433 label handling to define labels before their line is assembled, rather
1434 than after.
1435
1436 \b Reformatted a lot of the source code to be more readable. Included
1437 'coding.txt' as a guideline for how to format code for contributors.
1438
1439 \b Stopped nested \c{%reps} causing a panic - they now cause a slightly more
1440 friendly error message instead.
1441
1442 \b Fixed floating point constant problems (patch by Pedro Gimeno)
1443
1444 \b Fixed the return value of insn_size() not being checked for -1, indicating
1445 an error.
1446
1447 \b Incorporated 3Dnow! instructions.
1448
1449 \b Fixed the 'mov eax, eax + ebx' bug.
1450
1451 \b Fixed the GLOBAL EQU bug in ELF. Released developers release 3.
1452
1453 \b Incorporated John Fine's command line parsing changes
1454
1455 \b Incorporated David Lindauer's OMF debug support
1456
1457 \b Made changes for LCC 4.0 support (\c{__NASM_CDecl__}, removed register size
1458 specification warning when sizes agree).
1459
1460
1461 \H{cl-0.9x} NASM 0.9 Series
1462
1463 Revisions before 0.98.
1464
1465
1466 \S{cl-0.97} Version 0.97 released December 1997
1467
1468 \b This was entirely a bug-fix release to 0.96, which seems to have got
1469 cursed. Silly me.
1470
1471 \b Fixed stupid mistake in OBJ which caused `MOV EAX,<constant>' to
1472 fail. Caused by an error in the `MOV EAX,<segment>' support.
1473
1474 \b ndisasm hung at EOF when compiled with lcc on Linux because lcc on
1475 Linux somehow breaks feof(). ndisasm now does not rely on feof().
1476
1477 \b A heading in the documentation was missing due to a markup error in
1478 the indexing. Fixed.
1479
1480 \b Fixed failure to update all pointers on realloc() within extended-
1481 operand code in parser.c. Was causing wrong behaviour and seg faults
1482 on lines such as `dd 0.0,0.0,0.0,0.0,...'
1483
1484 \b Fixed a subtle preprocessor bug whereby invoking one multi-line
1485 macro on the first line of the expansion of another, when the second
1486 had been invoked with a label defined before it, didn't expand the
1487 inner macro. 
1488
1489 \b Added internal.doc back in to the distribution archives - it was
1490 missing in 0.96 *blush*
1491
1492 \b Fixed bug causing 0.96 to be unable to assemble its own test files,
1493 specifically objtest.asm. *blush again*
1494
1495 \b Fixed seg-faults and bogus error messages caused by mismatching
1496 \c{%rep} and \c{%endrep} within multi-line macro definitions.
1497
1498 \b Fixed a problem with buffer overrun in OBJ, which was causing
1499 corruption at ends of long PUBDEF records.
1500
1501 \b Separated DOS archives into main-program and documentation to reduce
1502 download size.
1503
1504
1505 \S{cl-0.96} Version 0.96 released November 1997
1506
1507 \b Fixed a bug whereby, if `nasm sourcefile' would cause a filename
1508 collision warning and put output into `nasm.out', then `nasm
1509 sourcefile -o outputfile' still gave the warning even though the
1510 `-o' was honoured.
1511 Fixed name pollution under Digital UNIX: one of its header files
1512 defined R_SP, which broke the enum in nasm.h.
1513
1514 \b Fixed minor instruction table problems: FUCOM and FUCOMP didn't have
1515 two-operand forms; NDISASM didn't recognise the longer register
1516 forms of PUSH and POP (eg FF F3 for PUSH BX); TEST mem,imm32 was
1517 flagged as undocumented; the 32-bit forms of CMOV had 16-bit operand
1518 size prefixes; `AAD imm' and `AAM imm' are no longer flagged as
1519 undocumented because the Intel Architecture reference documents
1520 them.
1521
1522 \b Fixed a problem with the local-label mechanism, whereby strange
1523 types of symbol (EQUs, auto-defined OBJ segment base symbols)
1524 interfered with the `previous global label' value and screwed up
1525 local labels.
1526
1527 \b Fixed a bug whereby the stub preprocessor didn't communicate with
1528 the listing file generator, so that the -a and -l options in
1529 conjunction would produce a useless listing file.
1530
1531 \b Merged `os2' object file format back into `obj', after discovering
1532 that `obj' _also_ shouldn't have a link pass separator in a module
1533 containing a non-trivial MODEND. Flat segments are now declared
1534 using the FLAT attribute. `os2' is no longer a valid object format
1535 name: use `obj'.
1536
1537 \b Removed the fixed-size temporary storage in the evaluator. Very very
1538 long expressions (like `mov ax,1+1+1+1+...' for two hundred 1s or
1539 so) should now no longer crash NASM.
1540
1541 \b Fixed a bug involving segfaults on disassembly of MMX instructions,
1542 by changing the meaning of one of the operand-type flags in nasm.h.
1543 This may cause other apparently unrelated MMX problems; it needs to
1544 be tested thoroughly.
1545
1546 \b Fixed some buffer overrun problems with large OBJ output files.
1547 Thanks to DJ Delorie for the bug report and fix.
1548
1549 \b Made preprocess-only mode actually listen to the \c{%line} markers as it
1550 prints them, so that it can report errors more sanely.
1551
1552 \b Re-designed the evaluator to keep more sensible track of expressions
1553 involving forward references: can now cope with previously-nightmare
1554 situations such as:
1555
1556 \c   mov ax,foo | bar
1557 \c   foo equ 1
1558 \c   bar equ 2
1559
1560 \b Added the ALIGN and ALIGNB standard macros.
1561
1562 \b Added PIC support in ELF: use of WRT to obtain the four extra
1563 relocation types needed.
1564
1565 \b Added the ability for output file formats to define their own
1566 extensions to the GLOBAL, COMMON and EXTERN directives.
1567
1568 \b Implemented common-variable alignment, and global-symbol type and
1569 size declarations, in ELF.
1570
1571 \b Implemented NEAR and FAR keywords for common variables, plus
1572 far-common element size specification, in OBJ.
1573
1574 \b Added a feature whereby EXTERNs and COMMONs in OBJ can be given a
1575 default WRT specification (either a segment or a group).
1576
1577 \b Transformed the Unix NASM archive into an auto-configuring package.
1578
1579 \b Added a sanity-check for people applying SEG to things which are
1580 already segment bases: this previously went unnoticed by the SEG
1581 processing and caused OBJ-driver panics later.
1582
1583 \b Added the ability, in OBJ format, to deal with `MOV EAX,<segment>'
1584 type references: OBJ doesn't directly support dword-size segment
1585 base fixups, but as long as the low two bytes of the constant term
1586 are zero, a word-size fixup can be generated instead and it will
1587 work.
1588
1589 \b Added the ability to specify sections' alignment requirements in
1590 Win32 object files and pure binary files.
1591
1592 \b Added preprocess-time expression evaluation: the \c{%assign} (and
1593 \c{%iassign}) directive and the bare \c{%if} (and \c{%elif}) conditional. Added
1594 relational operators to the evaluator, for use only in \c{%if}
1595 constructs: the standard relationals = < > <= >= <> (and C-like
1596 synonyms == and !=) plus low-precedence logical operators &&, ^^ and
1597 ||.
1598
1599 \b Added a preprocessor repeat construct: \c{%rep} / \c{%exitrep} / \c{%endrep}.
1600
1601 \b Added the __FILE__ and __LINE__ standard macros.
1602
1603 \b Added a sanity check for number constants being greater than
1604 0xFFFFFFFF. The warning can be disabled.
1605
1606 \b Added the %0 token whereby a variadic multi-line macro can tell how
1607 many parameters it's been given in a specific invocation.
1608
1609 \b Added \c{%rotate}, allowing multi-line macro parameters to be cycled.
1610
1611 \b Added the `*' option for the maximum parameter count on multi-line
1612 macros, allowing them to take arbitrarily many parameters.
1613
1614 \b Added the ability for the user-level forms of EXTERN, GLOBAL and
1615 COMMON to take more than one argument.
1616
1617 \b Added the IMPORT and EXPORT directives in OBJ format, to deal with
1618 Windows DLLs.
1619
1620 \b Added some more preprocessor \c{%if} constructs: \c{%ifidn} / \c{%ifidni} (exact
1621 textual identity), and \c{%ifid} / \c{%ifnum} / \c{%ifstr} (token type testing).
1622
1623 \b Added the ability to distinguish SHL AX,1 (the 8086 version) from
1624 SHL AX,BYTE 1 (the 286-and-upwards version whose constant happens to
1625 be 1).
1626
1627 \b Added NetBSD/FreeBSD/OpenBSD's variant of a.out format, complete
1628 with PIC shared library features.
1629
1630 \b Changed NASM's idiosyncratic handling of FCLEX, FDISI, FENI, FINIT,
1631 FSAVE, FSTCW, FSTENV, and FSTSW to bring it into line with the
1632 otherwise accepted standard. The previous behaviour, though it was a
1633 deliberate feature, was a deliberate feature based on a
1634 misunderstanding. Apologies for the inconvenience.
1635
1636 \b Improved the flexibility of ABSOLUTE: you can now give it an
1637 expression rather than being restricted to a constant, and it can
1638 take relocatable arguments as well.
1639
1640 \b Added the ability for a variable to be declared as EXTERN multiple
1641 times, and the subsequent definitions are just ignored.
1642
1643 \b We now allow instruction prefixes (CS, DS, LOCK, REPZ etc) to be
1644 alone on a line (without a following instruction).
1645
1646 \b Improved sanity checks on whether the arguments to EXTERN, GLOBAL
1647 and COMMON are valid identifiers.
1648
1649 \b Added misc/exebin.mac to allow direct generation of .EXE files by
1650 hacking up an EXE header using DB and DW; also added test/binexe.asm
1651 to demonstrate the use of this. Thanks to Yann Guidon for
1652 contributing the EXE header code.
1653
1654 \b ndisasm forgot to check whether the input file had been successfully
1655 opened. Now it does. Doh!
1656
1657 \b Added the Cyrix extensions to the MMX instruction set.
1658
1659 \b Added a hinting mechanism to allow [EAX+EBX] and [EBX+EAX] to be
1660 assembled differently. This is important since [ESI+EBP] and
1661 [EBP+ESI] have different default base segment registers.
1662
1663 \b Added support for the PharLap OMF extension for 4096-byte segment
1664 alignment.
1665
1666
1667 \S{cl-0.95 released July 1997} Version 0.95 released July 1997
1668
1669 \b Fixed yet another ELF bug. This one manifested if the user relied on
1670 the default segment, and attempted to define global symbols without
1671 first explicitly declaring the target segment.
1672
1673 \b Added makefiles (for NASM and the RDF tools) to build Win32 console
1674 apps under Symantec C++. Donated by Mark Junker.
1675
1676 \b Added `macros.bas' and `insns.bas', QBasic versions of the Perl
1677 scripts that convert `standard.mac' to `macros.c' and convert
1678 `insns.dat' to `insnsa.c' and `insnsd.c'. Also thanks to Mark
1679 Junker.
1680
1681 \b Changed the diassembled forms of the conditional instructions so
1682 that JB is now emitted as JC, and other similar changes. Suggested
1683 list by Ulrich Doewich.
1684
1685 \b Added `@' to the list of valid characters to begin an identifier
1686 with.
1687
1688 \b Documentary changes, notably the addition of the `Common Problems'
1689 section in nasm.doc.
1690
1691 \b Fixed a bug relating to 32-bit PC-relative fixups in OBJ.
1692
1693 \b Fixed a bug in perm_copy() in labels.c which was causing exceptions
1694 in cleanup_labels() on some systems.
1695
1696 \b Positivity sanity check in TIMES argument changed from a warning to
1697 an error following a further complaint.
1698
1699 \b Changed the acceptable limits on byte and word operands to allow
1700 things like `~10111001b' to work.
1701
1702 \b Fixed a major problem in the preprocessor which caused seg-faults if
1703 macro definitions contained blank lines or comment-only lines.
1704
1705 \b Fixed inadequate error checking on the commas separating the
1706 arguments to `db', `dw' etc.
1707
1708 \b Fixed a crippling bug in the handling of macros with operand counts
1709 defined with a `+' modifier.
1710
1711 \b Fixed a bug whereby object file formats which stored the input file
1712 name in the output file (such as OBJ and COFF) weren't doing so
1713 correctly when the output file name was specified on the command
1714 line.
1715
1716 \b Removed [INC] and [INCLUDE] support for good, since they were
1717 obsolete anyway.
1718
1719 \b Fixed a bug in OBJ which caused all fixups to be output in 16-bit
1720 (old-format) FIXUPP records, rather than putting the 32-bit ones in
1721 FIXUPP32 (new-format) records.
1722
1723 \b Added, tentatively, OS/2 object file support (as a minor variant on
1724 OBJ).
1725
1726 \b Updates to Fox Cutter's Borland C makefile, Makefile.bc2.
1727
1728 \b Removed a spurious second fclose() on the output file.
1729
1730 \b Added the `-s' command line option to redirect all messages which
1731 would go to stderr (errors, help text) to stdout instead.
1732
1733 \b Added the `-w' command line option to selectively suppress some
1734 classes of assembly warning messages.
1735
1736 \b Added the `-p' pre-include and `-d' pre-define command-line options.
1737
1738 \b Added an include file search path: the `-i' command line option.
1739
1740 \b Fixed a silly little preprocessor bug whereby starting a line with a
1741 `%!' environment-variable reference caused an `unknown directive'
1742 error.
1743
1744 \b Added the long-awaited listing file support: the `-l' command line
1745 option.
1746
1747 \b Fixed a problem with OBJ format whereby, in the absence of any
1748 explicit segment definition, non-global symbols declared in the
1749 implicit default segment generated spurious EXTDEF records in the
1750 output.
1751
1752 \b Added the NASM environment variable.
1753
1754 \b From this version forward, Win32 console-mode binaries will be
1755 included in the DOS distribution in addition to the 16-bit binaries.
1756 Added Makefile.vc for this purpose.
1757
1758 \b Added `return 0;' to test/objlink.c to prevent compiler warnings.
1759
1760 \b Added the __NASM_MAJOR__ and __NASM_MINOR__ standard defines.
1761
1762 \b Added an alternative memory-reference syntax in which prefixing an
1763 operand with `&' is equivalent to enclosing it in square brackets,
1764 at the request of Fox Cutter.
1765
1766 \b Errors in pass two now cause the program to return a non-zero error
1767 code, which they didn't before.
1768
1769 \b Fixed the single-line macro cycle detection, which didn't work at
1770 all on macros with no parameters (caused an infinite loop). Also
1771 changed the behaviour of single-line macro cycle detection to work
1772 like cpp, so that macros like `extrn' as given in the documentation
1773 can be implemented.
1774
1775 \b Fixed the implementation of WRT, which was too restrictive in that
1776 you couldn't do `mov ax,[di+abc wrt dgroup]' because (di+abc) wasn't
1777 a relocatable reference.
1778
1779
1780 \S{cl-0.94 released April 1997} Version 0.94 released April 1997
1781
1782
1783 \b Major item: added the macro processor.
1784
1785 \b Added undocumented instructions SMI, IBTS, XBTS and LOADALL286. Also
1786 reorganised CMPXCHG instruction into early-486 and Pentium forms.
1787 Thanks to Thobias Jones for the information.
1788
1789 \b Fixed two more stupid bugs in ELF, which were causing `ld' to
1790 continue to seg-fault in a lot of non-trivial cases.
1791
1792 \b Fixed a seg-fault in the label manager.
1793
1794 \b Stopped FBLD and FBSTP from _requiring_ the TWORD keyword, which is
1795 the only option for BCD loads/stores in any case.
1796
1797 \b Ensured FLDCW, FSTCW and FSTSW can cope with the WORD keyword, if
1798 anyone bothers to provide it. Previously they complained unless no
1799 keyword at all was present.
1800
1801 \b Some forms of FDIV/FDIVR and FSUB/FSUBR were still inverted: a
1802 vestige of a bug that I thought had been fixed in 0.92. This was
1803 fixed, hopefully for good this time...
1804
1805 \b Another minor phase error (insofar as a phase error can _ever_ be
1806 minor) fixed, this one occurring in code of the form
1807
1808 \c   rol ax,forward_reference
1809 \c   forward_reference equ 1
1810
1811 \b The number supplied to TIMES is now sanity-checked for positivity,
1812 and also may be greater than 64K (which previously didn't work on
1813 16-bit systems).
1814
1815 \b Added Watcom C makefiles, and misc/pmw.bat, donated by Dominik Behr.
1816
1817 \b Added the INCBIN pseudo-opcode.
1818
1819 \b Due to the advent of the preprocessor, the [INCLUDE] and [INC]
1820 directives have become obsolete. They are still supported in this
1821 version, with a warning, but won't be in the next.
1822
1823 \b Fixed a bug in OBJ format, which caused incorrect object records to
1824 be output when absolute labels were made global.
1825
1826 \b Updates to RDOFF subdirectory, and changes to outrdf.c.
1827
1828
1829 \S{cl-0.93 released January 1997} Version 0.93 released January 1997
1830
1831 This release went out in a great hurry after semi-crippling bugs
1832 were found in 0.92.
1833
1834 \b Really \e{did} fix the stack overflows this time. *blush*
1835
1836 \b Had problems with EA instruction sizes changing between passes, when
1837 an offset contained a forward reference and so 4 bytes were
1838 allocated for the offset in pass one; by pass two the symbol had
1839 been defined and happened to be a small absolute value, so only 1
1840 byte got allocated, causing instruction size mismatch between passes
1841 and hence incorrect address calculations. Fixed.
1842
1843 \b Stupid bug in the revised ELF section generation fixed (associated
1844 string-table section for .symtab was hard-coded as 7, even when this
1845 didn't fit with the real section table). Was causing `ld' to
1846 seg-fault under Linux.
1847
1848 \b Included a new Borland C makefile, Makefile.bc2, donated by Fox
1849 Cutter <lmb@comtch.iea.com>.
1850
1851
1852 \S{cl-0.92 released January 1997} Version 0.92 released January 1997
1853
1854 \b The FDIVP/FDIVRP and FSUBP/FSUBRP pairs had been inverted: this was
1855 fixed. This also affected the LCC driver.
1856
1857 \b Fixed a bug regarding 32-bit effective addresses of the form
1858 \c{[other_register+ESP]}.
1859
1860 \b Documentary changes, notably documentation of the fact that Borland
1861 Win32 compilers use `obj' rather than `win32' object format.
1862
1863 \b Fixed the COMENT record in OBJ files, which was formatted
1864 incorrectly.
1865
1866 \b Fixed a bug causing segfaults in large RDF files.
1867
1868 \b OBJ format now strips initial periods from segment and group
1869 definitions, in order to avoid complications with the local label
1870 syntax.
1871
1872 \b Fixed a bug in disassembling far calls and jumps in NDISASM.
1873
1874 \b Added support for user-defined sections in COFF and ELF files.
1875
1876 \b Compiled the DOS binaries with a sensible amount of stack, to
1877 prevent stack overflows on any arithmetic expression containing
1878 parentheses.
1879
1880 \b Fixed a bug in handling of files that do not terminate in a newline.
1881
1882
1883 \S{cl-0.91 released November 1996} Version 0.91 released November 1996
1884
1885 \b Loads of bug fixes.
1886
1887 \b Support for RDF added.
1888
1889 \b Support for DBG debugging format added.
1890
1891 \b Support for 32-bit extensions to Microsoft OBJ format added.
1892
1893 \b Revised for Borland C: some variable names changed, makefile added.
1894
1895 \b LCC support revised to actually work.
1896
1897 \b JMP/CALL NEAR/FAR notation added.
1898
1899 \b `a16', `o16', `a32' and `o32' prefixes added.
1900
1901 \b Range checking on short jumps implemented.
1902
1903 \b MMX instruction support added.
1904
1905 \b Negative floating point constant support added.
1906
1907 \b Memory handling improved to bypass 64K barrier under DOS.
1908
1909 \b \c{$} prefix to force treatment of reserved words as identifiers added.
1910
1911 \b Default-size mechanism for object formats added.
1912
1913 \b Compile-time configurability added.
1914
1915 \b \c{#}, \c{@}, \c{~} and c\{?} are now valid characters in labels.
1916
1917 \b \c{-e} and \c{-k} options in NDISASM added.
1918
1919
1920 \S{cl-0.90 released October 1996} Version 0.90 released October 1996
1921
1922 First release version. First support for object file output. Other
1923 changes from previous version (0.3x) too numerous to document.