blob: ffbcda0dd9730d5da8d6b9d76138d85f7bb1329c [file] [log] [blame]
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001\#
2\# NASM revision history in nasmdoc format
3\#
4
5\H{cl-2.xx} NASM 2 Series
6
H. Peter Anvine55e53d2012-09-09 16:30:07 -07007The NASM 2 series supports x86-64, and is the production version of NASM
H. Peter Anvin04156cd2008-07-14 02:45:57 -04008since 2007.
9
H. Peter Anvinbf6230b2018-11-11 13:25:16 -080010\S{cl-2.14.01} Version 2.14.01
11
12\b Create all system-defined macros defore processing command-line
13given preprocessing directives (\c{-p}, \c{-d}, \c{-u}, \c{--pragma},
14\c{--before}).
15
16\b If debugging is enabled, define a \c{__DEBUG_FORMAT__} predefined
17macro. See \k{dfmtm}.
18
H. Peter Anvin88959912018-11-26 14:38:32 -080019\b Fix an assert for the case in the \c{obj} format when a \c{SEG}
20operator refers to an \c{EXTERN} symbol declared further down in the
21code.
22
H. Peter Anvind7498062018-11-26 21:38:14 -080023\b Fix a corner case in the floating-point code where a binary, octal
H. Peter Anvinc06c87d2018-11-28 09:50:14 -080024or hexadecimal floating-point having at least 32, 11, or 8 mantissa
25digits could produce slightly incorrect results under very specific
26conditions.
H. Peter Anvin88959912018-11-26 14:38:32 -080027
Chang S. Baeef219262018-06-20 17:05:14 -070028\S{cl-2.14} Version 2.14
29
H. Peter Anvinbf6230b2018-11-11 13:25:16 -080030\b Changed \c{-I} option semantics by adding a trailing path separator
31 unconditionally.
Cyrill Gorcunov0e7f5112018-10-21 15:45:02 +030032
Cyrill Gorcunov1cbd48a2018-10-14 21:09:30 +030033\b Fixed null dereference in corrupted invalid single line macros.
34
35\b Fixed division by zero which may happen if source code is malformed.
36
Cyrill Gorcunovd94402d2018-10-13 23:03:24 +030037\b Fixed out of bound access in processing of malformed segment override.
38
Cyrill Gorcunova98a84b2018-10-13 18:15:36 +030039\b Fixed out of bound access in certain \c{EQU} parsing.
40
Cyrill Gorcunov10c0f662018-09-23 23:30:44 +030041\b Fixed buffer underflow in float parsing.
42
43\b Added \c{SGX} (Intel Software Guard Extensions) instructions.
44
45\b Added \c{+n} syntax for multiple contiguous registers.
46
Chang S. Baeef219262018-06-20 17:05:14 -070047\b Fixed \c{subsections_via_symbols} for \c{macho} object format.
48
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070049\b Added the \c{--gprefix}, \c{--gpostfix}, \c{--lprefix}, and
50\c{--lpostfix} command line options, to allow command line base symbol
H. Peter Anvin (Intel)d5585982018-06-25 18:19:15 -070051renaming. See \k{opt-pfix}.
52
53\b Allow label renaming to be specified by \c{%pragma} in addition to
54from the command line. See \k{mangling}.
Chang S. Baeef219262018-06-20 17:05:14 -070055
56\b Supported generic \c{%pragma} namespaces, \c{output} and \c{debug}. See
57\k{gen-namespace}.
58
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070059\b Added the \c{--pragma} command line option to inject a \c{%pragma}
60directive. See \k{opt-pragma}.
Chang S. Baeef219262018-06-20 17:05:14 -070061
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070062\b Added the \c{--before} command line option to accept preprocess
63statement before input. See \k{opt-before}.
Chang S. Baeef219262018-06-20 17:05:14 -070064
65\b Added \c{AVX512} \c{VBMI2} (Additional Bit Manipulation), \c{VNNI} (Vector
66Neural Network), \c{BITALG} (Bit Algorithm), and \c{GFNI} (Galois Field New
67Instruction) instructions.
68
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070069\b Added the \c{STATIC} directive for local symbols that should be
70renamed using global-symbol rules. See \k{static}.
Chang S. Baeef219262018-06-20 17:05:14 -070071
H. Peter Anvin (Intel)d5585982018-06-25 18:19:15 -070072\b Allow a symbol to be defined as \c{EXTERN} and then later
73overridden as \c{GLOBAL} or \c{COMMON}. Furthermore, a symbol declared
74\c{EXTERN} and then defined will be treated as \c{GLOBAL}. See \k{extern}.
75
76\b The \c{GLOBAL} directive no longer is required to precede the
77definition of the symbol.
78
Chang S. Baeef219262018-06-20 17:05:14 -070079\b Support \c{private_extern} as \c{macho} specific extension to the
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070080\c{GLOBAL} directive. See \k{macho-pext}.
Chang S. Baeef219262018-06-20 17:05:14 -070081
82\b Updated \c{UD0} encoding to match with the specification
83
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070084\b Added the \c{--limit-X} command line option to set execution
85limits. See \k{opt-limit}.
Chang S. Baeef219262018-06-20 17:05:14 -070086
H. Peter Anvin (Intel)d5585982018-06-25 18:19:15 -070087\b Updated the \c{Codeview} version number to be aligned with \c{MASM}.
Chang S. Baeef219262018-06-20 17:05:14 -070088
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070089\b Added the \c{--keep-all} command line option to preserve output
90files. See \k{opt-keep-all}.
Chang S. Baeef219262018-06-20 17:05:14 -070091
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070092\b Added the \c{--include} command line option, an alias to \c{-P} (\k{opt-p}).
Chang S. Baeef219262018-06-20 17:05:14 -070093
H. Peter Anvin (Intel)b6b4b5d2018-06-25 14:19:39 -070094\b Added the \c{--help} command line option as an alias to \c{-h} (\k{syntax}).
H. Peter Anvin8524e162018-02-14 11:09:07 -080095
96\b Added \c{-W}, \c{-D}, and \c{-Q} suffix aliases for \c{RET}
97 instructions so the operand sizes of these instructions can be
98 encoded without using \c{o16}, \c{o32} or \c{o64}.
99
H. Peter Anvin0c2da082018-01-08 12:59:26 -0800100\S{cl-2.13.03} Version 2.13.03
101
102\b Added AVX and AVX512 \c{VAES*} and \c{VPCLMULQDQ} instructions.
H. Peter Anvin73c804c2018-02-07 10:52:50 -0800103
Cyrill Gorcunov92543232018-02-05 20:13:44 +0300104\b Fixed missing dwarf record in x32 ELF output format.
H. Peter Anvin0c2da082018-01-08 12:59:26 -0800105
H. Peter Anvin77c9bf62017-08-16 21:14:33 -0700106\S{cl-2.13.02} Version 2.13.02
107
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300108\b Fix false positive in testing of numeric overflows.
109
Cyrill Gorcunov8e2307c2017-11-25 17:42:45 +0300110\b Fix generation of \c{PEXTRW} instruction.
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300111
H. Peter Anvin075ebe72017-11-29 11:23:08 -0800112\b Fix \c{smartalign} package which could trigger an error during
113 optimization if the alignment code expanded too much due to
114 optimization of the previous code.
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300115
116\b Fix a case where negative value in \c{TIMES} directive causes
H. Peter Anvin075ebe72017-11-29 11:23:08 -0800117 panic instead of an error.
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300118
119\b Always finalize \c{.debug_abbrev} section with a null in
120 \c{dwarf} output format.
121
122\b Support \c{debug} flag in section attributes for \c{macho}
H. Peter Anvin075ebe72017-11-29 11:23:08 -0800123 output format. See \k{machosect}.
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300124
125\b Support up to 16 characters in section names for \c{macho}
126 output format.
127
128\b Fix missing update of global \c{BITS} setting if \c{SECTION}
H. Peter Anvin23b971d2017-11-29 11:05:02 -0800129 directive specified a bit size using output format-specific
130 extensions (e.g. \c{USE32} for the \c{obj} output format.)
Cyrill Gorcunov4c171ce2017-11-25 17:41:38 +0300131
H. Peter Anvinf275ce92017-08-16 22:36:32 -0700132\b Fix the incorrect generation of VEX-encoded instruction when static
133 mode decorators are specified on scalar instructions, losing the
134 decorators as they require EVEX encoding.
135
H. Peter Anvin77c9bf62017-08-16 21:14:33 -0700136\b Option \c{-MW} to quote dependency outputs according to Watcom
H. Peter Anvinf275ce92017-08-16 22:36:32 -0700137 Make conventions instead of POSIX Make conventions. See \k{opt-MW}.
138
139\b The \c{obj} output format now contains embedded dependency file
140 information, unless disabled with \c{%pragma obj nodepend}. See
141 \k{objdepend}.
142
143\b Fix generation of dependency lists.
144
H. Peter Anvin075ebe72017-11-29 11:23:08 -0800145\b Fix a number of null pointer reference and memory allocation errors.
H. Peter Anvinf275ce92017-08-16 22:36:32 -0700146
147\b Always generate symbol-relative relocations for the \c{macho64}
148 output format; at least some versions of the XCode/LLVM linker fails
149 for section-relative relocations.
H. Peter Anvin77c9bf62017-08-16 21:14:33 -0700150
H. Peter Anvin3301ee82017-05-01 15:41:30 -0700151\S{cl-2.13.01} Version 2.13.01
152
153\b Fix incorrect output for some types of \c{FAR} or \c{SEG}
154 references in the \c{obj} output format, and possibly other 16-bit
155 output formats.
156
157\b Fix the address in the list file for an instruction containing a
158 \c{TIMES} directive.
159
H. Peter Anvin4892f952017-05-01 21:16:21 -0700160\b Fix error with \c{TIMES} used together with an instruction which
161 can vary in size, e.g. \c{JMP}.
162
163\b Fix breakage on some uses of the \c{DZ} pseudo-op.
164
H. Peter Anvinf805cde2017-02-23 17:19:56 -0800165\S{cl-2.13} Version 2.13
166
167\b Support the official forms of the \c{UD0} and \c{UD1} instructions.
168
169\b Allow self-segment-relative expressions in immediates and
170 displacements, even when combined with an external or otherwise
171 out-of-segment special symbol, e.g.:
172
173\c extern foo
174\c mov eax,[foo - $ + ebx] ; Now legal
175
176\b Handle a 64-bit origin in NDISASM.
177
178\b NASM can now generate sparse output files for relevant output
179 formats, if the underlying operating system supports them.
180
H. Peter Anvincea308b2017-04-17 14:05:51 -0700181\b The \c{macho} object format now supports the \c{subsections_via_symbols}
H. Peter Anvin37d01d12017-03-28 15:51:45 -0700182 and \c{no_dead_strip} directives, see \k{macho-ssvs}.
183
H. Peter Anvincea308b2017-04-17 14:05:51 -0700184\b The \c{macho} object format now supports the \c{no_dead_strip},
H. Peter Anvin37d01d12017-03-28 15:51:45 -0700185 \c{live_support} and \c{strip_static_syms} section flags, see
186 \k{machosect}.
H. Peter Anvin7fcd9892017-03-07 23:03:11 -0800187
H. Peter Anvincea308b2017-04-17 14:05:51 -0700188\b The \c{macho} object format now supports the \c{dwarf} debugging
189 format, as required by newer toolchains.
190
H. Peter Anvind49a3bf2017-03-08 01:50:08 -0800191\b All warnings can now be suppressed if desired; warnings not
192 otherwise part of any warning class are now considered its own
193 warning class called \c{other} (e.g. \c{-w-other}). Furthermore,
194 warning-as-error can now be controlled on a per warning class
195 basis, using the syntax \c{-w+error=}\e{warning-class} and its
196 equivalent for all other warning control options. See \k{opt-w}
197 for the command-line options and warning classes and
198 \k{asmdir-warning} for the \c{[WARNING]} directive.
H. Peter Anvinb2047cb2017-03-08 01:26:40 -0800199
H. Peter Anvinb1a5b262017-04-02 19:45:35 -0700200\b Fix a number of bugs related to AVX-512 decorators.
201
H. Peter Anvinc5b29162017-04-06 19:10:57 -0700202\b Significant improvements to building NASM with Microsoft Visual
H. Peter Anvin06242962017-04-29 13:09:52 -0700203 Studio via \c{Mkfiles/msvc.mak}. It is now possible to build the
204 full Windows installer binary as long as the necessary
205 prerequisites are installed; see \c{Mkfiles/README}
H. Peter Anvinc5b29162017-04-06 19:10:57 -0700206
H. Peter Anvinb1a5b262017-04-02 19:45:35 -0700207\b To build NASM with custom modifications (table changes) or from the
H. Peter Anvin06242962017-04-29 13:09:52 -0700208 git tree now requires Perl 5.8 at the very minimum, quite possibly
H. Peter Anvinb1a5b262017-04-02 19:45:35 -0700209 a higher version (Perl 5.24.1 tested.) There is no requirement to
210 have Perl on your system at all if all you want to do is build
211 unmodified NASM from source archives.
212
H. Peter Anvinc5b29162017-04-06 19:10:57 -0700213\b Fix the \c{\{z\}} decorator on AVX-512 \c{VMOVDQ*} instructions.
214
H. Peter Anvin5e0d3b72016-10-03 23:01:58 -0700215\b Add new warnings for certain dangerous constructs which never ought
216 to have been allowed. In particular, the \c{RESB} family of
217 instructions should have been taking a critical expression all
218 along.
219
220\b Fix the EVEX (AVX-512) versions of the \c{VPBROADCAST}, \c{VPEXTR},
221 and \c{VPINSR} instructions.
222
223\b Support contracted forms of additional instructions. As a general
224 rule, if an instruction has a non-destructive source immediately
225 after a destination register that isn't used as an input, NASM
226 supports omitting that source register, using the destination
227 register as that value. This among other things makes it easier to
228 convert SSE code to the equivalent AVX code:
229
230\c addps xmm1,xmm0 ; SSE instruction
231\c vaddps ymm1,ymm1,ymm0 ; AVX official long form
232\c vaddps ymm1,ymm0 ; AVX contracted form
233
234\b Fix Codeview malformed compiler version record.
235
H. Peter Anvin6a6a40c2016-10-03 23:37:51 -0700236\b Add the \c{CLWB} and \c{PCOMMIT} instructions. Note that the
237 \c{PCOMMIT} instruction has been deprecated and will never be
238 included in a shipping product; it is included for completeness
239 only.
240
H. Peter Anvin91ac58d2017-04-29 13:34:19 -0700241\b Add the \c{%pragma} preprocessor directive for soft-error directives.
H. Peter Anvin3f87a2a2016-10-04 14:07:19 -0700242
H. Peter Anvin456b1c42016-11-15 11:56:42 -0800243\b Add the \c{RDPID} instruction.
244
H. Peter Anvin8494cc82016-04-05 13:06:14 -0700245\S{cl-2.12.02} Version 2.12.02
246
247\b Fix preprocessor errors, especially \c{%error} and \c{%warning},
248 inside \c{%if} statements.
249
H. Peter Anvinff7ff122016-05-09 11:19:58 -0700250\b Fix relative relocations in 32-bit Mach-O.
251
252\b More Codeview debug format fixes.
253
H. Peter Anvince637832016-10-04 00:04:44 -0700254\b If the MASM \c{PTR} keyword is encountered, issue a warning. This is
H. Peter Anvin19bc9de2016-05-09 12:09:04 -0700255 much more likely to indicate a MASM-ism encountered in NASM than it
H. Peter Anvin77511e32016-05-09 14:36:59 -0700256 is a valid label. This warning can be suppressed with \c{-w-ptr},
257 the \c{[warning]} directive (see \k{opt-w}) or by the macro
H. Peter Anvin964d5022017-03-01 13:35:13 -0800258 definition \c{%idefine ptr $%?} (see \k{selfref%?}).
H. Peter Anvin77511e32016-05-09 14:36:59 -0700259
260\b When an error or a warning comes from the expansion of a multi-line
261 macro, display the file and line numbers for the expanded macros.
262 Macros defined with \c{.nolist} do not get displayed.
H. Peter Anvin19bc9de2016-05-09 12:09:04 -0700263
H. Peter Anvinaa958b12016-05-24 23:03:17 -0700264\b Add macros \c{ilog2fw()} and \c{ilog2cw()} to the \c{ifunc} macro
265 package. See \k{ilog2}.
266
H. Peter Anvinff7ff122016-05-09 11:19:58 -0700267
H. Peter Anvinc5b95dd2016-03-03 12:43:02 -0800268\S{cl-2.12.01} Version 2.12.01
269
270\b Portability fixes for some platforms.
271
H. Peter Anvinc073fc02016-03-04 10:57:01 -0800272\b Fix error when not specifying a list file.
273
H. Peter Anvin2a74d842016-03-07 22:17:10 -0800274\b Correct the handling of macro-local labels in the Codeview
275 debugging format.
276
Cyrill Gorcunov6832acb2016-03-07 22:36:18 +0300277\b Add \c{CLZERO}, \c{MONITORX} and \c{MWAITX} instructions.
Cyrill Gorcunovf34cf392016-03-07 22:32:31 +0300278
H. Peter Anvinc5b95dd2016-03-03 12:43:02 -0800279
Cyrill Gorcunov23386132016-02-17 17:00:06 +0300280\S{cl-2.12} Version 2.12
281
H. Peter Anvin277308f2016-02-18 11:49:33 -0800282\b Major fixes to the \c{macho} backend (\k{machofmt}); earlier versions
283 would produce invalid symbols and relocations on a regular basis.
284
285\b Support for thread-local storage in Mach-O.
286
287\b Support for arbitrary sections in Mach-O.
Cyrill Gorcunov23386132016-02-17 17:00:06 +0300288
289\b Fix wrong negative size treated as a big positive value passed into
H. Peter Anvin277308f2016-02-18 11:49:33 -0800290 backend causing NASM to crash.
Cyrill Gorcunov23386132016-02-17 17:00:06 +0300291
292\b Fix handling of zero-extending unsigned relocations, we have been printing
293 wrong message and forgot to assign segment with predefined value before
294 passing it into output format.
295
296\b Fix potential write of oversized (with size greater than allowed in
297 output format) relative relocations.
298
H. Peter Anvinf15b1252017-02-23 20:20:50 -0800299\b Portability fixes for building NASM with the LLVM compiler.
Cyrill Gorcunov23386132016-02-17 17:00:06 +0300300
H. Peter Anvin277308f2016-02-18 11:49:33 -0800301\b Add support of Codeview version 8 (\c{cv8}) debug format for
302 \c{win32} and \c{win64} formats in the \c{COFF} backend,
303 see \k{codeview}.
H. Peter Anvin9f7c68a2016-02-17 13:44:51 -0800304
305\b Allow 64-bit outputs in 16/32-bit only backends. Unsigned 64-bit
306 relocations are zero-extended from 32-bits with a warning
H. Peter Anvin277308f2016-02-18 11:49:33 -0800307 (suppressible via \c{-w-zext-reloc}); signed 64-bit relocations are
H. Peter Anvind2238e22016-03-17 17:34:49 -0700308 an error.
Cyrill Gorcunov23386132016-02-17 17:00:06 +0300309
H. Peter Anvind2ea49b2016-02-17 15:35:06 -0800310\b Line numbers in list files now correspond to the lines in the source
311 files, instead of simply being sequential.
312
H. Peter Anvina8506052016-02-26 20:47:45 -0800313\b There is now an official 64-bit (x64 a.k.a. x86-64) build for Windows.
314
H. Peter Anvin277308f2016-02-18 11:49:33 -0800315
Cyrill Gorcunov8b4ef2d2015-07-26 14:42:30 +0300316\S{cl-2.11.09} Version 2.11.09
317
318\b Fix potential stack overwrite in \c{macho32} backend.
319
320\b Fix relocation records in \c{macho64} backend.
321
322\b Fix symbol lookup computation in \c{macho64} backend.
323
324\b Adjust \c{.symtab} and \c{.rela.text} sections alignments to 8 bytes
325 in \c{elf64} backed.
326
327\b Fix section length computation in \c{bin} backend which leaded in incorrect
328 relocation records.
329
Cyrill Gorcunov399d29c2015-02-21 22:12:57 +0300330\S{cl-2.11.08} Version 2.11.08
331
332\b Fix section length computation in \c{bin} backend which leaded in incorrect
333 relocation records.
334
335\b Add a warning for numeric preprocessor definitions passed via command
336 line which might have unexpected results otherwise.
337
338\b Add ability to specify a module name record in \c{rdoff} linker with
339 \c{-mn} option.
340
341\b Increase label length capacity up to 256 bytes in \c{rdoff} backend for
342 FreePascal sake, which tends to generate very long labels for procedures.
343
344\b Fix segmentation failure when rip addressing is used in \c{macho64} backend.
345
346\b Fix access on out of memory when handling strings with a single
347 grave. We have sixed similar problem in previous release but not
348 all cases were covered.
349
350\b Fix NULL dereference in disassembled on \c{BND} instruction.
351
Cyrill Gorcunove3131142014-12-09 21:47:23 +0300352\S{cl-2.11.07} Version 2.11.07
353
354\b Fix 256 bit \c{VMOVNTPS} instruction.
355
356\b Fix \c{-MD} option handling, which was rather broken in previous
357release changing command line api.
358
359\b Fix access to unitialized space when handling strings with
360a single grave.
361
362\b Fix nil dereference in handling memory reference parsing.
363
Jim Kukunase3e4f7c2014-10-17 14:51:36 -0700364\S{cl-2.11.06} Version 2.11.06
365
366\b Update AVX512 instructions based on the Extension Reference (319433-021 Sept
3672014).
368
369\b Fix the behavior of \c{-MF} and \c{-MD} options (Bugzilla 3392280)
370
371\b Updated Win32 Makefile to fix issue with build
372
H. Peter Anvin4ac3b022014-05-21 08:28:21 -0700373\S{cl-2.11.05} Version 2.11.05
374
375\b Add \c{--v} as an alias for \c{-v} (see \k{opt-v}), for
376command-line compatibility with Yasm.
377
378\b Fix a bug introduced in 2.11.03 whereby certain instructions would
379contain multiple REX prefixes, and thus be corrupt.
380
Jin Kyu Song3a105c32014-05-07 13:55:58 -0700381\S{cl-2.11.04} Version 2.11.04
382
383\b Removed an invalid error checking code. Sometimes a memref only with
384a displacement can also set an evex flag. For example:
385
386\c vmovdqu32 [0xabcd]{k1}, zmm0
387
388\b Fixed a bug in disassembler that EVEX.L'L vector length was not matched
389when EVEX.b was set because it was simply considered as EVEC.RC.
390Separated EVEX.L'L case from EVEX.RC which is ignored in matching.
391
H. Peter Anvin1a032812014-05-05 11:21:17 -0700392\S{cl-2.11.03} Version 2.11.03
393
394\b Fix a bug there REX prefixes were missing on instructions inside a
395\c{TIMES} statement.
396
H. Peter Anvin0b7db572014-02-19 14:55:54 -0800397\S{cl-2.11.02} Version 2.11.02
398
399\b Add the \c{XSAVEC}, \c{XSAVES} and \c{XRSTORS} family instructions.
400
H. Peter Anvin727eb3f2014-02-19 15:39:57 -0800401\b Add the \c{CLFLUSHOPT} instruction.
402
H. Peter Anvinf2d25692014-02-18 14:05:14 -0800403\S{cl-2.11.01} Version 2.11.01
404
405\b Allow instructions which implicitly uses \c{XMM0} (\c{VBLENDVPD},
406\c{VBLENDVPS}, \c{PBLENDVB} and \c{SHA256RNDS2}) to be specified
407without an explicit \c{xmm0} on the assembly line. In other words,
408the following two lines produce the same output:
409
410\c vblendvpd xmm2,xmm1,xmm0 ; Last operand is fixed xmm0
411\c vblendvpd xmm2,xmm1 ; Implicit xmm0 omitted
412
413\b In the ELF backends, don't crash the assembler if \c{section align}
414is specified without a value.
415
Jin Kyu Song1ab16e42013-11-25 17:59:25 -0800416\S{cl-2.11} Version 2.11
417
H. Peter Anvinebfa6a62013-11-28 21:24:09 -0800418\b Add support for the Intel AVX-512 instruction set:
Jin Kyu Song1ab16e42013-11-25 17:59:25 -0800419
420\b 16 new, 512-bit SIMD registers. Total 32 \c{(ZMM0 ~ ZMM31)}
421
422\b 8 new opmask registers \c{(K0 ~ K7)}. One of 7 registers \c{(K1 ~ K7)} can
423be used as an opmask for conditional execution.
424
425\b A new EVEX encoding prefix. EVEX is based on VEX and provides more
426capabilities: opmasks, broadcasting, embedded rounding and compressed
427displacements.
428
429\c - opmask
430\c VDIVPD zmm0{k1}{z}, zmm1, zmm3 ; conditional vector operation
431\c ; using opmask k1.
432\c ; {z} is for zero-masking
433\c - broadcasting
434\c VDIVPS zmm4, zmm5, [rbx]{1to16} ; load single-precision float and
435\c ; replicate it 16 times. 32 * 16 = 512
436\c - embedded rounding
437\c VCVTSI2SD xmm6, xmm7, {rz-sae}, rax ; round toward zero. note that it
438\c ; is used as if a separate operand.
439\c ; it comes after the last SIMD operand
440
H. Peter Anvinebfa6a62013-11-28 21:24:09 -0800441\b Add support for \c{ZWORD} (512 bits), \c{DZ} and \c{RESZ}.
442
443\b Add support for the MPX and SHA instruction sets.
444
445\b Better handling of section redefinition.
446
447\b Generate manpages when running \c{'make dist'}.
448
449\b Handle all token chains in mmacro params range.
450
451\b Support split [base,index] effective address:
452
453\c mov eax,[eax+8,ecx*4] ; eax=base, ecx=index, 4=scale, 8=disp
454
455This is expected to be most useful for the MPX instructions.
456
457\b Support \c{BND} prefix for branch instructions (for MPX).
458
H. Peter Anvinb2fcac92013-12-31 10:38:51 -0800459\b The \c{DEFAULT} directive can now take \c{BND} and \c{NOBND}
460options to indicate whether all relevant branches should be getting
461\c{BND} prefixes. This is expected to be the normal for use in MPX
462code.
463
H. Peter Anvinebfa6a62013-11-28 21:24:09 -0800464\b Add \c{{evex}}, \c{{vex3}} and \c{{vex2}} instruction prefixes to
465have NASM encode the corresponding instruction, if possible, with an EVEX,
4663-byte VEX, or 2-byte VEX prefix, respectively.
467
H. Peter Anvinebfa6a62013-11-28 21:24:09 -0800468\b Support for section names longer than 8 bytes in Win32/Win64 COFF.
Jin Kyu Song1ab16e42013-11-25 17:59:25 -0800469
H. Peter Anvinbe1d0522013-12-31 10:35:12 -0800470\b The \c{NOSPLIT} directive by itself no longer forces a single
471register to become an index register, unless it has an explicit
472multiplier.
473
474\c mov eax,[nosplit eax] ; eax as base register
475\c mov eax,[nosplit eax*1] ; eax as index register
476
Cyrill Gorcunove74e4942013-07-23 09:36:00 +0400477\S{cl-2.10.09} Version 2.10.09
478
479\b Pregenerate man pages.
480
Cyrill Gorcunov82139da2013-07-21 00:42:47 +0400481\S{cl-2.10.08} Version 2.10.08
482
Cyrill Gorcunov85f734b2013-07-21 11:19:27 +0400483\b Fix \c{VMOVNTDQA}, \c{MOVNTDQA} and \c{MOVLPD} instructions.
484
Cyrill Gorcunov82139da2013-07-21 00:42:47 +0400485\b Fix collision for \c{VGATHERQPS}, \c{VPGATHERQD} instructions.
486
487\b Fix \c{VPMOVSXBQ}, \c{VGATHERQPD}, \c{VSPLLW} instructions.
488
489\b Add a bunch of AMD TBM instructions.
490
491\b Fix potential stack overwrite in numbers conversion.
492
493\b Allow byte size in \c{PREFETCHTx} instructions.
494
495\b Make manual pages up to date.
496
497\b Make \c{F3} and \c{F2} SSE prefixes to override \c{66}.
498
499\b Support of AMD SVM instructions in 32 bit mode.
500
501\b Fix near offsets code generation for \c{JMP}, \c{CALL} instrictions
502in long mode.
503
504\b Fix preprocessor parse regression when id is expanding to a whitespace.
505
Cyrill Gorcunov6cdebb42012-12-27 20:28:02 +0400506\S{cl-2.10.07} Version 2.10.07
507
508\b Fix line continuation parsing being broken in previous version.
509
H. Peter Anvin55340992012-09-09 17:09:00 -0700510\S{cl-2.10.06} Version 2.10.06
511
512\b Always quote the dependency source names when using the automatic
513dependency generation options.
514
515\b If no dependency target name is specified via the \c{-MT} or
516\c{-MQ} options, quote the default output name.
517
H. Peter Anvin4dab7a02012-10-08 12:05:59 +0800518\b Fix assembly of shift operations in \c{CPU 8086} mode.
519
520\b Fix incorrect generation of explicit immediate byte for shift by 1
521under certain circumstances.
522
523\b Fix assembly of the \c{VPCMPGTQ} instruction.
524
H. Peter Anvinf2ded502012-12-04 13:36:42 -0800525\b Fix RIP-relative relocations in the \c{macho64} backend.
526
H. Peter Anvin55f3cb82012-09-09 11:05:35 -0700527\S{cl-2.10.05} Version 2.10.05
528
529\b Add the \c{CLAC} and \c{STAC} instructions.
530
H. Peter Anvin480435c2012-08-17 15:42:24 -0700531\S{cl-2.10.04} Version 2.10.04
532
533\b Add back the inadvertently deleted 256-bit version of the \c{VORPD}
534instruction.
535
536\b Correct disassembly of instructions starting with byte \c{82} hex.
537
538\b Fix corner cases in token pasting, for example:
539
540\c %define N 1e%++%+ 5
541\c dd N, 1e+5
542
H. Peter Anvin7f9a43a2012-07-22 21:08:30 -0700543\S{cl-2.10.03} Version 2.10.03
544
545\b Correct the assembly of the instruction:
546
547\c XRELEASE MOV [absolute],AL
548
H. Peter Anvin5194f772017-04-13 21:54:42 -0700549\> Previous versions would incorrectly generate \c{F3 A2} for this
H. Peter Anvin7f9a43a2012-07-22 21:08:30 -0700550instruction and issue a warning; correct behavior is to emit \c{F3 88
55105}.
552
H. Peter Anvin5c4c5062012-07-20 17:53:55 -0700553\S{cl-2.10.02} Version 2.10.02
554
555\b Add the \c{ifunc} macro package with integer functions, currently
556only integer logarithms. See \k{pkg_ifunc}.
557
558\b Add the \c{RDSEED}, \c{ADCX} and \c{ADOX} instructions.
559
Cyrill Gorcunov45bf92b2012-05-25 00:58:43 +0400560\S{cl-2.10.01} Version 2.10.01
561
562\b Add missing VPMOVMSKB instruction with reg32, ymmreg operands.
563
H. Peter Anvinaf5cb1b2010-08-24 14:13:32 -0700564\S{cl-2.10} Version 2.10
565
566\b When optimization is enabled, \c{mov r64,imm} now optimizes to the
567 shortest form possible between:
568
H. Peter Anvin96e8d962010-08-24 14:20:40 -0700569\c mov r32,imm32 ; 5 bytes
570\c mov r64,imm32 ; 7 bytes
571\c mov r64,imm64 ; 10 bytes
H. Peter Anvinaf5cb1b2010-08-24 14:13:32 -0700572
H. Peter Anvin5194f772017-04-13 21:54:42 -0700573\> To force a specific form, use the \c{STRICT} keyword, see \k{strict}.
H. Peter Anvind68466a2010-08-24 14:14:48 -0700574
H. Peter Anvin8a44aa42012-02-25 13:30:41 -0800575\b Add support for the Intel AVX2 instruction set.
576
577\b Add support for Bit Manipulation Instructions 1 and 2.
578
579\b Add support for Intel Transactional Synchronization Extensions (TSX).
H. Peter Anvin2d3dce22010-08-24 09:55:27 -0700580
H. Peter Anvinc92aaa12012-02-25 15:05:45 -0800581\b Add support for x32 ELF (32-bit ELF with the CPU in 64-bit mode.)
582 See \k{elffmt}.
583
H. Peter Anvin6b8cc122012-02-25 15:34:14 -0800584\b Add support for bigendian UTF-16 and UTF-32. See \k{unicode}.
585
Cyrill Gorcunoved48ab82011-07-16 01:33:00 +0400586\S{cl-2.09.10} Version 2.09.10
587
588\b Fix up NSIS script to protect uninstaller against registry keys
589 absence or corruption. It brings in a few additional questions
590 to a user during deinstallation procedure but still it is better
591 than unpredictable file removal.
592
Cyrill Gorcunov68868b02011-07-04 00:47:08 +0400593\S{cl-2.09.09} Version 2.09.09
594
595\b Fix initialization of section attributes of \c{bin} output format.
596
597\b Fix \c{mach64} output format bug that crashes NASM due to NULL symbols.
598
599
Cyrill Gorcunov47e7ecd2011-04-06 19:08:34 +0400600\S{cl-2.09.08} Version 2.09.08
601
602\b Fix \c{__OUTPUT_FORMAT__} assignment when output driver alias
603 is used. For example when \c{-f elf} is used \c{__OUTPUT_FORMAT__}
604 must be set to \c{elf}, if \c{-f elf32} is used \c{__OUTPUT_FORMAT__}
605 must be assigned accordingly, i.e. to \c{elf32}. The rule applies to
606 all output driver aliases. See \k{ofmtm}.
607
608
Cyrill Gorcunov16f998e2011-03-07 11:35:18 +0300609\S{cl-2.09.07} Version 2.09.07
610
611\b Fix attempts to close same file several times
612 when \c{-a} option is used.
613
Cyrill Gorcunoveb9b2942011-03-07 12:44:43 +0300614\b Fixes for VEXTRACTF128, VMASKMOVPS encoding.
Cyrill Gorcunov16f998e2011-03-07 11:35:18 +0300615
Cyrill Gorcunova09fe1e2011-03-12 22:35:42 +0300616
Cyrill Gorcunov16f998e2011-03-07 11:35:18 +0300617\S{cl-2.09.06} Version 2.09.06
Cyrill Gorcunov37dacf02011-02-28 09:58:52 +0300618
619\b Fix missed section attribute initialization in \c{bin} output target.
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400620
Cyrill Gorcunov1616b9d2011-02-28 10:03:53 +0300621
Cyrill Gorcunove5c2c492011-02-20 21:22:25 +0300622\S{cl-2.09.05} Version 2.09.05
623
Cyrill Gorcunov8fc44e92011-02-20 22:12:32 +0300624\b Fix arguments encoding for VPEXTRW instruction.
625
626\b Remove invalid form of VPEXTRW instruction.
Cyrill Gorcunove5c2c492011-02-20 21:22:25 +0300627
Cyrill Gorcunovb6c1dca2011-02-23 00:49:13 +0300628\b Add \c{VLDDQU} as alias for \c{VLDQQU} to
629 match specification.
630
Cyrill Gorcunove5c2c492011-02-20 21:22:25 +0300631
Cyrill Gorcunov9348b902010-11-21 19:51:49 +0300632\S{cl-2.09.04} Version 2.09.04
633
634\b Fix incorrect labels offset for VEX intructions.
635
636\b Eliminate bogus warning on implicit operand size override.
637
638\b \c{%if} term could not handle 64 bit numbers.
639
640\b The COFF backend was limiting relocations number to 16 bits even if
641 in real there were a way more relocations.
642
643
Cyrill Gorcunovfdbe8ba2010-10-27 21:50:20 +0400644\S{cl-2.09.03} Version 2.09.03
645
646\b Print \c{%macro} name inside \c{%rep} blocks on error.
647
648\b Fix preprocessor expansion behaviour. It happened sometime
649 too early and sometime simply wrong. Move behaviour back to
650 the origins (down to NASM 2.05.01).
651
652\b Fix unitialized data dereference on OMF output format.
653
654\b Issue warning on unterminated \c{%{} construct.
655
656\b Fix for documentation typo.
657
658
H. Peter Anvin2c11f972010-09-15 08:59:12 -0700659\S{cl-2.09.02} Version 2.09.02
660
661\b Fix reversed tokens when \c{%deftok} produces more than one output token.
662
Cyrill Gorcunov831222f2010-09-15 21:13:48 +0400663\b Fix segmentation fault on disassembling some VEX instructions.
664
665\b Missing \c{%endif} did not always cause error.
666
667\b Fix typo in documentation.
668
Cyrill Gorcunova28db5f2010-09-18 02:55:46 +0400669\b Compound context local preprocessor single line macro identifiers
670 were not expanded early enough and as result lead to unresolved
671 symbols.
672
H. Peter Anvin2c11f972010-09-15 08:59:12 -0700673
Cyrill Gorcunov234e4ed2010-09-07 20:57:36 +0400674\S{cl-2.09.01} Version 2.09.01
675
676\b Fix NULL dereference on missed %deftok second parameter.
677
678\b Fix NULL dereference on invalid %substr parameters.
679
680
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400681\S{cl-2.09} Version 2.09
682
Cyrill Gorcunove091d6e2010-08-09 13:58:22 +0400683\b Fixed assignment the magnitude of \c{%rep} counter. It is limited
684 to 62 bits now.
685
Cyrill Gorcunov088d1512010-07-23 18:57:40 +0400686\b Fixed NULL dereference if argument of \c{%strlen} resolves
687 to whitespace. For example if nonexistent macro parameter is used.
688
H. Peter Anvin077fb932010-07-20 14:56:30 -0700689\b \c{%ifenv}, \c{%elifenv}, \c{%ifnenv}, and \c{%elifnenv} directives
690 introduced. See \k{ifenv}.
Bryant Kellera537d492010-07-13 23:49:39 +0400691
Cyrill Gorcunov702df6d2010-07-13 20:59:46 +0400692\b Fixed NULL dereference if environment variable is missed.
693
Cyrill Gorcunovaed4eaa2010-07-17 18:24:13 +0400694\b Updates of new AVX v7 Intel instructions.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400695
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400696\b \c{PUSH imm32} is now officially documented.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400697
698\b Fix for encoding the LFS, LGS and LSS in 64-bit mode.
699
H. Peter Anvin077fb932010-07-20 14:56:30 -0700700\b Fixes for compatibility with OpenWatcom compiler and DOS 8.3 file
701 format limitation.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400702
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400703\b Macros parameters range expansion introduced. See \k{mlmacrange}.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400704
H. Peter Anvinab5bd052010-07-25 12:43:30 -0700705\b Backward compatibility on expanging of local sigle macros restored.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400706
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400707\b 8 bit relocations for \c{elf} and \c{bin} output formats are introduced.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400708
709\b Short intersegment jumps are permitted now.
710
Cyrill Gorcunov327edcf2010-08-16 13:47:24 +0400711\b An alignment more than 64 bytes are allowed for \c{win32},
H. Peter Anvin077fb932010-07-20 14:56:30 -0700712 \c{win64} output formats.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400713
Cyrill Gorcunov407e6c72010-07-28 17:59:49 +0400714\b \c{SECTALIGN} directive introduced. See \k{sectalign}.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400715
H. Peter Anvin077fb932010-07-20 14:56:30 -0700716\b \c{nojmp} option introduced in \c{smartalign} package. See
717 \k{pkg_smartalign}.
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400718
H. Peter Anvin077fb932010-07-20 14:56:30 -0700719\b Short aliases \c{win}, \c{elf} and \c{macho} for output formats are
720 introduced. Each stands for \c{win32}, \c{elf32} and \c{macho32}
721 accordingly.
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400722
723\b Faster handling of missing directives implemented.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400724
725\b Various small improvements in documentation.
726
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400727\b No hang anymore if unable to open malloc.log file.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400728
Cyrill Gorcunov924df0d2010-07-12 23:15:01 +0400729\b The environments without vsnprintf function are able to build nasm again.
Cyrill Gorcunovf2c1cb02010-07-07 01:48:33 +0400730
731\b AMD LWP instructions updated.
732
733\b Tighten EA checks. We warn a user if there overflow in EA addressing.
734
H. Peter Anvin31387b22010-07-15 18:28:52 -0700735\b Make \c{-Ox} the default optimization level. For the legacy
H. Peter Anvinab5bd052010-07-25 12:43:30 -0700736 behavior, specify \c{-O0} explicitly. See \k{opt-O}.
H. Peter Anvin31387b22010-07-15 18:28:52 -0700737
H. Peter Anvin077fb932010-07-20 14:56:30 -0700738\b Environment variables read with \c{%!} or tested with \c{%ifenv}
739 can now contain non-identifier characters if surrounded by quotes.
740 See \k{getenv}.
741
H. Peter Anvin2d3dce22010-08-24 09:55:27 -0700742\b Add a new standard macro package \c{%use fp} for floating-point
743 convenience macros. See \k{pkg_fp}.
744
Cyrill Gorcunovb9771902009-11-06 11:24:54 +0300745
H. Peter Anvin5bc03272010-07-15 22:44:03 -0700746\S{cl-2.08.02} Version 2.08.02
747
748\b Fix crash under certain circumstances when using the \c{%+} operator.
749
750
751\S{cl-2.08.01} Version 2.08.01
752
753\b Fix the \c{%use} statement, which was broken in 2.08.
754
755
H. Peter Anvin57924832009-11-09 14:58:45 -0800756\S{cl-2.08} Version 2.08
Cyrill Gorcunov66ba8cd2009-10-18 01:09:40 +0400757
758\b A number of enhancements/fixes in macros area.
759
Keith Kanios4ea84662009-10-25 14:06:24 -0500760\b Support for converting strings to tokens. See \k{deftok}.
761
Cyrill Gorcunov66ba8cd2009-10-18 01:09:40 +0400762\b Fuzzy operand size logic introduced.
763
Cyrill Gorcunov78debd02009-12-13 14:13:35 +0300764\b Fix COFF stack overrun on too long export identifiers.
765
Keith Kanios4ea84662009-10-25 14:06:24 -0500766\b Fix Macho-O alignment bug.
767
Cyrill Gorcunov66ba8cd2009-10-18 01:09:40 +0400768\b Fix crashes with -fwin32 on file with many exports.
769
770\b Fix stack overrun for too long [DEBUG id].
771
Cyrill Gorcunovb9771902009-11-06 11:24:54 +0300772\b Fix incorrect sbyte usage in IMUL (hit only if optimization
773 flag passed).
774
Cyrill Gorcunov66ba8cd2009-10-18 01:09:40 +0400775\b Append ending token for \c{.stabs} records in the ELF output format.
776
777\b New NSIS script which uses ModernUI and MultiUser approach.
778
779\b Visual Studio 2008 NASM integration (rules file).
780
Cyrill Gorcunov7a8098c2010-01-03 15:41:22 +0300781\b Warn a user if a constant is too long (and as result will be stripped).
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400782
H. Peter Anvin57924832009-11-09 14:58:45 -0800783\b The obsoleted pre-XOP AMD SSE5 instruction set which was never actualized
784 was removed.
785
Cyrill Gorcunov78debd02009-12-13 14:13:35 +0300786\b Fix stack overrun on too long error file name passed from the command line.
Keith Kanios4ea84662009-10-25 14:06:24 -0500787
Cyrill Gorcunov7a8098c2010-01-03 15:41:22 +0300788\b Bind symbols to the .text section by default (ie in case if SECTION
789 directive was omitted) in the ELF output format.
790
791\b Fix sync points array index wrapping.
792
793\b A few fixes for FMA4 and XOP instruction templates.
794
795\b Add AMD Lightweight Profiling (LWP) instructions.
796
H. Peter Anvin3af37792010-02-15 10:15:53 -0800797\b Fix the offset for \c{%arg} in 64-bit mode.
798
799\b An undefined local macro (\c{%$}) no longer matches a global macro
800 with the same name.
801
Cyrill Gorcunov3dce1e12010-03-03 23:13:48 +0300802\b Fix NULL dereference on too long local labels.
H. Peter Anvin3af37792010-02-15 10:15:53 -0800803
Cyrill Gorcunov90bb2852010-03-03 23:15:25 +0300804
H. Peter Anvinfba06d22009-07-06 11:28:12 -0700805\S{cl-2.07} Version 2.07
806
807\b NASM is now under the 2-clause BSD license. See \k{legal}.
808
809\b Fix the section type for the \c{.strtab} section in the \c{elf64}
810 output format.
811
812\b Fix the handling of \c{COMMON} directives in the \c{obj} output format.
813
814\b New \c{ith} and \c{srec} output formats; these are variants of the
815 \c{bin} output format which output Intel hex and Motorola S-records,
816 respectively. See \k{ithfmt} and \k{srecfmt}.
817
818\b \c{rdf2ihx} replaced with an enhanced \c{rdf2bin}, which can output
819 binary, COM, Intel hex or Motorola S-records.
820
821\b The Windows installer now puts the NASM directory first in the
822 \c{PATH} of the "NASM Shell".
823
H. Peter Anvin83b942d2009-07-06 19:00:08 -0700824\b Revert the early expansion behavior of \c{%+} to pre-2.06 behavior:
825 \c{%+} is only expanded late.
826
H. Peter Anvine227fe62009-07-06 19:27:33 -0700827\b Yet another Mach-O alignment fix.
828
H. Peter Anvina7a14b22009-07-07 16:08:56 -0700829\b Don't delete the list file on errors. Also, include error and
830 warning information in the list file.
831
H. Peter Anvina6e25b52009-07-08 21:32:28 -0700832\b Support for 64-bit Mach-O output, see \k{machofmt}.
833
H. Peter Anvina99c9842009-07-15 17:43:32 -0400834\b Fix assert failure on certain operations that involve strings with
835 high-bit bytes.
H. Peter Anvincc6ee1a2009-07-15 16:31:55 -0400836
H. Peter Anvinfba06d22009-07-06 11:28:12 -0700837
H. Peter Anvinb34fce72008-10-24 16:05:19 -0700838\S{cl-2.06} Version 2.06
839
H. Peter Anvinc940afc2009-06-28 17:12:37 -0700840\b This release is dedicated to the memory of Charles A. Crayne, long
841 time NASM developer as well as moderator of \c{comp.lang.asm.x86} and
842 author of the book \e{Serious Assembler}. We miss you, Chuck.
843
H. Peter Anvinb34fce72008-10-24 16:05:19 -0700844\b Support for indirect macro expansion (\c{%[...]}). See \k{indmacro}.
845
H. Peter Anvin0b7d9032008-10-24 16:27:11 -0700846\b \c{%pop} can now take an argument, see \k{pushpop}.
847
H. Peter Anvin264b7b92008-10-24 16:38:17 -0700848\b The argument to \c{%use} is no longer macro-expanded. Use
849 \c{%[...]} if macro expansion is desired.
850
H. Peter Anvine263d042008-11-02 20:41:29 -0800851\b Support for thread-local storage in ELF32 and ELF64. See \k{elftls}.
852
H. Peter Anvin67a405e2008-11-04 14:26:32 -0800853\b Fix crash on \c{%ifmacro} without an argument.
854
H. Peter Anvin67478812008-11-06 09:42:11 -0800855\b Correct the arguments to the \c{POPCNT} instruction.
856
H. Peter Anvinfd925d92008-12-22 16:37:59 -0800857\b Fix section alignment in the Mach-O format.
858
H. Peter Anvine8a3e622009-02-18 14:13:25 -0800859\b Update AVX support to version 5 of the Intel specification.
860
H. Peter Anvin87513882009-02-21 18:26:20 -0800861\b Fix the handling of accesses to context-local macros from higher
862 levels in the context stack.
863
864\b Treat \c{WAIT} as a prefix rather than as an instruction, thereby
865 allowing constructs like \c{O16 FSAVE} to work correctly.
866
Victor van den Elzenb32536c2009-03-29 03:09:13 +0200867\b Support for structures with a non-zero base offset. See \k{struc}.
868
H. Peter Anvin9c7f3f52009-04-07 22:09:05 -0700869\b Correctly handle preprocessor token concatenation (see \k{concat})
870 involving floating-point numbers.
871
H. Peter Anvin883735f2009-06-25 11:23:37 -0700872\b The \c{PINSR} series of instructions have been corrected and
873 rationalized.
874
875\b Removed AMD SSE5, replaced with the new XOP/FMA4/CVT16 (rev 3.03)
876 spec.
877
H. Peter Anvind219a3e2009-06-25 12:30:50 -0700878\b The ELF backends no longer automatically generate a \c{.comment} section.
879
H. Peter Anvinc4471462009-06-25 14:54:44 -0700880\b Add additional "well-known" ELF sections with default attributes. See
881 \k{elfsect}.
882
H. Peter Anvinb34fce72008-10-24 16:05:19 -0700883
H. Peter Anvin7714ced2008-10-29 10:51:51 -0700884\S{cl-2.05.01} Version 2.05.01
885
886\b Fix the \c{-w}/\c{-W} option parsing, which was broken in NASM 2.05.
887
888
H. Peter Anvindc0bf472008-09-30 16:24:47 -0700889\S{cl-2.05} Version 2.05
890
H. Peter Anvin1abb9e52008-09-30 17:14:54 -0700891\b Fix redundant REX.W prefix on \c{JMP reg64}.
892
H. Peter Anvindc0bf472008-09-30 16:24:47 -0700893\b Make the behaviour of \c{-O0} match NASM 0.98 legacy behavior.
894 See \k{opt-O}.
895
H. Peter Anvin2f160432008-09-30 16:39:17 -0700896\b \c{-w-user} can be used to suppress the output of \c{%warning} directives.
897 See \k{opt-w}.
898
H. Peter Anvina3a60e92008-10-01 10:02:44 -0700899\b Fix bug where \c{ALIGN} would issue a full alignment datum instead of
900 zero bytes.
901
902\b Fix offsets in list files.
903
904\b Fix \c{%include} inside multi-line macros or loops.
905
H. Peter Anvin6c80ab62008-10-04 18:50:47 -0700906\b Fix error where NASM would generate a spurious warning on valid
907 optimizations of immediate values.
908
H. Peter Anvin04c60522008-10-06 18:00:13 -0700909\b Fix arguments to a number of the \c{CVT} SSE instructions.
910
H. Peter Anvin68b41d32008-10-06 19:15:42 -0700911\b Fix RIP-relative offsets when the instruction carries an immediate.
912
H. Peter Anvin3ffd0fc2008-10-17 23:36:45 -0700913\b Massive overhaul of the ELF64 backend for spec compliance.
H. Peter Anvin8cd1df82008-10-12 21:17:04 -0700914
H. Peter Anvin7766ab02008-10-23 19:29:28 -0700915\b Fix the Geode \c{PFRCPV} and \c{PFRSQRTV} instruction.
916
917\b Fix the SSE 4.2 \c{CRC32} instruction.
918
H. Peter Anvindc0bf472008-09-30 16:24:47 -0700919
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400920\S{cl-2.04} Version 2.04
921
H. Peter Anvin6477f3d2008-07-14 02:49:52 -0400922\b Sanitize macro handing in the \c{%error} directive.
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400923
H. Peter Anvin6477f3d2008-07-14 02:49:52 -0400924\b New \c{%warning} directive to issue user-controlled warnings.
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400925
H. Peter Anvin8e3f75e2008-09-24 00:21:58 -0700926\b \c{%error} directives are now deferred to the final assembly phase.
927
928\b New \c{%fatal} directive to immediately terminate assembly.
929
H. Peter Anvindf73e0b2008-09-03 15:16:44 -0700930\b New \c{%strcat} directive to join quoted strings together.
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400931
H. Peter Anvindf73e0b2008-09-03 15:16:44 -0700932\b New \c{%use} macro directive to support standard macro directives. See
933 \k{use}.
934
935\b Excess default parameters to \c{%macro} now issues a warning by default.
936 See \k{mlmacro}.
937
H. Peter Anvin13f1f3e2008-09-24 08:59:29 -0700938\b Fix \c{%ifn} and \c{%elifn}.
939
940\b Fix nested \c{%else} clauses.
941
942\b Correct the handling of nested \c{%rep}s.
943
944\b New \c{%unmacro} directive to undeclare a multi-line macro.
945 See \k{unmacro}.
946
H. Peter Anvin010aee22008-09-24 17:34:37 -0700947\b Builtin macro \c{__PASS__} which expands to the current assembly pass.
948 See \k{pass_macro}.
949
H. Peter Anvin13f1f3e2008-09-24 08:59:29 -0700950\b \c{__utf16__} and \c{__utf32__} operators to generate UTF-16 and UTF-32
951 strings. See \k{unicode}.
952
953\b Fix bug in case-insensitive matching when compiled on platforms that
954 don't use the \c{configure} script. Of the official release binaries,
955 that only affected the OS/2 binary.
956
957\b Support for x87 packed BCD constants. See \k{bcdconst}.
958
959\b Correct the \c{LTR} and \c{SLDT} instructions in 64-bit mode.
960
961\b Fix unnecessary REX.W prefix on indirect jumps in 64-bit mode.
962
963\b Add AVX versions of the AES instructions (\c{VAES}...).
964
965\b Fix the 256-bit FMA instructions.
966
967\b Add 256-bit AVX stores per the latest AVX spec.
968
969\b VIA XCRYPT instructions can now be written either with or without
970 \c{REP}, apparently different versions of the VIA spec wrote them
971 differently.
972
973\b Add missing 64-bit \c{MOVNTI} instruction.
974
975\b Fix the operand size of \c{VMREAD} and \c{VMWRITE}.
976
H. Peter Anvindf73e0b2008-09-03 15:16:44 -0700977\b Numerous bug fixes, especially to the AES, AVX and VTX instructions.
978
H. Peter Anvina2d542c2008-09-10 23:04:56 -0700979\b The optimizer now always runs until it converges. It also runs even
980 when disabled, but doesn't optimize. This allows most forward references
981 to be resolved properly.
982
H. Peter Anvinc83f9de2008-10-24 16:53:53 -0700983\b \c{%push} no longer needs a context identifier; omitting the context
984 identifier results in an anonymous context.
985
H. Peter Anvin04156cd2008-07-14 02:45:57 -0400986
987\S{cl-2.03.01} Version 2.03.01
988
989\b Fix buffer overflow in the listing module.
990
991\b Fix the handling of hexadecimal escape codes in `...` strings.
992
993\b The Postscript/PDF documentation has been reformatted.
994
995\b The \c{-F} option now implies \c{-g}.
996
997
998\S{cl-2.03} Version 2.03
999
1000\b Add support for Intel AVX, CLMUL and FMA instructions,
1001including YMM registers.
1002
1003\b \c{dy}, \c{resy} and \c{yword} for 32-byte operands.
1004
1005\b Fix some SSE5 instructions.
1006
1007\b Intel \c{INVEPT}, \c{INVVPID} and \c{MOVBE} instructions.
1008
1009\b Fix checking for critical expressions when the optimizer is enabled.
1010
1011\b Support the DWARF debugging format for ELF targets.
1012
1013\b Fix optimizations of signed bytes.
1014
1015\b Fix operation on bigendian machines.
1016
1017\b Fix buffer overflow in the preprocessor.
1018
1019\b \c{SAFESEH} support for Win32, \c{IMAGEREL} for Win64 (SEH).
1020
1021\b \c{%?} and \c{%??} to refer to the name of a macro itself. In particular,
1022\c{%idefine keyword $%?} can be used to make a keyword "disappear".
1023
1024\b New options for dependency generation: \c{-MD}, \c{-MF},
1025\c{-MP}, \c{-MT}, \c{-MQ}.
1026
1027\b New preprocessor directives \c{%pathsearch} and \c{%depend}; INCBIN
1028reimplemented as a macro.
1029
1030\b \c{%include} now resolves macros in a sane manner.
1031
1032\b \c{%substr} can now be used to get other than one-character substrings.
1033
1034\b New type of character/string constants, using backquotes (\c{`...`}),
1035which support C-style escape sequences.
1036
1037\b \c{%defstr} and \c{%idefstr} to stringize macro definitions before
1038creation.
1039
1040\b Fix forward references used in \c{EQU} statements.
1041
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001042
H. Peter Anvina5e02792009-06-24 16:50:54 -07001043\S{cl-2.02} Version 2.02
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001044
1045\b Additional fixes for MMX operands with explicit \c{qword}, as well as
1046 (hopefully) SSE operands with \c{oword}.
1047
1048\b Fix handling of truncated strings with \c{DO}.
1049
1050\b Fix segfaults due to memory overwrites when floating-point constants
1051 were used.
1052
1053\b Fix segfaults due to missing include files.
1054
1055\b Fix OpenWatcom Makefiles for DOS and OS/2.
1056
1057\b Add autogenerated instruction list back into the documentation.
1058
1059\b ELF: Fix segfault when generating stabs, and no symbols have been
1060 defined.
1061
1062\b ELF: Experimental support for DWARF debugging information.
1063
1064\b New compile date and time standard macros.
1065
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001066\b \c{%ifnum} now returns true for negative numbers.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001067
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001068\b New \c{%iftoken} test for a single token.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001069
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001070\b New \c{%ifempty} test for empty expansion.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001071
1072\b Add support for the \c{XSAVE} instruction group.
1073
1074\b Makefile for Netware/gcc.
1075
1076\b Fix issue with some warnings getting emitted way too many times.
1077
1078\b Autogenerated instruction list added to the documentation.
1079
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001080
H. Peter Anvina5e02792009-06-24 16:50:54 -07001081\S{cl-2.01} Version 2.01
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001082
1083\b Fix the handling of MMX registers with explicit \c{qword} tags on
1084 memory (broken in 2.00 due to 64-bit changes.)
1085
1086\b Fix the PREFETCH instructions.
1087
1088\b Fix the documentation.
1089
1090\b Fix debugging info when using \c{-f elf}
1091(backwards compatibility alias for \c{-f elf32}).
1092
1093\b Man pages for rdoff tools (from the Debian project.)
1094
1095\b ELF: handle large numbers of sections.
1096
1097\b Fix corrupt output when the optimizer runs out of passes.
1098
1099
1100\S{cl-2.00} Version 2.00
1101
1102\b Added c99 data-type compliance.
1103
1104\b Added general x86-64 support.
1105
1106\b Added win64 (x86-64 COFF) output format.
1107
1108\b Added \c{__BITS__} standard macro.
1109
1110\b Renamed the \c{elf} output format to \c{elf32} for clarity.
1111
1112\b Added \c{elf64} and \c{macho} (MacOS X) output formats.
1113
1114\b Added Numeric constants in \c{dq} directive.
1115
1116\b Added \c{oword}, \c{do} and \c{reso} pseudo operands.
1117
1118\b Allow underscores in numbers.
1119
1120\b Added 8-, 16- and 128-bit floating-point formats.
1121
1122\b Added binary, octal and hexadecimal floating-point.
1123
1124\b Correct the generation of floating-point constants.
1125
1126\b Added floating-point option control.
1127
1128\b Added Infinity and NaN floating point support.
1129
1130\b Added ELF Symbol Visibility support.
1131
1132\b Added setting OSABI value in ELF header directive.
1133
1134\b Added Generate Makefile Dependencies option.
1135
1136\b Added Unlimited Optimization Passes option.
1137
1138\b Added \c{%IFN} and \c{%ELIFN} support.
1139
1140\b Added Logical Negation Operator.
1141
1142\b Enhanced Stack Relative Preprocessor Directives.
1143
1144\b Enhanced ELF Debug Formats.
1145
1146\b Enhanced Send Errors to a File option.
1147
1148\b Added SSSE3, SSE4.1, SSE4.2, SSE5 support.
1149
1150\b Added a large number of additional instructions.
1151
1152\b Significant performance improvements.
1153
H. Peter Anvin8a2f1452008-10-29 18:14:03 -07001154\b \c{-w+warning} and \c{-w-warning} can now be written as -Wwarning and
1155 -Wno-warning, respectively. See \k{opt-w}.
1156
1157\b Add \c{-w+error} to treat warnings as errors. See \k{opt-w}.
1158
1159\b Add \c{-w+all} and \c{-w-all} to enable or disable all suppressible
1160 warnings. See \k{opt-w}.
1161
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001162
1163\H{cl-0.98.xx} NASM 0.98 Series
1164
1165The 0.98 series was the production versions of NASM from 1999 to 2007.
1166
1167
1168\S{cl-0.98.39} Version 0.98.39
1169
1170\b fix buffer overflow
1171
1172\b fix outas86's \c{.bss} handling
1173
1174\b "make spotless" no longer deletes config.h.in.
1175
1176\b \c{%(el)if(n)idn} insensitivity to string quotes difference (#809300).
1177
1178\b (nasm.c)\c{__OUTPUT_FORMAT__} changed to string value instead of symbol.
1179
1180\S{cl-0.98.38} Version 0.98.38
1181
1182
1183\b Add Makefile for 16-bit DOS binaries under OpenWatcom, and modify
1184 \c{mkdep.pl} to be able to generate completely pathless dependencies, as
1185 required by OpenWatcom wmake (it supports path searches, but not
1186 explicit paths.)
1187
1188\b Fix the \c{STR} instruction.
1189
1190\b Fix the ELF output format, which was broken under certain
1191 circumstances due to the addition of stabs support.
1192
1193\b Quick-fix Borland format debug-info for \c{-f obj}
1194
1195\b Fix for \c{%rep} with no arguments (#560568)
1196
1197\b Fix concatenation of preprocessor function call (#794686)
1198
1199\b Fix long label causes coredump (#677841)
1200
1201\b Use autoheader as well as autoconf to keep configure from generating
1202 ridiculously long command lines.
1203
1204\b Make sure that all of the formats which support debugging output
1205 actually will suppress debugging output when \c{-g} not specified.
1206
1207\S{cl-0.98.37} Version 0.98.37
1208
1209
1210\b Paths given in \c{-I} switch searched for \c{incbin}-ed as
1211 well as \c{%include}-ed files.
1212
1213\b Added stabs debugging for the ELF output format, patch from
1214 Martin Wawro.
1215
1216\b Fix \c{output/outbin.c} to allow origin > 80000000h.
1217
1218\b Make \c{-U} switch work.
1219
1220\b Fix the use of relative offsets with explicit prefixes, e.g.
1221\c{a32 loop foo}.
1222
1223\b Remove \c{backslash()}.
1224
1225\b Fix the \c{SMSW} and \c{SLDT} instructions.
1226
1227\b \c{-O2} and \c{-O3} are no longer aliases for \c{-O10} and \c{-O15}.
1228If you mean the latter, please say so! :)
1229
1230\S{cl-0.98.36} Version 0.98.36
1231
1232
1233\b Update rdoff - librarian/archiver - common rec - docs!
1234
1235\b Fix signed/unsigned problems.
1236
1237\b Fix \c{JMP FAR label} and \c{CALL FAR label}.
1238
1239\b Add new multisection support - map files - fix align bug
1240
1241\b Fix sysexit, movhps/movlps reg,reg bugs in insns.dat
1242
1243\b \c{Q} or \c{O} suffixes indicate octal
1244
1245\b Support Prescott new instructions (PNI).
1246
1247\b Cyrix \c{XSTORE} instruction.
1248
1249
1250\S{cl-0.98.35} Version 0.98.35
1251
1252\b Fix build failure on 16-bit DOS (Makefile.bc3 workaround for compiler bug.)
1253
1254\b Fix dependencies and compiler warnings.
1255
1256\b Add "const" in a number of places.
1257
1258\b Add -X option to specify error reporting format (use -Xvc to
1259 integrate with Microsoft Visual Studio.)
1260
1261\b Minor changes for code legibility.
1262
1263\b Drop use of tmpnam() in rdoff (security fix.)
1264
1265
1266\S{cl-0.98.34} Version 0.98.34
1267
1268\b Correct additional address-size vs. operand-size confusions.
1269
1270\b Generate dependencies for all Makefiles automatically.
1271
1272\b Add support for unimplemented (but theoretically available)
1273 registers such as tr0 and cr5. Segment registers 6 and 7 are called
1274 segr6 and segr7 for the operations which they can be represented.
1275
1276\b Correct some disassembler bugs related to redundant address-size prefixes.
1277 Some work still remains in this area.
1278
1279\b Correctly generate an error for things like "SEG eax".
1280
1281\b Add the JMPE instruction, enabled by "CPU IA64".
1282
1283\b Correct compilation on newer gcc/glibc platforms.
1284
1285\b Issue an error on things like "jmp far eax".
1286
1287
1288\S{cl-0.98.33} Version 0.98.33
1289
1290\b New __NASM_PATCHLEVEL__ and __NASM_VERSION_ID__ standard macros to
1291 round out the version-query macros. version.pl now understands
1292 X.YYplWW or X.YY.ZZplWW as a version number, equivalent to
1293 X.YY.ZZ.WW (or X.YY.0.WW, as appropriate).
1294
1295\b New keyword "strict" to disable the optimization of specific
1296 operands.
1297
1298\b Fix the handing of size overrides with JMP instructions
1299 (instructions such as "jmp dword foo".)
1300
1301\b Fix the handling of "ABSOLUTE label", where "label" points into a
1302 relocatable segment.
1303
1304\b Fix OBJ output format with lots of externs.
1305
1306\b More documentation updates.
1307
1308\b Add -Ov option to get verbose information about optimizations.
1309
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001310\b Undo a braindead change which broke \c{%elif} directives.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001311
1312\b Makefile updates.
1313
1314
1315\S{cl-0.98.32} Version 0.98.32
1316
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001317\b Fix NASM crashing when \c{%macro} directives were left unterminated.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001318
1319\b Lots of documentation updates.
1320
1321\b Complete rewrite of the PostScript/PDF documentation generator.
1322
1323\b The MS Visual C++ Makefile was updated and corrected.
1324
1325\b Recognize .rodata as a standard section name in ELF.
1326
1327\b Fix some obsolete Perl4-isms in Perl scripts.
1328
1329\b Fix configure.in to work with autoconf 2.5x.
1330
1331\b Fix a couple of "make cleaner" misses.
1332
1333\b Make the normal "./configure && make" work with Cygwin.
1334
1335
1336\S{cl-0.98.31} Version 0.98.31
1337
1338\b Correctly build in a separate object directory again.
1339
1340\b Derive all references to the version number from the version file.
1341
1342\b New standard macros __NASM_SUBMINOR__ and __NASM_VER__ macros.
1343
1344\b Lots of Makefile updates and bug fixes.
1345
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001346\b New \c{%ifmacro} directive to test for multiline macros.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001347
1348\b Documentation updates.
1349
1350\b Fixes for 16-bit OBJ format output.
1351
1352\b Changed the NASM environment variable to NASMENV.
1353
1354
1355\S{cl-0.98.30} Version 0.98.30
1356
1357\b Changed doc files a lot: completely removed old READMExx and
1358 Wishlist files, incorporating all information in CHANGES and TODO.
1359
1360\b I waited a long time to rename zoutieee.c to (original) outieee.c
1361
1362\b moved all output modules to output/ subdirectory.
1363
1364\b Added 'make strip' target to strip debug info from nasm & ndisasm.
1365
1366\b Added INSTALL file with installation instructions.
1367
1368\b Added -v option description to nasm man.
1369
1370\b Added dist makefile target to produce source distributions.
1371
1372\b 16-bit support for ELF output format (GNU extension, but useful.)
1373
1374
1375\S{cl-0.98.28} Version 0.98.28
1376
1377\b Fastcooked this for Debian's Woody release:
1378Frank applied the INCBIN bug patch to 0.98.25alt and called
1379it 0.98.28 to not confuse poor little apt-get.
1380
1381
1382\S{cl-0.98.26} Version 0.98.26
1383
1384\b Reorganised files even better from 0.98.25alt
1385
1386
1387\S{cl-0.98.25alt} Version 0.98.25alt
1388
1389\b Prettified the source tree. Moved files to more reasonable places.
1390
1391\b Added findleak.pl script to misc/ directory.
1392
1393\b Attempted to fix doc.
1394
1395
1396\S{cl-0.98.25} Version 0.98.25
1397
1398\b Line continuation character \c{\\}.
1399
1400\b Docs inadvertantly reverted - "dos packaging".
1401
1402
1403\S{cl-0.98.24p1} Version 0.98.24p1
1404
1405\b FIXME: Someone, document this please.
1406
1407
1408\S{cl-0.98.24} Version 0.98.24
1409
1410\b Documentation - Ndisasm doc added to Nasm.doc.
1411
1412
1413\S{cl-0.98.23} Version 0.98.23
1414
1415\b Attempted to remove rdoff version1
1416
1417\b Lino Mastrodomenico's patches to preproc.c (%$$ bug?).
1418
1419
1420\S{cl-0.98.22} Version 0.98.22
1421
1422\b Update rdoff2 - attempt to remove v1.
1423
1424
1425\S{cl-0.98.21} Version 0.98.21
1426
1427\b Optimization fixes.
1428
1429
1430\S{cl-0.98.20} Version 0.98.20
1431
1432\b Optimization fixes.
1433
1434
1435\S{cl-0.98.19} Version 0.98.19
1436
1437\b H. J. Lu's patch back out.
1438
1439
1440\S{cl-0.98.18} Version 0.98.18
1441
1442\b Added ".rdata" to "-f win32".
1443
1444
1445\S{cl-0.98.17} Version 0.98.17
1446
1447\b H. J. Lu's "bogus elf" patch. (Red Hat problem?)
1448
1449
1450\S{cl-0.98.16} Version 0.98.16
1451
1452\b Fix whitespace before "[section ..." bug.
1453
1454
1455\S{cl-0.98.15} Version 0.98.15
1456
1457\b Rdoff changes (?).
1458
1459\b Fix fixes to memory leaks.
1460
1461
1462\S{cl-0.98.14} Version 0.98.14
1463
1464\b Fix memory leaks.
1465
1466
1467\S{cl-0.98.13} Version 0.98.13
1468
1469\b There was no 0.98.13
1470
1471
1472\S{cl-0.98.12} Version 0.98.12
1473
1474\b Update optimization (new function of "-O1")
1475
1476\b Changes to test/bintest.asm (?).
1477
1478
1479\S{cl-0.98.11} Version 0.98.11
1480
1481\b Optimization changes.
1482
1483\b Ndisasm fixed.
1484
1485
1486\S{cl-0.98.10} Version 0.98.10
1487
1488\b There was no 0.98.10
1489
1490
1491\S{cl-0.98.09} Version 0.98.09
1492
1493\b Add multiple sections support to "-f bin".
1494
1495\b Changed GLOBAL_TEMP_BASE in outelf.c from 6 to 15.
1496
1497\b Add "-v" as an alias to the "-r" switch.
1498
1499\b Remove "#ifdef" from Tasm compatibility options.
1500
1501\b Remove redundant size-overrides on "mov ds, ex", etc.
1502
1503\b Fixes to SSE2, other insns.dat (?).
1504
1505\b Enable uppercase "I" and "P" switches.
1506
1507\b Case insinsitive "seg" and "wrt".
1508
1509\b Update install.sh (?).
1510
1511\b Allocate tokens in blocks.
1512
1513\b Improve "invalid effective address" messages.
1514
1515
1516\S{cl-0.98.08} Version 0.98.08
1517
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001518\b Add "\c{%strlen}" and "\c{%substr}" macro operators
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001519
1520\b Fixed broken c16.mac.
1521
1522\b Unterminated string error reported.
1523
1524\b Fixed bugs as per 0.98bf
1525
1526
1527\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
1528
1529Changes from 0.98.07 release to 98.09b as of 28-Oct-2001
1530
1531\b More closely compatible with 0.98 when -O0 is implied
H. Peter Anvinf805cde2017-02-23 17:19:56 -08001532or specified. Not strictly identical, since backward
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001533branches in range of short offsets are recognized, and signed
1534byte values with no explicit size specification will be
1535assembled as a single byte.
1536
1537\b More forgiving with the PUSH instruction. 0.98 requires
1538a size to be specified always. 0.98.09b will imply the size
1539from the current BITS setting (16 or 32).
1540
1541\b Changed definition of the optimization flag:
1542
H. Peter Anvin5194f772017-04-13 21:54:42 -07001543\c -O0 strict two-pass assembly, JMP and Jcc are
1544\c handled more like 0.98, except that back-
1545\c ward JMPs are short, if possible.
1546\c
1547\c -O1 strict two-pass assembly, but forward
1548\c branches are assembled with code guaranteed
1549\c to reach; may produce larger code than
1550\c -O0, but will produce successful assembly
1551\c more often if branch offset sizes are not
1552\c specified.
1553\c
1554\c -O2 multi-pass optimization, minimize branch
1555\c offsets; also will minimize signed immed-
1556\c iate bytes, overriding size specification.
1557\c
1558\c -O3 like -O2, but more passes taken, if needed
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001559
1560
1561\S{cl-0.98.07 released 01/28/01} Version 0.98.07 released 01/28/01
1562
H. Peter Anvin5194f772017-04-13 21:54:42 -07001563\b Added Stepane Denis' SSE2 instructions to a *working*
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001564 version of the code - some earlier versions were based on
1565 broken code - sorry 'bout that. version "0.98.07"
1566
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001567\b Cosmetic modifications to nasm.c, nasm.h,
1568 AUTHORS, MODIFIED
1569
1570
1571\S{cl-0.98.06f released 01/18/01} Version 0.98.06f released 01/18/01
1572
1573
H. Peter Anvin5194f772017-04-13 21:54:42 -07001574\b Add "metalbrain"s jecxz bug fix in insns.dat
1575
1576\b Alter nasmdoc.src to match - version "0.98.06f"
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001577
1578
1579\S{cl-0.98.06e released 01/09/01} Version 0.98.06e released 01/09/01
1580
1581
1582\b Removed the "outforms.h" file - it appears to be
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001583 someone's old backup of "outform.h". version "0.98.06e"
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001584
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001585\b fbk - finally added the fix for the "multiple %includes bug",
1586 known since 7/27/99 - reported originally (?) and sent to
1587 us by Austin Lunnen - he reports that John Fine had a fix
1588 within the day. Here it is...
1589
1590\b Nelson Rush resigns from the group. Big thanks to Nelson for
1591 his leadership and enthusiasm in getting these changes
1592 incorporated into Nasm!
1593
1594\b fbk - [list +], [list -] directives - ineptly implemented, should
1595 be re-written or removed, perhaps.
1596
1597\b Brian Raiter / fbk - "elfso bug" fix - applied to aoutb format
1598 as well - testing might be desirable...
1599
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001600\b James Seter - -postfix, -prefix command line switches.
1601
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001602\b Yuri Zaporozhets - rdoff utility changes.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001603
1604
1605\S{cl-0.98p1} Version 0.98p1
1606
1607\b GAS-like palign (Panos Minos)
1608
1609\b FIXME: Someone, fill this in with details
1610
1611
1612\S{cl-0.98bf (bug-fixed)} Version 0.98bf (bug-fixed)
1613
1614\b Fixed - elf and aoutb bug - shared libraries
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001615 - multiple "%include" bug in "-f obj"
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001616 - jcxz, jecxz bug
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001617 - unrecognized option bug in ndisasm
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001618
1619\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
1620
1621\b Added signed byte optimizations for the 0x81/0x83 class
1622of instructions: ADC, ADD, AND, CMP, OR, SBB, SUB, XOR:
1623when used as 'ADD reg16,imm' or 'ADD reg32,imm.' Also
1624optimization of signed byte form of 'PUSH imm' and 'IMUL
1625reg,imm'/'IMUL reg,reg,imm.' No size specification is needed.
1626
1627\b Added multi-pass JMP and Jcc offset optimization. Offsets
1628on forward references will preferentially use the short form,
1629without the need to code a specific size (short or near) for
1630the branch. Added instructions for 'Jcc label' to use the
1631form 'Jnotcc $+3/JMP label', in cases where a short offset
1632is out of bounds. If compiling for a 386 or higher CPU, then
1633the 386 form of Jcc will be used instead.
1634
H. Peter Anvin5194f772017-04-13 21:54:42 -07001635\> This feature is controlled by a new command-line switch: "O",
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001636(upper case letter O). "-O0" reverts the assembler to no
1637extra optimization passes, "-O1" allows up to 5 extra passes,
1638and "-O2"(default), allows up to 10 extra optimization passes.
1639
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001640\b Added a new directive: 'cpu XXX', where XXX is any of:
H. Peter Anvin04156cd2008-07-14 02:45:57 -040016418086, 186, 286, 386, 486, 586, pentium, 686, PPro, P2, P3 or
1642Katmai. All are case insensitive. All instructions will
1643be selected only if they apply to the selected cpu or lower.
1644Corrected a couple of bugs in cpu-dependence in 'insns.dat'.
1645
1646\b Added to 'standard.mac', the "use16" and "use32" forms of
1647the "bits 16/32" directive. This is nothing new, just conforms
1648to a lot of other assemblers. (minor)
1649
Yuri Zaporozhets7a33af22015-01-18 20:21:14 +02001650\b Changed label allocation from 320/32 (10000 labels @ 200K+)
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001651to 32/37 (1000 labels); makes running under DOS much easier.
1652Since additional label space is allocated dynamically, this
1653should have no effect on large programs with lots of labels.
1654The 37 is a prime, believed to be better for hashing. (minor)
1655
1656
1657\S{cl-0.98.03} Version 0.98.03
1658
1659"Integrated patchfile 0.98-0.98.01. I call this version 0.98.03 for
1660historical reasons: 0.98.02 was trashed." --John Coffman
1661<johninsd@san.rr.com>, 27-Jul-2000
1662
1663\b Kendall Bennett's SciTech MGL changes
1664
1665\b Note that you must define "TASM_COMPAT" at compile-time
1666to get the Tasm Ideal Mode compatibility.
1667
1668\b All changes can be compiled in and out using the TASM_COMPAT macros,
1669and when compiled without TASM_COMPAT defined we get the exact same
1670binary as the unmodified 0.98 sources.
1671
1672\b standard.mac, macros.c: Added macros to ignore TASM directives before
1673first include
1674
1675\b nasm.h: Added extern declaration for tasm_compatible_mode
1676
1677\b nasm.c: Added global variable tasm_compatible_mode
1678
1679\b Added command line switch for TASM compatible mode (-t)
1680
1681\b Changed version command line to reflect when compiled with TASM additions
1682
1683\b Added response file processing to allow all arguments on a single
1684line (response file is @resp rather than -@resp for NASM format).
1685
1686\b labels.c: Changes islocal() macro to support TASM style @@local labels.
1687
1688\b Added islocalchar() macro to support TASM style @@local labels.
1689
1690\b parser.c: Added support for TASM style memory references (ie: mov
1691[DWORD eax],10 rather than the NASM style mov DWORD [eax],10).
1692
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001693\b preproc.c: Added new directives, \c{%arg}, \c{%local}, \c{%stacksize} to directives
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001694table
1695
1696\b Added support for TASM style directives without a leading % symbol.
1697
1698\b Integrated a block of changes from Andrew Zabolotny <bit@eltech.ru>:
1699
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001700\b A new keyword \c{%xdefine} and its case-insensitive counterpart \c{%ixdefine}.
1701They work almost the same way as \c{%define} and \c{%idefine} but expand
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001702the definition immediately, not on the invocation. Something like a cross
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001703between \c{%define} and \c{%assign}. The "x" suffix stands for "eXpand", so
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001704"xdefine" can be deciphered as "expand-and-define". Thus you can do
1705things like this:
1706
1707\c %assign ofs 0
1708\c
1709\c %macro arg 1
1710\c %xdefine %1 dword [esp+ofs]
1711\c %assign ofs ofs+4
1712\c %endmacro
1713
1714\b Changed the place where the expansion of %$name macros are expanded.
1715Now they are converted into ..@ctxnum.name form when detokenizing, so
1716there are no quirks as before when using %$name arguments to macros,
1717in macros etc. For example:
1718
1719\c %macro abc 1
1720\c %define %1 hello
1721\c %endm
1722\c
1723\c abc %$here
1724\c %$here
1725
H. Peter Anvin5194f772017-04-13 21:54:42 -07001726\> Now last line will be expanded into "hello" as expected. This also allows
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001727 for lots of goodies, a good example are extended "proc" macros included
1728 in this archive.
1729
1730\b Added a check for "cstk" in smacro_defined() before calling get_ctx() -
1731 this allows for things like:
1732
1733\c %ifdef %$abc
1734\c %endif
1735
H. Peter Anvin5194f772017-04-13 21:54:42 -07001736\> to work without warnings even in no context.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001737
1738\b Added a check for "cstk" in %if*ctx and %elif*ctx directives -
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001739 this allows to use \c{%ifctx} without excessive warnings. If there is
1740 no active context, \c{%ifctx} goes through "false" branch.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001741
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001742\b Removed "user error: " prefix with \c{%error} directive: it just clobbers the
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001743 output and has absolutely no functionality. Besides, this allows to write
1744 macros that does not differ from built-in functions in any way.
1745
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001746\b Added expansion of string that is output by \c{%error} directive. Now you
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001747 can do things like:
1748
1749\c %define hello(x) Hello, x!
1750\c
1751\c %define %$name andy
1752\c %error "hello(%$name)"
1753
H. Peter Anvin5194f772017-04-13 21:54:42 -07001754\> Same happened with \c{%include} directive.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001755
1756\b Now all directives that expect an identifier will try to expand and
1757 concatenate everything without whitespaces in between before usage.
1758 For example, with "unfixed" nasm the commands
1759
1760\c %define %$abc hello
1761\c %define __%$abc goodbye
1762\c __%$abc
1763
H. Peter Anvin5194f772017-04-13 21:54:42 -07001764\> would produce "incorrect" output: last line will expand to
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001765
1766\c hello goodbyehello
1767
H. Peter Anvin5194f772017-04-13 21:54:42 -07001768\> Not quite what you expected, eh? :-) The answer is that preprocessor
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001769 treats the \c{%define} construct as if it would be
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001770
1771\c %define __ %$abc goodbye
1772
H. Peter Anvin5194f772017-04-13 21:54:42 -07001773\> (note the white space between __ and %$abc). After my "fix" it
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001774 will "correctly" expand into
1775
1776\c goodbye
1777
H. Peter Anvin5194f772017-04-13 21:54:42 -07001778\> as expected. Note that I use quotes around words "correct", "incorrect"
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001779 etc because this is rather a feature not a bug; however current behaviour
1780 is more logical (and allows more advanced macro usage :-).
1781
1782 Same change was applied to:
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001783 \c{%push},\c{%macro},\c{%imacro},\c{%define},\c{%idefine},\c{%xdefine},\c{%ixdefine},
1784 \c{%assign},\c{%iassign},\c{%undef}
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001785
1786\b A new directive [WARNING {+|-}warning-id] have been added. It works only
1787 if the assembly phase is enabled (i.e. it doesn't work with nasm -e).
1788
1789\b A new warning type: macro-selfref. By default this warning is disabled;
1790 when enabled NASM warns when a macro self-references itself; for example
1791 the following source:
1792
1793\c [WARNING macro-selfref]
1794\c
1795\c %macro push 1-*
1796\c %rep %0
1797\c push %1
1798\c %rotate 1
1799\c %endrep
1800\c %endmacro
1801\c
1802\c push eax,ebx,ecx
1803
H. Peter Anvin5194f772017-04-13 21:54:42 -07001804\> will produce a warning, but if we remove the first line we won't see it
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001805 anymore (which is The Right Thing To Do {tm} IMHO since C preprocessor
1806 eats such constructs without warnings at all).
1807
1808\b Added a "error" routine to preprocessor which always will set ERR_PASS1
1809 bit in severity_code. This removes annoying repeated errors on first
1810 and second passes from preprocessor.
1811
1812\b Added the %+ operator in single-line macros for concatenating two
1813 identifiers. Usage example:
1814
1815\c %define _myfunc _otherfunc
1816\c %define cextern(x) _ %+ x
1817\c cextern (myfunc)
1818
H. Peter Anvin5194f772017-04-13 21:54:42 -07001819\> After first expansion, third line will become "_myfunc". After this
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001820 expansion is performed again so it becomes "_otherunc".
1821
1822\b Now if preprocessor is in a non-emitting state, no warning or error
1823 will be emitted. Example:
1824
1825\c %if 1
1826\c mov eax,ebx
1827\c %else
1828\c put anything you want between these two brackets,
1829\c even macro-parameter references %1 or local
1830\c labels %$zz or macro-local labels %%zz - no
1831\c warning will be emitted.
1832\c %endif
1833
1834\b Context-local variables on expansion as a last resort are looked up
1835 in outer contexts. For example, the following piece:
1836
1837\c %push outer
1838\c %define %$a [esp]
1839\c
1840\c %push inner
1841\c %$a
1842\c %pop
1843\c %pop
1844
H. Peter Anvin5194f772017-04-13 21:54:42 -07001845\> will expand correctly the fourth line to [esp]; if we'll define another
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001846 %$a inside the "inner" context, it will take precedence over outer
1847 definition. However, this modification has been applied only to
1848 expand_smacro and not to smacro_define: as a consequence expansion
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001849 looks in outer contexts, but \c{%ifdef} won't look in outer contexts.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001850
H. Peter Anvin5194f772017-04-13 21:54:42 -07001851\> This behaviour is needed because we don't want nested contexts to
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001852 act on already defined local macros. Example:
1853
1854\c %define %$arg1 [esp+4]
1855\c test eax,eax
1856\c if nz
1857\c mov eax,%$arg1
1858\c endif
1859
H. Peter Anvin5194f772017-04-13 21:54:42 -07001860\> In this example the "if" mmacro enters into the "if" context, so %$arg1
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001861 is not valid anymore inside "if". Of course it could be worked around
1862 by using explicitely %$$arg1 but this is ugly IMHO.
1863
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001864\b Fixed memory leak in \c{%undef}. The origline wasn't freed before
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001865 exiting on success.
1866
1867\b Fixed trap in preprocessor when line expanded to empty set of tokens.
1868 This happens, for example, in the following case:
1869
1870\c #define SOMETHING
1871\c SOMETHING
1872
1873
1874\S{cl-0.98} Version 0.98
1875
1876All changes since NASM 0.98p3 have been produced by H. Peter Anvin <hpa@zytor.com>.
1877
1878\b The documentation comment delimiter is \# not #.
1879
1880\b Allow EQU definitions to refer to external labels; reported by
1881 Pedro Gimeno.
1882
1883\b Re-enable support for RDOFF v1; reported by Pedro Gimeno.
1884
1885\b Updated License file per OK from Simon and Julian.
1886
1887
1888\S{cl-0.98p9} Version 0.98p9
1889
1890\b Update documentation (although the instruction set reference will
1891 have to wait; I don't want to hold up the 0.98 release for it.)
1892
1893\b Verified that the NASM implementation of the PEXTRW and PMOVMSKB
1894 instructions is correct. The encoding differs from what the Intel
1895 manuals document, but the Pentium III behaviour matches NASM, not
1896 the Intel manuals.
1897
1898\b Fix handling of implicit sizes in PSHUFW and PINSRW, reported by
1899 Stefan Hoffmeister.
1900
1901\b Resurrect the -s option, which was removed when changing the
1902 diagnostic output to stdout.
1903
1904
1905\S{cl-0.98p8} Version 0.98p8
1906
1907\b Fix for "DB" when NASM is running on a bigendian machine.
1908
1909\b Invoke insns.pl once for each output script, making Makefile.in
1910 legal for "make -j".
1911
1912\b Improve the Unix configure-based makefiles to make package
1913 creation easier.
1914
1915\b Included an RPM .spec file for building RPM (RedHat Package Manager)
1916 packages on Linux or Unix systems.
1917
1918\b Fix Makefile dependency problems.
1919
1920\b Change src/rdsrc.pl to include sectioning information in info
1921 output; required for install-info to work.
1922
1923\b Updated the RDOFF distribution to version 2 from Jules; minor
1924 massaging to make it compile in my environment.
1925
1926\b Split doc files that can be built by anyone with a Perl interpreter off
1927 into a separate archive.
1928
1929\b "Dress rehearsal" release!
1930
1931
1932\S{cl-0.98p7} Version 0.98p7
1933
1934\b Fixed opcodes with a third byte-sized immediate argument to not
1935 complain if given "byte" on the immediate.
1936
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001937\b Allow \c{%undef} to remove single-line macros with arguments. This
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001938 matches the behaviour of #undef in the C preprocessor.
1939
1940\b Allow -d, -u, -i and -p to be specified as -D, -U, -I and -P for
1941 compatibility with most C compilers and preprocessors. This allows
1942 Makefile options to be shared between cc and nasm, for example.
1943
1944\b Minor cleanups.
1945
1946\b Went through the list of Katmai instructions and hopefully fixed the
1947 (rather few) mistakes in it.
1948
1949\b (Hopefully) fixed a number of disassembler bugs related to ambiguous
1950 instructions (disambiguated by -p) and SSE instructions with REP.
1951
1952\b Fix for bug reported by Mark Junger: "call dword 0x12345678" should
1953 work and may add an OSP (affected CALL, JMP, Jcc).
1954
1955\b Fix for environments when "stderr" isn't a compile-time constant.
1956
1957
1958\S{cl-0.98p6} Version 0.98p6
1959
1960
1961\b Took officially over coordination of the 0.98 release; so drop
1962 the p3.x notation. Skipped p4 and p5 to avoid confusion with John
1963 Fine's J4 and J5 releases.
1964
1965\b Update the documentation; however, it still doesn't include
1966 documentation for the various new instructions. I somehow wonder if
1967 it makes sense to have an instruction set reference in the assembler
1968 manual when Intel et al have PDF versions of their manuals online.
1969
1970\b Recognize "idt" or "centaur" for the -p option to ndisasm.
1971
1972\b Changed error messages back to stderr where they belong, but add an
1973 -E option to redirect them elsewhere (the DOS shell cannot redirect
1974 stderr.)
1975
1976\b -M option to generate Makefile dependencies (based on code from Alex
1977 Verstak.)
1978
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001979\b \c{%undef} preprocessor directive, and -u option, that undefines a
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001980 single-line macro.
1981
1982\b OS/2 Makefile (Mkfiles/Makefile.os2) for Borland under OS/2; from
1983 Chuck Crayne.
1984
1985\b Various minor bugfixes (reported by):
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04001986 - Dangling \c{%s} in preproc.c (Martin Junker)
H. Peter Anvin04156cd2008-07-14 02:45:57 -04001987
1988\b THERE ARE KNOWN BUGS IN SSE AND THE OTHER KATMAI INSTRUCTIONS. I am
1989 on a trip and didn't bring the Katmai instruction reference, so I
1990 can't work on them right now.
1991
1992\b Updated the License file per agreement with Simon and Jules to
1993 include a GPL distribution clause.
1994
1995
1996\S{cl-0.98p3.7} Version 0.98p3.7
1997
1998\b (Hopefully) fixed the canned Makefiles to include the outrdf2 and
1999 zoutieee modules.
2000
2001\b Renamed changes.asm to changed.asm.
2002
2003
2004\S{cl-0.98p3.6} Version 0.98p3.6
2005
2006\b Fixed a bunch of instructions that were added in 0.98p3.5 which had
2007 memory operands, and the address-size prefix was missing from the
2008 instruction pattern.
2009
2010
2011\S{cl-0.98p3.5} Version 0.98p3.5
2012
2013\b Merged in changes from John S. Fine's 0.98-J5 release. John's based
2014 0.98-J5 on my 0.98p3.3 release; this merges the changes.
2015
2016\b Expanded the instructions flag field to a long so we can fit more
2017 flags; mark SSE (KNI) and AMD or Katmai-specific instructions as
2018 such.
2019
2020\b Fix the "PRIV" flag on a bunch of instructions, and create new
2021 "PROT" flag for protected-mode-only instructions (orthogonal to if
2022 the instruction is privileged!) and new "SMM" flag for SMM-only
2023 instructions.
2024
2025\b Added AMD-only SYSCALL and SYSRET instructions.
2026
2027\b Make SSE actually work, and add new Katmai MMX instructions.
2028
2029\b Added a -p (preferred vendor) option to ndisasm so that it can
2030 distinguish e.g. Cyrix opcodes also used in SSE. For example:
2031
2032\c ndisasm -p cyrix aliased.bin
2033\c 00000000 670F514310 paddsiw mm0,[ebx+0x10]
2034\c 00000005 670F514320 paddsiw mm0,[ebx+0x20]
2035\c ndisasm -p intel aliased.bin
2036\c 00000000 670F514310 sqrtps xmm0,[ebx+0x10]
2037\c 00000005 670F514320 sqrtps xmm0,[ebx+0x20]
2038
2039\b Added a bunch of Cyrix-specific instructions.
2040
2041
2042\S{cl-0.98p3.4} Version 0.98p3.4
2043
2044\b Made at least an attempt to modify all the additional Makefiles (in
2045 the Mkfiles directory). I can't test it, but this was the best I
2046 could do.
2047
2048\b DOS DJGPP+"Opus Make" Makefile from John S. Fine.
2049
2050\b changes.asm changes from John S. Fine.
2051
2052
2053\S{cl-0.98p3.3} Version 0.98p3.3
2054
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002055\b Patch from Conan Brink to allow nesting of \c{%rep} directives.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002056
2057\b If we're going to allow INT01 as an alias for INT1/ICEBP (one of
2058 Jules 0.98p3 changes), then we should allow INT03 as an alias for INT3
2059 as well.
2060
2061\b Updated changes.asm to include the latest changes.
2062
2063\b Tried to clean up the <CR>s that had snuck in from a DOS/Windows
2064 environment into my Unix environment, and try to make sure than
2065 DOS/Windows users get them back.
2066
2067\b We would silently generate broken tools if insns.dat wasn't sorted
2068 properly. Change insns.pl so that the order doesn't matter.
2069
2070\b Fix bug in insns.pl (introduced by me) which would cause conditional
2071 instructions to have an extra "cc" in disassembly, e.g. "jnz"
2072 disassembled as "jccnz".
2073
2074
2075\S{cl-0.98p3.2} Version 0.98p3.2
2076
2077\b Merged in John S. Fine's changes from his 0.98-J4 prerelease; see
2078 http://www.csoft.net/cz/johnfine/
2079
2080\b Changed previous "spotless" Makefile target (appropriate for distribution)
2081 to "distclean", and added "cleaner" target which is same as "clean"
2082 except deletes files generated by Perl scripts; "spotless" is union.
2083
2084\b Removed BASIC programs from distribution. Get a Perl interpreter
2085 instead (see below.)
2086
2087\b Calling this "pre-release 3.2" rather than "p3-hpa2" because of
2088 John's contributions.
2089
2090\b Actually link in the IEEE output format (zoutieee.c); fix a bunch of
2091 compiler warnings in that file. Note I don't know what IEEE output
2092 is supposed to look like, so these changes were made "blind".
2093
2094
2095\S{cl-0.98p3-hpa} Version 0.98p3-hpa
2096
2097\b Merged nasm098p3.zip with nasm-0.97.tar.gz to create a fully
2098 buildable version for Unix systems (Makefile.in updates, etc.)
2099
2100\b Changed insns.pl to create the instruction tables in nasm.h and
2101 names.c, so that a new instruction can be added by adding it *only*
2102 to insns.dat.
2103
2104\b Added the following new instructions: SYSENTER, SYSEXIT, FXSAVE,
2105 FXRSTOR, UD1, UD2 (the latter two are two opcodes that Intel
2106 guarantee will never be used; one of them is documented as UD2 in
2107 Intel documentation, the other one just as "Undefined Opcode" --
2108 calling it UD1 seemed to make sense.)
2109
2110\b MAX_SYMBOL was defined to be 9, but LOADALL286 and LOADALL386 are 10
2111 characters long. Now MAX_SYMBOL is derived from insns.dat.
2112
2113\b A note on the BASIC programs included: forget them. insns.bas is
2114 already out of date. Get yourself a Perl interpreter for your
2115 platform of choice at
2116 \W{http://www.cpan.org/ports/index.html}{http://www.cpan.org/ports/index.html}.
2117
2118
2119\S{cl-0.98p3} Version 0.98 pre-release 3
2120
2121\b added response file support, improved command line handling, new layout
2122help screen
2123
2124\b fixed limit checking bug, 'OUT byte nn, reg' bug, and a couple of rdoff
2125related bugs, updated Wishlist; 0.98 Prerelease 3.
2126
2127
2128\S{cl-0.98p2} Version 0.98 pre-release 2
2129
2130\b fixed bug in outcoff.c to do with truncating section names longer
2131than 8 characters, referencing beyond end of string; 0.98 pre-release 2
2132
2133
2134\S{cl-0.98p1} Version 0.98 pre-release 1
2135
2136\b Fixed a bug whereby STRUC didn't work at all in RDF.
2137
2138\b Fixed a problem with group specification in PUBDEFs in OBJ.
2139
2140\b Improved ease of adding new output formats. Contribution due to
2141Fox Cutter.
2142
2143\b Fixed a bug in relocations in the `bin' format: was showing up when
2144a relocatable reference crossed an 8192-byte boundary in any output
2145section.
2146
2147\b Fixed a bug in local labels: local-label lookups were inconsistent
2148between passes one and two if an EQU occurred between the definition
2149of a global label and the subsequent use of a local label local to
2150that global.
2151
2152\b Fixed a seg-fault in the preprocessor (again) which happened when
2153you use a blank line as the first line of a multi-line macro
2154definition and then defined a label on the same line as a call to
2155that macro.
2156
2157\b Fixed a stale-pointer bug in the handling of the NASM environment
2158variable. Thanks to Thomas McWilliams.
2159
2160\b ELF had a hard limit on the number of sections which caused
2161segfaults when transgressed. Fixed.
2162
2163\b Added ability for ndisasm to read from stdin by using `-' as the
2164filename.
2165
2166\b ndisasm wasn't outputting the TO keyword. Fixed.
2167
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002168\b Fixed error cascade on bogus expression in \c{%if} - an error in
2169evaluation was causing the entire \c{%if} to be discarded, thus creating
2170trouble later when the \c{%else} or \c{%endif} was encountered.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002171
2172\b Forward reference tracking was instruction-granular not operand-
2173granular, which was causing 286-specific code to be generated
2174needlessly on code of the form `shr word [forwardref],1'. Thanks to
2175Jim Hague for sending a patch.
2176
2177\b All messages now appear on stdout, as sending them to stderr serves
2178no useful purpose other than to make redirection difficult.
2179
2180\b Fixed the problem with EQUs pointing to an external symbol - this
2181now generates an error message.
2182
2183\b Allowed multiple size prefixes to an operand, of which only the first
2184is taken into account.
2185
2186\b Incorporated John Fine's changes, including fixes of a large number
2187of preprocessor bugs, some small problems in OBJ, and a reworking of
2188label handling to define labels before their line is assembled, rather
2189than after.
2190
2191\b Reformatted a lot of the source code to be more readable. Included
2192'coding.txt' as a guideline for how to format code for contributors.
2193
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002194\b Stopped nested \c{%reps} causing a panic - they now cause a slightly more
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002195friendly error message instead.
2196
2197\b Fixed floating point constant problems (patch by Pedro Gimeno)
2198
2199\b Fixed the return value of insn_size() not being checked for -1, indicating
2200an error.
2201
2202\b Incorporated 3Dnow! instructions.
2203
2204\b Fixed the 'mov eax, eax + ebx' bug.
2205
2206\b Fixed the GLOBAL EQU bug in ELF. Released developers release 3.
2207
2208\b Incorporated John Fine's command line parsing changes
2209
2210\b Incorporated David Lindauer's OMF debug support
2211
2212\b Made changes for LCC 4.0 support (\c{__NASM_CDecl__}, removed register size
2213specification warning when sizes agree).
2214
2215
2216\H{cl-0.9x} NASM 0.9 Series
2217
2218Revisions before 0.98.
2219
2220
2221\S{cl-0.97} Version 0.97 released December 1997
2222
2223\b This was entirely a bug-fix release to 0.96, which seems to have got
2224cursed. Silly me.
2225
2226\b Fixed stupid mistake in OBJ which caused `MOV EAX,<constant>' to
2227fail. Caused by an error in the `MOV EAX,<segment>' support.
2228
2229\b ndisasm hung at EOF when compiled with lcc on Linux because lcc on
2230Linux somehow breaks feof(). ndisasm now does not rely on feof().
2231
2232\b A heading in the documentation was missing due to a markup error in
2233the indexing. Fixed.
2234
2235\b Fixed failure to update all pointers on realloc() within extended-
2236operand code in parser.c. Was causing wrong behaviour and seg faults
2237on lines such as `dd 0.0,0.0,0.0,0.0,...'
2238
2239\b Fixed a subtle preprocessor bug whereby invoking one multi-line
2240macro on the first line of the expansion of another, when the second
2241had been invoked with a label defined before it, didn't expand the
H. Peter Anvinf805cde2017-02-23 17:19:56 -08002242inner macro.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002243
2244\b Added internal.doc back in to the distribution archives - it was
2245missing in 0.96 *blush*
2246
2247\b Fixed bug causing 0.96 to be unable to assemble its own test files,
2248specifically objtest.asm. *blush again*
2249
2250\b Fixed seg-faults and bogus error messages caused by mismatching
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002251\c{%rep} and \c{%endrep} within multi-line macro definitions.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002252
2253\b Fixed a problem with buffer overrun in OBJ, which was causing
2254corruption at ends of long PUBDEF records.
2255
2256\b Separated DOS archives into main-program and documentation to reduce
2257download size.
2258
2259
2260\S{cl-0.96} Version 0.96 released November 1997
2261
2262\b Fixed a bug whereby, if `nasm sourcefile' would cause a filename
2263collision warning and put output into `nasm.out', then `nasm
2264sourcefile -o outputfile' still gave the warning even though the
2265`-o' was honoured.
2266Fixed name pollution under Digital UNIX: one of its header files
2267defined R_SP, which broke the enum in nasm.h.
2268
2269\b Fixed minor instruction table problems: FUCOM and FUCOMP didn't have
2270two-operand forms; NDISASM didn't recognise the longer register
2271forms of PUSH and POP (eg FF F3 for PUSH BX); TEST mem,imm32 was
2272flagged as undocumented; the 32-bit forms of CMOV had 16-bit operand
2273size prefixes; `AAD imm' and `AAM imm' are no longer flagged as
2274undocumented because the Intel Architecture reference documents
2275them.
2276
2277\b Fixed a problem with the local-label mechanism, whereby strange
2278types of symbol (EQUs, auto-defined OBJ segment base symbols)
2279interfered with the `previous global label' value and screwed up
2280local labels.
2281
2282\b Fixed a bug whereby the stub preprocessor didn't communicate with
2283the listing file generator, so that the -a and -l options in
2284conjunction would produce a useless listing file.
2285
2286\b Merged `os2' object file format back into `obj', after discovering
2287that `obj' _also_ shouldn't have a link pass separator in a module
2288containing a non-trivial MODEND. Flat segments are now declared
2289using the FLAT attribute. `os2' is no longer a valid object format
2290name: use `obj'.
2291
2292\b Removed the fixed-size temporary storage in the evaluator. Very very
2293long expressions (like `mov ax,1+1+1+1+...' for two hundred 1s or
2294so) should now no longer crash NASM.
2295
2296\b Fixed a bug involving segfaults on disassembly of MMX instructions,
2297by changing the meaning of one of the operand-type flags in nasm.h.
2298This may cause other apparently unrelated MMX problems; it needs to
2299be tested thoroughly.
2300
2301\b Fixed some buffer overrun problems with large OBJ output files.
2302Thanks to DJ Delorie for the bug report and fix.
2303
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002304\b Made preprocess-only mode actually listen to the \c{%line} markers as it
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002305prints them, so that it can report errors more sanely.
2306
2307\b Re-designed the evaluator to keep more sensible track of expressions
2308involving forward references: can now cope with previously-nightmare
2309situations such as:
2310
2311\c mov ax,foo | bar
2312\c foo equ 1
2313\c bar equ 2
2314
2315\b Added the ALIGN and ALIGNB standard macros.
2316
2317\b Added PIC support in ELF: use of WRT to obtain the four extra
2318relocation types needed.
2319
2320\b Added the ability for output file formats to define their own
2321extensions to the GLOBAL, COMMON and EXTERN directives.
2322
2323\b Implemented common-variable alignment, and global-symbol type and
2324size declarations, in ELF.
2325
2326\b Implemented NEAR and FAR keywords for common variables, plus
2327far-common element size specification, in OBJ.
2328
2329\b Added a feature whereby EXTERNs and COMMONs in OBJ can be given a
2330default WRT specification (either a segment or a group).
2331
2332\b Transformed the Unix NASM archive into an auto-configuring package.
2333
2334\b Added a sanity-check for people applying SEG to things which are
2335already segment bases: this previously went unnoticed by the SEG
2336processing and caused OBJ-driver panics later.
2337
2338\b Added the ability, in OBJ format, to deal with `MOV EAX,<segment>'
2339type references: OBJ doesn't directly support dword-size segment
2340base fixups, but as long as the low two bytes of the constant term
2341are zero, a word-size fixup can be generated instead and it will
2342work.
2343
2344\b Added the ability to specify sections' alignment requirements in
2345Win32 object files and pure binary files.
2346
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002347\b Added preprocess-time expression evaluation: the \c{%assign} (and
2348\c{%iassign}) directive and the bare \c{%if} (and \c{%elif}) conditional. Added
2349relational operators to the evaluator, for use only in \c{%if}
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002350constructs: the standard relationals = < > <= >= <> (and C-like
2351synonyms == and !=) plus low-precedence logical operators &&, ^^ and
2352||.
2353
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002354\b Added a preprocessor repeat construct: \c{%rep} / \c{%exitrep} / \c{%endrep}.
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002355
2356\b Added the __FILE__ and __LINE__ standard macros.
2357
2358\b Added a sanity check for number constants being greater than
23590xFFFFFFFF. The warning can be disabled.
2360
2361\b Added the %0 token whereby a variadic multi-line macro can tell how
2362many parameters it's been given in a specific invocation.
2363
2364\b Added \c{%rotate}, allowing multi-line macro parameters to be cycled.
2365
2366\b Added the `*' option for the maximum parameter count on multi-line
2367macros, allowing them to take arbitrarily many parameters.
2368
2369\b Added the ability for the user-level forms of EXTERN, GLOBAL and
2370COMMON to take more than one argument.
2371
2372\b Added the IMPORT and EXPORT directives in OBJ format, to deal with
2373Windows DLLs.
2374
H. Peter Anvin5506e1f2008-07-14 02:54:00 -04002375\b Added some more preprocessor \c{%if} constructs: \c{%ifidn} / \c{%ifidni} (exact
2376textual identity), and \c{%ifid} / \c{%ifnum} / \c{%ifstr} (token type testing).
H. Peter Anvin04156cd2008-07-14 02:45:57 -04002377
2378\b Added the ability to distinguish SHL AX,1 (the 8086 version) from
2379SHL AX,BYTE 1 (the 286-and-upwards version whose constant happens to
2380be 1).
2381
2382\b Added NetBSD/FreeBSD/OpenBSD's variant of a.out format, complete
2383with PIC shared library features.
2384
2385\b Changed NASM's idiosyncratic handling of FCLEX, FDISI, FENI, FINIT,
2386FSAVE, FSTCW, FSTENV, and FSTSW to bring it into line with the
2387otherwise accepted standard. The previous behaviour, though it was a
2388deliberate feature, was a deliberate feature based on a
2389misunderstanding. Apologies for the inconvenience.
2390
2391\b Improved the flexibility of ABSOLUTE: you can now give it an
2392expression rather than being restricted to a constant, and it can
2393take relocatable arguments as well.
2394
2395\b Added the ability for a variable to be declared as EXTERN multiple
2396times, and the subsequent definitions are just ignored.
2397
2398\b We now allow instruction prefixes (CS, DS, LOCK, REPZ etc) to be
2399alone on a line (without a following instruction).
2400
2401\b Improved sanity checks on whether the arguments to EXTERN, GLOBAL
2402and COMMON are valid identifiers.
2403
2404\b Added misc/exebin.mac to allow direct generation of .EXE files by
2405hacking up an EXE header using DB and DW; also added test/binexe.asm
2406to demonstrate the use of this. Thanks to Yann Guidon for
2407contributing the EXE header code.
2408
2409\b ndisasm forgot to check whether the input file had been successfully
2410opened. Now it does. Doh!
2411
2412\b Added the Cyrix extensions to the MMX instruction set.
2413
2414\b Added a hinting mechanism to allow [EAX+EBX] and [EBX+EAX] to be
2415assembled differently. This is important since [ESI+EBP] and
2416[EBP+ESI] have different default base segment registers.
2417
2418\b Added support for the PharLap OMF extension for 4096-byte segment
2419alignment.
2420
2421
2422\S{cl-0.95 released July 1997} Version 0.95 released July 1997
2423
2424\b Fixed yet another ELF bug. This one manifested if the user relied on
2425the default segment, and attempted to define global symbols without
2426first explicitly declaring the target segment.
2427
2428\b Added makefiles (for NASM and the RDF tools) to build Win32 console
2429apps under Symantec C++. Donated by Mark Junker.
2430
2431\b Added `macros.bas' and `insns.bas', QBasic versions of the Perl
2432scripts that convert `standard.mac' to `macros.c' and convert
2433`insns.dat' to `insnsa.c' and `insnsd.c'. Also thanks to Mark
2434Junker.
2435
2436\b Changed the diassembled forms of the conditional instructions so
2437that JB is now emitted as JC, and other similar changes. Suggested
2438list by Ulrich Doewich.
2439
2440\b Added `@' to the list of valid characters to begin an identifier
2441with.
2442
2443\b Documentary changes, notably the addition of the `Common Problems'
2444section in nasm.doc.
2445
2446\b Fixed a bug relating to 32-bit PC-relative fixups in OBJ.
2447
2448\b Fixed a bug in perm_copy() in labels.c which was causing exceptions
2449in cleanup_labels() on some systems.
2450
2451\b Positivity sanity check in TIMES argument changed from a warning to
2452an error following a further complaint.
2453
2454\b Changed the acceptable limits on byte and word operands to allow
2455things like `~10111001b' to work.
2456
2457\b Fixed a major problem in the preprocessor which caused seg-faults if
2458macro definitions contained blank lines or comment-only lines.
2459
2460\b Fixed inadequate error checking on the commas separating the
2461arguments to `db', `dw' etc.
2462
2463\b Fixed a crippling bug in the handling of macros with operand counts
2464defined with a `+' modifier.
2465
2466\b Fixed a bug whereby object file formats which stored the input file
2467name in the output file (such as OBJ and COFF) weren't doing so
2468correctly when the output file name was specified on the command
2469line.
2470
2471\b Removed [INC] and [INCLUDE] support for good, since they were
2472obsolete anyway.
2473
2474\b Fixed a bug in OBJ which caused all fixups to be output in 16-bit
2475(old-format) FIXUPP records, rather than putting the 32-bit ones in
2476FIXUPP32 (new-format) records.
2477
2478\b Added, tentatively, OS/2 object file support (as a minor variant on
2479OBJ).
2480
2481\b Updates to Fox Cutter's Borland C makefile, Makefile.bc2.
2482
2483\b Removed a spurious second fclose() on the output file.
2484
2485\b Added the `-s' command line option to redirect all messages which
2486would go to stderr (errors, help text) to stdout instead.
2487
2488\b Added the `-w' command line option to selectively suppress some
2489classes of assembly warning messages.
2490
2491\b Added the `-p' pre-include and `-d' pre-define command-line options.
2492
2493\b Added an include file search path: the `-i' command line option.
2494
2495\b Fixed a silly little preprocessor bug whereby starting a line with a
2496`%!' environment-variable reference caused an `unknown directive'
2497error.
2498
2499\b Added the long-awaited listing file support: the `-l' command line
2500option.
2501
2502\b Fixed a problem with OBJ format whereby, in the absence of any
2503explicit segment definition, non-global symbols declared in the
2504implicit default segment generated spurious EXTDEF records in the
2505output.
2506
2507\b Added the NASM environment variable.
2508
2509\b From this version forward, Win32 console-mode binaries will be
2510included in the DOS distribution in addition to the 16-bit binaries.
2511Added Makefile.vc for this purpose.
2512
2513\b Added `return 0;' to test/objlink.c to prevent compiler warnings.
2514
2515\b Added the __NASM_MAJOR__ and __NASM_MINOR__ standard defines.
2516
2517\b Added an alternative memory-reference syntax in which prefixing an
2518operand with `&' is equivalent to enclosing it in square brackets,
2519at the request of Fox Cutter.
2520
2521\b Errors in pass two now cause the program to return a non-zero error
2522code, which they didn't before.
2523
2524\b Fixed the single-line macro cycle detection, which didn't work at
2525all on macros with no parameters (caused an infinite loop). Also
2526changed the behaviour of single-line macro cycle detection to work
2527like cpp, so that macros like `extrn' as given in the documentation
2528can be implemented.
2529
2530\b Fixed the implementation of WRT, which was too restrictive in that
2531you couldn't do `mov ax,[di+abc wrt dgroup]' because (di+abc) wasn't
2532a relocatable reference.
2533
2534
2535\S{cl-0.94 released April 1997} Version 0.94 released April 1997
2536
2537
2538\b Major item: added the macro processor.
2539
2540\b Added undocumented instructions SMI, IBTS, XBTS and LOADALL286. Also
2541reorganised CMPXCHG instruction into early-486 and Pentium forms.
2542Thanks to Thobias Jones for the information.
2543
2544\b Fixed two more stupid bugs in ELF, which were causing `ld' to
2545continue to seg-fault in a lot of non-trivial cases.
2546
2547\b Fixed a seg-fault in the label manager.
2548
2549\b Stopped FBLD and FBSTP from _requiring_ the TWORD keyword, which is
2550the only option for BCD loads/stores in any case.
2551
2552\b Ensured FLDCW, FSTCW and FSTSW can cope with the WORD keyword, if
2553anyone bothers to provide it. Previously they complained unless no
2554keyword at all was present.
2555
2556\b Some forms of FDIV/FDIVR and FSUB/FSUBR were still inverted: a
2557vestige of a bug that I thought had been fixed in 0.92. This was
2558fixed, hopefully for good this time...
2559
2560\b Another minor phase error (insofar as a phase error can _ever_ be
2561minor) fixed, this one occurring in code of the form
2562
2563\c rol ax,forward_reference
2564\c forward_reference equ 1
2565
2566\b The number supplied to TIMES is now sanity-checked for positivity,
2567and also may be greater than 64K (which previously didn't work on
256816-bit systems).
2569
2570\b Added Watcom C makefiles, and misc/pmw.bat, donated by Dominik Behr.
2571
2572\b Added the INCBIN pseudo-opcode.
2573
2574\b Due to the advent of the preprocessor, the [INCLUDE] and [INC]
2575directives have become obsolete. They are still supported in this
2576version, with a warning, but won't be in the next.
2577
2578\b Fixed a bug in OBJ format, which caused incorrect object records to
2579be output when absolute labels were made global.
2580
2581\b Updates to RDOFF subdirectory, and changes to outrdf.c.
2582
2583
2584\S{cl-0.93 released January 1997} Version 0.93 released January 1997
2585
2586This release went out in a great hurry after semi-crippling bugs
2587were found in 0.92.
2588
2589\b Really \e{did} fix the stack overflows this time. *blush*
2590
2591\b Had problems with EA instruction sizes changing between passes, when
2592an offset contained a forward reference and so 4 bytes were
2593allocated for the offset in pass one; by pass two the symbol had
2594been defined and happened to be a small absolute value, so only 1
2595byte got allocated, causing instruction size mismatch between passes
2596and hence incorrect address calculations. Fixed.
2597
2598\b Stupid bug in the revised ELF section generation fixed (associated
2599string-table section for .symtab was hard-coded as 7, even when this
2600didn't fit with the real section table). Was causing `ld' to
2601seg-fault under Linux.
2602
2603\b Included a new Borland C makefile, Makefile.bc2, donated by Fox
2604Cutter <lmb@comtch.iea.com>.
2605
2606
2607\S{cl-0.92 released January 1997} Version 0.92 released January 1997
2608
2609\b The FDIVP/FDIVRP and FSUBP/FSUBRP pairs had been inverted: this was
2610fixed. This also affected the LCC driver.
2611
2612\b Fixed a bug regarding 32-bit effective addresses of the form
2613\c{[other_register+ESP]}.
2614
2615\b Documentary changes, notably documentation of the fact that Borland
2616Win32 compilers use `obj' rather than `win32' object format.
2617
2618\b Fixed the COMENT record in OBJ files, which was formatted
2619incorrectly.
2620
2621\b Fixed a bug causing segfaults in large RDF files.
2622
2623\b OBJ format now strips initial periods from segment and group
2624definitions, in order to avoid complications with the local label
2625syntax.
2626
2627\b Fixed a bug in disassembling far calls and jumps in NDISASM.
2628
2629\b Added support for user-defined sections in COFF and ELF files.
2630
2631\b Compiled the DOS binaries with a sensible amount of stack, to
2632prevent stack overflows on any arithmetic expression containing
2633parentheses.
2634
2635\b Fixed a bug in handling of files that do not terminate in a newline.
2636
2637
2638\S{cl-0.91 released November 1996} Version 0.91 released November 1996
2639
2640\b Loads of bug fixes.
2641
2642\b Support for RDF added.
2643
2644\b Support for DBG debugging format added.
2645
2646\b Support for 32-bit extensions to Microsoft OBJ format added.
2647
2648\b Revised for Borland C: some variable names changed, makefile added.
2649
2650\b LCC support revised to actually work.
2651
2652\b JMP/CALL NEAR/FAR notation added.
2653
2654\b `a16', `o16', `a32' and `o32' prefixes added.
2655
2656\b Range checking on short jumps implemented.
2657
2658\b MMX instruction support added.
2659
2660\b Negative floating point constant support added.
2661
2662\b Memory handling improved to bypass 64K barrier under DOS.
2663
2664\b \c{$} prefix to force treatment of reserved words as identifiers added.
2665
2666\b Default-size mechanism for object formats added.
2667
2668\b Compile-time configurability added.
2669
2670\b \c{#}, \c{@}, \c{~} and c\{?} are now valid characters in labels.
2671
2672\b \c{-e} and \c{-k} options in NDISASM added.
2673
2674
2675\S{cl-0.90 released October 1996} Version 0.90 released October 1996
2676
2677First release version. First support for object file output. Other
2678changes from previous version (0.3x) too numerous to document.