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