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