]> git.ipfire.org Git - thirdparty/binutils-gdb.git/blame - gas/NEWS
MIPS: Add Global INValidate ASE support
[thirdparty/binutils-gdb.git] / gas / NEWS
CommitLineData
252b5132 1-*- text -*-
96a84ea3 2
6f20c942
FS
3* Add support for the MIPS Global INValidate (GINV) ASE.
4
730c3174
SE
5* Add support for the MIPS Cyclic Redudancy Check (CRC) ASE.
6
7b4ae824
JD
7* Add support for the Freescale S12Z architecture.
8
0df8ad28
NC
9* Add --generate-missing-build-notes=[yes|no] option to create (or not) GNU
10 Build Attribute notes if none are present in the input sources. Add a
11 --enable-generate-build-notes=[yes|no] configure time option to set the
12 default behaviour. Set the default if the configure option is not used
13 to "no".
14
bd5dea88
L
15* Remove -mold-gcc command-line option for x86 targets.
16
b6f8c7c4
L
17* Add -O[2|s] command-line options to x86 assembler to enable alternate
18 shorter instruction encoding.
19
8f065d3b 20* Add support for .nops directive. It is currently supported only for
62a02d25
L
21 x86 targets.
22
9176ac5b
NC
23Changes in 2.30:
24
ba8826a8
AO
25* Add support for loaction views in DWARF debug line information.
26
55a09eb6
TG
27Changes in 2.29:
28
a91e1603
L
29* Add support for ELF SHF_GNU_MBIND.
30
f96bd6c2
PC
31* Add support for the WebAssembly file format and wasm32 ELF conversion.
32
7e0de605 33* PowerPC gas now checks that the correct register class is used in
ece5dcc1
AM
34 instructions. For instance, "addi %f4,%cr3,%r31" warns three times
35 that the registers are invalid.
7e0de605 36
93f11b16
DD
37* Add support for the Texas Instruments PRU processor.
38
0cda1e19
TP
39* Support for the ARMv8-R architecture and Cortex-R52 processor has been
40 added to the ARM port.
ced40572 41
9703a4ef
TG
42Changes in 2.28:
43
e23eba97
NC
44* Add support for the RISC-V architecture.
45
b19ea8d2 46* Add support for the ARM Cortex-M23 and Cortex-M33 processors.
ce1b0a45 47
96a84ea3
TG
48Changes in 2.27:
49
4e3e1fdf
L
50* Default to --enable-compressed-debug-sections=gas for Linux/x86 targets.
51
2edb36e7
NC
52* Add --no-pad-sections to stop the assembler from padding the end of output
53 sections up to their alignment boundary.
54
15afaa63
TP
55* Support for the ARMv8-M architecture has been added to the ARM port. Support
56 for the ARMv8-M Security and DSP Extensions has also been added to the ARM
57 port.
58
f36e33da
CZ
59* ARC backend accepts .extInstruction, .extCondCode, .extAuxRegister, and
60 .extCoreRegister pseudo-ops that allow an user to define custom
61 instructions, conditional codes, auxiliary and core registers.
62
b8871f35
L
63* Add a configure option --enable-elf-stt-common to decide whether ELF
64 assembler should generate common symbols with the STT_COMMON type by
65 default. Default to no.
66
67* New command line option --elf-stt-common= for ELF targets to control
68 whether to generate common symbols with the STT_COMMON type.
69
9fb71ee4
NC
70* Add ability to set section flags and types via numeric values for ELF
71 based targets.
81c23f82 72
0cb4071e
L
73* Add a configure option --enable-x86-relax-relocations to decide whether
74 x86 assembler should generate relax relocations by default. Default to
75 yes, except for x86 Solaris targets older than Solaris 12.
76
77* New command line option -mrelax-relocations= for x86 target to control
78 whether to generate relax relocations.
79
9d3fc4e1
L
80* New command line option -mfence-as-lock-add=yes for x86 target to encode
81 lfence, mfence and sfence as "lock addl $0x0, (%[re]sp)".
82
4670103e
CZ
83* Add assembly-time relaxation option for ARC cpus.
84
9004b6bd
AB
85* Add --with-cpu=TYPE configure option for ARC gas. This allows the default
86 cpu type to be adjusted at configure time.
87
7feec526
TG
88Changes in 2.26:
89
edeefb67
L
90* Add a configure option --enable-compressed-debug-sections={all,gas} to
91 decide whether DWARF debug sections should be compressed by default.
e12fe555 92
886a2506
NC
93* Add support for the ARC EM/HS, and ARC600/700 architectures. Remove
94 assembler support for Argonaut RISC architectures.
95
d02603dc
NC
96* Symbol and label names can now be enclosed in double quotes (") which allows
97 them to contain characters that are not part of valid symbol names in high
98 level languages.
99
f33026a9
MW
100* Added the correctly spelled -march=armv6kz, for ARMv6KZ support. The
101 previous spelling, -march=armv6zk, is still accepted.
102
88f0ea34
MW
103* Support for the ARMv8.1 architecture has been added to the Aarch64 port.
104 Support for the individual ARMv8.1 Adv.SIMD, LOR and PAN architecture
105 extensions has also been added to the Aarch64 port.
106
a5932920
MW
107* Support for the ARMv8.1 architecture has been added to the ARM port. Support
108 for the individual ARMv8.1 Adv.SIMD and PAN architecture extensions has also
109 been added to the ARM port.
110
ea556d25
L
111* Extend --compress-debug-sections option to support
112 --compress-debug-sections=[none|zlib|zlib-gnu|zlib-gabi] for ELF
113 targets.
114
0d2b51ad
L
115* --compress-debug-sections is turned on for Linux/x86 by default.
116
c50415e2
TG
117Changes in 2.25:
118
f36e8886
BS
119* Add support for the AVR Tiny microcontrollers.
120
73589c9d
CS
121* Replace support for openrisc and or32 with support for or1k.
122
2e6976a8
DG
123* Enhanced the ARM port to accept the assembler output from the CodeComposer
124 Studio tool. Support is enabled via the new command line option -mccs.
125
35c08157
KLC
126* Add support for the Andes NDS32.
127
58ca03a2
TG
128Changes in 2.24:
129
13761a11
NC
130* Add support for the Texas Instruments MSP430X processor.
131
b40bf0a2
NC
132* Add -gdwarf-sections command line option to enable per-code-section
133 generation of DWARF .debug_line sections.
134
36591ba1
SL
135* Add support for Altera Nios II.
136
a3c62988
NC
137* Add support for the Imagination Technologies Meta processor.
138
5bf135a7
NC
139* Add support for the v850e3v5.
140
e8044f35
RS
141* Remove assembler support for MIPS ECOFF targets.
142
af18cb59
TG
143Changes in 2.23:
144
da2bb560
NC
145* Add support for the 64-bit ARM architecture: AArch64.
146
6927f982
NC
147* Add support for S12X processor.
148
b9c361e0
JL
149* Add support for the VLE extension to the PowerPC architecture.
150
f6c1a2d5
NC
151* Add support for the Freescale XGATE architecture.
152
fa94de6b
RM
153* Add support for .bundle_align_mode, .bundle_lock, and .bundle_unlock
154 directives. These are currently available only for x86 and ARM targets.
155
99c513f6
DD
156* Add support for the Renesas RL78 architecture.
157
cfb8c092
NC
158* Add support for the Adapteva EPIPHANY architecture.
159
fe13e45b 160* For x86, allow 'rep bsf', 'rep bsr', and 'rep ret' syntax.
29c048b6 161
a7142d94
TG
162Changes in 2.22:
163
69f56ae1 164* Add support for the Tilera TILEPro and TILE-Gx architectures.
44f45767 165
90b3661c 166Changes in 2.21:
44f45767 167
5fec8599
L
168* Gas no longer requires doubling of ampersands in macros.
169
40b36596
JM
170* Add support for the TMS320C6000 (TI C6X) processor family.
171
31907d5e
DK
172* GAS now understands an extended syntax in the .section directive flags
173 for COFF targets that allows the section's alignment to be specified. This
174 feature has also been backported to the 2.20 release series, starting with
175 2.20.1.
176
c7927a3c
NC
177* Add support for the Renesas RX processor.
178
700c4060
CC
179* New command line option, --compress-debug-sections, which requests
180 compression of DWARF debug information sections in the relocatable output
181 file. Compressed debug sections are supported by readelf, objdump, and
182 gold, but not currently by Gnu ld.
183
81c23f82
TG
184Changes in 2.20:
185
1cd986c5
NC
186* Added support for v850e2 and v850e2v3.
187
3e7a7d11
NC
188* GNU/Linux targets now supports "gnu_unique_object" as a value in the .type
189 pseudo op. It marks the symbol as being globally unique in the entire
190 process.
191
c921be7d
NC
192* ARM assembler now supports .inst[.nw] pseudo-ops to insert opcodes specified
193 in binary rather than text.
6e33da12 194
c1711530
DK
195* Add support for common symbol alignment to PE formats.
196
92846e72
CC
197* Add support for the new discriminator column in the DWARF line table,
198 with a discriminator operand for the .loc directive.
199
c3b7224a
NC
200* Add support for Sunplus score architecture.
201
d8045f23
NC
202* The .type pseudo-op now accepts a type of STT_GNU_IFUNC which can be used to
203 indicate that if the symbol is the target of a relocation, its value should
204 not be use. Instead the function should be invoked and its result used as
205 the value.
fa94de6b 206
84e94c90
NC
207* Add support for Lattice Mico32 (lm32) architecture.
208
fa94de6b 209* Add support for Xilinx MicroBlaze architecture.
caa03924 210
6e33da12
TG
211Changes in 2.19:
212
4f6d9c90
DJ
213* New pseudo op .cfi_val_encoded_addr, to record constant addresses in unwind
214 tables without runtime relocation.
215
6fd4f6cc
DD
216* New command line option, -h-tick-hex, for sh, m32c, and h8/300 targets, which
217 adds compatibility with H'00 style hex constants.
218
daf50ae7
L
219* New command line option, -msse-check=[none|error|warning], for x86
220 targets.
221
83f10cb2
NC
222* New sub-option added to the assembler's -a command line switch to
223 generate a listing output. The 'g' sub-option will insert into the listing
224 various information about the assembly, such as assembler version, the
225 command line options used, and a time stamp.
226
c0f3af97
L
227* New command line option -msse2avx for x86 target to encode SSE
228 instructions with VEX prefix.
229
f1f8f695 230* Add Intel XSAVE, EPT, MOVBE, AES, PCLMUL, AVX/FMA support for x86 target.
c0f3af97 231
ae40c993
L
232* New command line options, -march=CPU[,+EXTENSION...], -mtune=CPU,
233 -mmnemonic=[att|intel], -msyntax=[att|intel], -mindex-reg,
234 -mnaked-reg and -mold-gcc, for x86 targets.
235
38a57ae7
NC
236* Support for generating wide character strings has been added via the new
237 pseudo ops: .string16, .string32 and .string64.
238
85f10a01
MM
239* Support for SSE5 has been added to the i386 port.
240
7c3d153f
NC
241Changes in 2.18:
242
ec2655a6
NC
243* The GAS sources are now released under the GPLv3.
244
3d3d428f
NC
245* Support for the National Semiconductor CR16 target has been added.
246
3f9ce309
AM
247* Added gas .reloc pseudo. This is a low-level interface for creating
248 relocations.
249
99ad8390
NC
250* Add support for x86_64 PE+ target.
251
1c0d3aa6 252* Add support for Score target.
83518699 253
ec2655a6
NC
254Changes in 2.17:
255
d70c5fc7
NC
256* Support for the Infineon XC16X has been added by KPIT Cummins Infosystems.
257
08333dc4
NS
258* Support for ms2 architecture has been added.
259
b7b8fb1d
NC
260* Support for the Z80 processor family has been added.
261
3e8a519c
MM
262* Add support for the "@<file>" syntax to the command line, so that extra
263 switches can be read from <file>.
264
37dedf66
NC
265* The SH target supports a new command line switch --enable-reg-prefix which,
266 if enabled, will allow register names to be optionally prefixed with a $
267 character. This allows register names to be distinguished from label names.
fa94de6b 268
6eaeac8a
JB
269* Macros with a variable number of arguments are now supported. See the
270 documentation for how this works.
271
4bdd3565
NC
272* Added --reduce-memory-overheads switch to reduce the size of the hash
273 tables used, at the expense of longer assembly times, and
274 --hash-size=<NUMBER> to set the size of the hash tables used by gas.
275
5e75c3ab
JB
276* Macro names and macro parameter names can now be any identifier that would
277 also be legal as a symbol elsewhere. For macro parameter names, this is
278 known to cause problems in certain sources when the respective target uses
279 characters inconsistently, and thus macro parameter references may no longer
280 be recognized as such (see the documentation for details).
fa94de6b 281
d2c5f73e
NC
282* Support the .f_floating, .d_floating, .g_floating and .h_floating directives
283 for the VAX target in order to be more compatible with the VAX MACRO
284 assembler.
285
8c2fda1d
L
286* New command line option -mtune=[itanium1|itanium2] for IA64 targets.
287
957d91c1
NC
288Changes in 2.16:
289
fffeaa5f
JB
290* Redefinition of macros now results in an error.
291
91d777ee
L
292* New command line option -mhint.b=[ok|warning|error] for IA64 targets.
293
970d6792
L
294* New command line option -munwind-check=[warning|error] for IA64
295 targets.
296
f1dab70d
JB
297* The IA64 port now uses automatic dependency violation removal as its default
298 mode.
299
7499d566
NC
300* Port to MAXQ processor contributed by HCL Tech.
301
7ed4c4c5
NC
302* Added support for generating unwind tables for ARM ELF targets.
303
329e276d
NC
304* Add a -g command line option to generate debug information in the target's
305 preferred debug format.
306
1fe1f39c
NC
307* Support for the crx-elf target added.
308
1a320fbb 309* Support for the sh-symbianelf target added.
1fe1f39c 310
0503b355
BF
311* Added a pseudo-op (.secrel32) to generate 32 bit section relative relocations
312 on pe[i]-i386; required for this target's DWARF 2 support.
313
6b6e92f4
NC
314* Support for Motorola MCF521x/5249/547x/548x added.
315
fd99574b
NC
316* Support for ColdFire EMAC instructions added and Motorola syntax for MAC/EMAC
317 instrucitons.
318
aa6975fb
ILT
319* New command line option -mno-shared for MIPS ELF targets.
320
caa32fe5
NC
321* New command line option --alternate and pseudo-ops .altmacro and .noaltmacro
322 added to enter (and leave) alternate macro syntax mode.
323
0477af35
NC
324Changes in 2.15:
325
7a7f4e42
CD
326* The MIPS -membedded-pic option (Embedded-PIC code generation) is
327 deprecated and will be removed in a future release.
328
6edf0760
NC
329* Added PIC m32r Linux (ELF) and support to M32R assembler.
330
09d92015
MM
331* Added support for ARM V6.
332
88da98f3
MS
333* Added support for sh4a and variants.
334
eb764db8
NC
335* Support for Renesas M32R2 added.
336
88da98f3
MS
337* Limited support for Mapping Symbols as specified in the ARM ELF
338 specification has been added to the arm assembler.
ed769ec1 339
0bbf2aa4
NC
340* On ARM architectures, added a new gas directive ".unreq" that undoes
341 definitions created by ".req".
342
3e602632
NC
343* Support for Motorola ColdFire MCF528x added.
344
05da4302
NC
345* Added --gstabs+ switch to enable the generation of STABS debug format
346 information with GNU extensions.
fa94de6b 347
6a265366
CD
348* Added support for MIPS64 Release 2.
349
8ad30312
NC
350* Added support for v850e1.
351
12b55ccc
L
352* Added -n switch for x86 assembler. By default, x86 GAS replaces
353 multiple nop instructions used for alignment within code sections
354 with multi-byte nop instructions such as leal 0(%esi,1),%esi. This
355 switch disables the optimization.
356
78849248
ILT
357* Removed -n option from MIPS assembler. It was not useful, and confused the
358 existing -non_shared option.
359
43c58ae6
CD
360Changes in 2.14:
361
69be0a2b
CD
362* Added support for MIPS32 Release 2.
363
e8fd7476
NC
364* Added support for Xtensa architecture.
365
e16bb312
NC
366* Support for Intel's iWMMXt processor (an ARM variant) added.
367
cce4814f
NC
368* An assembler test generator has been contributed and an example file that
369 uses it (gas/testsuite/gas/all/test-gen.c and test-exmaple.c).
fa94de6b 370
5177500f
NC
371* Support for SH2E added.
372
fea17916
NC
373* GASP has now been removed.
374
004d9caf
NC
375* Support for Texas Instruments TMS320C4x and TMS320C3x series of
376 DSP's contributed by Michael Hayes and Svein E. Seldal.
fa94de6b 377
a40cbfa3
NC
378* Support for the Ubicom IP2xxx microcontroller added.
379
2cbb2eef
NC
380Changes in 2.13:
381
a40cbfa3
NC
382* Support for the Fujitsu FRV architecture added by Red Hat. Models for FR400
383 and FR500 included.
0ebb9a87 384
a40cbfa3 385* Support for DLX processor added.
52216602 386
a40cbfa3
NC
387* GASP has now been deprecated and will be removed in a future release. Use
388 the macro facilities in GAS instead.
3f965e60 389
a40cbfa3
NC
390* GASP now correctly parses floating point numbers. Unless the base is
391 explicitly specified, they are interpreted as decimal numbers regardless of
392 the currently specified base.
1ac57253 393
9a66911f
NC
394Changes in 2.12:
395
a40cbfa3 396* Support for Don Knuth's MMIX, by Hans-Peter Nilsson.
49fda6c8 397
a40cbfa3 398* Support for the OpenRISC 32-bit embedded processor by OpenCores.
3b16e843 399
fa94de6b
RM
400* The ARM assembler now accepts -march=..., -mcpu=... and -mfpu=... for
401 specifying the target instruction set. The old method of specifying the
a40cbfa3
NC
402 target processor has been deprecated, but is still accepted for
403 compatibility.
03b1477f 404
a40cbfa3
NC
405* Support for the VFP floating-point instruction set has been added to
406 the ARM assembler.
252b5132 407
a40cbfa3
NC
408* New psuedo op: .incbin to include a set of binary data at a given point
409 in the assembly. Contributed by Anders Norlander.
7e005732 410
a40cbfa3
NC
411* The MIPS assembler now accepts -march/-mtune. -mcpu has been deprecated
412 but still works for compatability.
ec68c924 413
fa94de6b 414* The MIPS assembler no longer issues a warning by default when it
a40cbfa3
NC
415 generates a nop instruction from a macro. The new command line option
416 -n will turn on the warning.
63486801 417
2dac7317
JW
418Changes in 2.11:
419
500800ca
NC
420* Support for PDP-11 and 2.11BSD a.out format, by Lars Brinkhoff.
421
a40cbfa3 422* x86 gas now supports the full Pentium4 instruction set.
a167610d 423
a40cbfa3 424* Support for AMD x86-64 architecture, by Jan Hubicka, SuSE Labs.
c0d8940f 425
a40cbfa3 426* Support for Motorola 68HC11 and 68HC12.
df86943d 427
a40cbfa3 428* Support for Texas Instruments TMS320C54x (tic54x).
39bec121 429
a40cbfa3 430* Support for IA-64.
2dac7317 431
a40cbfa3 432* Support for i860, by Jason Eckhardt.
22b36938 433
a40cbfa3 434* Support for CRIS (Axis Communications ETRAX series).
5bcac8a4 435
a40cbfa3 436* x86 gas has a new .arch pseudo op to specify the target CPU architecture.
a38cf1db 437
a40cbfa3
NC
438* x86 gas -q command line option quietens warnings about register size changes
439 due to suffix, indirect jmp/call without `*', stand-alone prefixes, and
440 translating various deprecated floating point instructions.
a38cf1db 441
252b5132
RH
442Changes in 2.10:
443
a40cbfa3
NC
444* Support for the ARM msr instruction was changed to only allow an immediate
445 operand when altering the flags field.
d14442f4 446
a40cbfa3 447* Support for ATMEL AVR.
adde6300 448
a40cbfa3 449* Support for IBM 370 ELF. Somewhat experimental.
b5ebe70e 450
a40cbfa3 451* Support for numbers with suffixes.
3fd9f047 452
a40cbfa3 453* Added support for breaking to the end of repeat loops.
6a6987a9 454
a40cbfa3 455* Added support for parallel instruction syntax (DOUBLEBAR_PARALLEL).
6a6987a9 456
a40cbfa3 457* New .elseif pseudo-op added.
3fd9f047 458
a40cbfa3 459* New --fatal-warnings option.
1f776aa5 460
a40cbfa3 461* picoJava architecture support added.
252b5132 462
a40cbfa3 463* Motorola MCore 210 processor support added.
041dd5a9 464
fa94de6b 465* A new pseudo-op .intel_syntax has been implemented to allow gas to parse i386
a40cbfa3 466 assembly programs with intel syntax.
252b5132 467
a40cbfa3 468* New pseudo-ops .func,.endfunc to aid in debugging user-written assembler code.
252b5132 469
a40cbfa3 470* Added -gdwarf2 option to generate DWARF 2 debugging information.
041dd5a9 471
a40cbfa3 472* Full 16-bit mode support for i386.
252b5132 473
fa94de6b 474* Greatly improved instruction operand checking for i386. This change will
a40cbfa3
NC
475 produce errors or warnings on incorrect assembly code that previous versions
476 of gas accepted. If you get unexpected messages from code that worked with
477 older versions of gas, please double check the code before reporting a bug.
252b5132 478
a40cbfa3 479* Weak symbol support added for COFF targets.
252b5132 480
a40cbfa3 481* Mitsubishi D30V support added.
252b5132 482
a40cbfa3 483* Texas Instruments c80 (tms320c80) support added.
252b5132 484
a40cbfa3 485* i960 ELF support added.
bedf545c 486
a40cbfa3 487* ARM ELF support added.
a057431b 488
252b5132
RH
489Changes in 2.9:
490
a40cbfa3 491* Texas Instruments c30 (tms320c30) support added.
252b5132 492
fa94de6b 493* The assembler now optimizes the exception frame information generated by egcs
a40cbfa3 494 and gcc 2.8. The new --traditional-format option disables this optimization.
252b5132 495
a40cbfa3 496* Added --gstabs option to generate stabs debugging information.
252b5132 497
fa94de6b 498* The -a option takes a new suboption, m (e.g., -alm) to expand macros in a
a40cbfa3 499 listing.
252b5132 500
a40cbfa3 501* Added -MD option to print dependencies.
252b5132
RH
502
503Changes in 2.8:
504
a40cbfa3 505* BeOS support added.
252b5132 506
a40cbfa3 507* MIPS16 support added.
252b5132 508
a40cbfa3 509* Motorola ColdFire 5200 support added (configure for m68k and use -m5200).
252b5132 510
a40cbfa3 511* Alpha/VMS support added.
252b5132 512
a40cbfa3
NC
513* m68k options --base-size-default-16, --base-size-default-32,
514 --disp-size-default-16, and --disp-size-default-32 added.
252b5132 515
a40cbfa3
NC
516* The alignment directives now take an optional third argument, which is the
517 maximum number of bytes to skip. If doing the alignment would require
518 skipping more than the given number of bytes, the alignment is not done at
519 all.
252b5132 520
a40cbfa3 521* The ELF assembler has a new pseudo-op, .symver, used for symbol versioning.
252b5132 522
a40cbfa3
NC
523* The -a option takes a new suboption, c (e.g., -alc), to skip false
524 conditionals in listings.
252b5132 525
a40cbfa3
NC
526* Added new pseudo-op, .equiv; it's like .equ, except that it is an error if
527 the symbol is already defined.
252b5132
RH
528
529Changes in 2.7:
530
a40cbfa3
NC
531* The PowerPC assembler now allows the use of symbolic register names (r0,
532 etc.) if -mregnames is used. Symbolic names preceded by a '%' (%r0, etc.)
533 can be used any time. PowerPC 860 move to/from SPR instructions have been
534 added.
252b5132 535
a40cbfa3 536* Alpha Linux (ELF) support added.
252b5132 537
a40cbfa3 538* PowerPC ELF support added.
252b5132 539
a40cbfa3 540* m68k Linux (ELF) support added.
252b5132 541
a40cbfa3 542* i960 Hx/Jx support added.
252b5132 543
a40cbfa3 544* i386/PowerPC gnu-win32 support added.
252b5132 545
a40cbfa3
NC
546* SCO ELF support added. For OpenServer 5 targets (i386-unknown-sco3.2v5) the
547 default is to build COFF-only support. To get a set of tools that generate
fa94de6b 548 ELF (they'll understand both COFF and ELF), you must configure with
a40cbfa3 549 target=i386-unknown-sco3.2v5elf.
252b5132 550
a40cbfa3 551* m88k-motorola-sysv3* support added.
252b5132
RH
552
553Changes in 2.6:
554
a40cbfa3 555* Gas now directly supports macros, without requiring GASP.
252b5132 556
a40cbfa3
NC
557* Gas now has an MRI assembler compatibility mode. Use -M or --mri to select
558 MRI mode. The pseudo-op ``.mri 1'' will switch into the MRI mode until the
559 ``.mri 0'' is seen; this can be convenient for inline assembler code.
252b5132 560
a40cbfa3 561* Added --defsym SYM=VALUE option.
252b5132 562
a40cbfa3 563* Added -mips4 support to MIPS assembler.
252b5132 564
a40cbfa3 565* Added PIC support to Solaris and SPARC SunOS 4 assembler.
252b5132
RH
566
567Changes in 2.4:
568
a40cbfa3 569* Converted this directory to use an autoconf-generated configure script.
252b5132 570
a40cbfa3 571* ARM support, from Richard Earnshaw.
252b5132 572
a40cbfa3
NC
573* Updated VMS support, from Pat Rankin, including considerably improved
574 debugging support.
252b5132 575
a40cbfa3 576* Support for the control registers in the 68060.
252b5132 577
a40cbfa3 578* Handles (ignores) a new directive ".this_GCC_requires_the_GNU_assembler", to
fa94de6b
RM
579 provide for possible future gcc changes, for targets where gas provides some
580 features not available in the native assembler. If the native assembler is
a40cbfa3 581 used, it should become obvious pretty quickly what the problem is.
252b5132 582
a40cbfa3 583* Usage message is available with "--help".
252b5132 584
fa94de6b 585* The GNU Assembler Preprocessor (gasp) is included. (Actually, it was in 2.3
a40cbfa3 586 also, but didn't get into the NEWS file.)
252b5132 587
a40cbfa3 588* Weak symbol support for a.out.
252b5132 589
fa94de6b 590* A bug in the listing code which could cause an infinite loop has been fixed.
a40cbfa3 591 Bugs in listings when generating a COFF object file have also been fixed.
252b5132 592
a40cbfa3
NC
593* Initial i386-svr4 PIC implementation from Eric Youngdale, based on code by
594 Paul Kranenburg.
252b5132 595
a40cbfa3
NC
596* Improved Alpha support. Immediate constants can have a much larger range
597 now. Support for the 21164 has been contributed by Digital.
252b5132 598
a40cbfa3 599* Updated ns32k (pc532-mach, netbsd532) support from Ian Dall.
252b5132
RH
600
601Changes in 2.3:
602
a40cbfa3 603* Mach i386 support, by David Mackenzie and Ken Raeburn.
252b5132 604
a40cbfa3 605* RS/6000 and PowerPC support by Ian Taylor.
252b5132 606
a40cbfa3
NC
607* VMS command scripts (make-gas.com, config-gas.com) have been worked on a bit,
608 based on mail received from various people. The `-h#' option should work
609 again too.
252b5132 610
a40cbfa3 611* HP-PA work, by Jeff Law. Note, for the PA, gas-2.3 has been designed to work
fa94de6b 612 with gdb-4.12 and gcc-2.6. As gcc-2.6 has not been released yet, a special
a40cbfa3
NC
613 version of gcc-2.5.8 has been patched to work with gas-2.3. You can retrieve
614 this special version of gcc-2.5.8 via anonymous ftp from jaguar.cs.utah.edu
615 in the "dist" directory.
252b5132 616
a40cbfa3
NC
617* Vax support in gas fixed for BSD, so it builds and seems to run a couple
618 simple tests okay. I haven't put it through extensive testing. (GNU make is
619 currently required for BSD 4.3 builds.)
252b5132 620
fa94de6b 621* Support for the DEC Alpha, running OSF/1 (ECOFF format). The gas support is
a40cbfa3
NC
622 based on code donated by CMU, which used an a.out-based format. I'm afraid
623 the alpha-a.out support is pretty badly mangled, and much of it removed;
624 making it work will require rewriting it as BFD support for the format anyways.
252b5132 625
a40cbfa3 626* Irix 5 support.
252b5132 627
fa94de6b 628* The test suites have been fixed up a bit, so that they should work with a
a40cbfa3 629 couple different versions of expect and dejagnu.
252b5132 630
fa94de6b
RM
631* Symbols' values are now handled internally as expressions, permitting more
632 flexibility in evaluating them in some cases. Some details of relocation
a40cbfa3
NC
633 handling have also changed, and simple constant pool management has been
634 added, to make the Alpha port easier.
252b5132 635
a40cbfa3
NC
636* New option "--statistics" for printing out program run times. This is
637 intended to be used with the gcc "-Q" option, which prints out times spent in
638 various phases of compilation. (You should be able to get all of them
639 printed out with "gcc -Q -Wa,--statistics", I think.)
252b5132
RH
640
641Changes in 2.2:
642
a40cbfa3 643* RS/6000 AIX and MIPS SGI Irix 5 support has been added.
252b5132 644
fa94de6b
RM
645* Configurations that are still in development (and therefore are convenient to
646 have listed in configure.in) still get rejected without a minor change to
a40cbfa3
NC
647 gas/Makefile.in, so people not doing development work shouldn't get the
648 impression that support for such configurations is actually believed to be
649 reliable.
252b5132 650
fa94de6b 651* The program name (usually "as") is printed when a fatal error message is
a40cbfa3
NC
652 displayed. This should prevent some confusion about the source of occasional
653 messages about "internal errors".
252b5132 654
fa94de6b 655* ELF support is falling into place. Support for the 386 should be working.
a40cbfa3 656 Support for SPARC Solaris is in. HPPA support from Utah is being integrated.
252b5132 657
a40cbfa3
NC
658* Symbol values are maintained as expressions instead of being immediately
659 boiled down to add-symbol, sub-symbol, and constant. This permits slightly
660 more complex calculations involving symbols whose values are not alreadey
661 known.
252b5132 662
a40cbfa3 663* DBX-style debugging info ("stabs") is now supported for COFF formats.
fa94de6b
RM
664 If any stabs directives are seen in the source, GAS will create two new
665 sections: a ".stab" and a ".stabstr" section. The format of the .stab
a40cbfa3
NC
666 section is nearly identical to the a.out symbol format, and .stabstr is
667 its string table. For this to be useful, you must have configured GCC
668 to generate stabs (by defining DBX_DEBUGGING_INFO), and must have a GDB
669 that can use the stab sections (4.11 or later).
252b5132 670
fa94de6b 671* LynxOS, on i386 and m68k platforms, is now supported. SPARC LynxOS
a40cbfa3 672 support is in progress.
252b5132
RH
673
674Changes in 2.1:
675
fa94de6b 676* Several small fixes for i386-aix (PS/2) support from Minh Tran-Le have been
a40cbfa3 677 incorporated, but not well tested yet.
252b5132 678
fa94de6b 679* Altered the opcode table split for m68k; it should require less VM to compile
a40cbfa3 680 with gcc now.
252b5132 681
a40cbfa3
NC
682* Some minor adjustments to add (Convergent Technologies') Miniframe support,
683 suggested by Ronald Cole.
252b5132 684
a40cbfa3
NC
685* HPPA support (running OSF only, not HPUX) has been contributed by Utah. This
686 includes improved ELF support, which I've started adapting for SPARC Solaris
687 2.x. Integration isn't completely, so it probably won't work.
252b5132 688
a40cbfa3 689* HP9000/300 support, donated by HP, has been merged in.
252b5132 690
a40cbfa3 691* Ian Taylor has finished the MIPS ECOFF (Ultrix, Irix) support.
252b5132 692
a40cbfa3 693* Better error messages for unsupported configurations (e.g., hppa-hpux).
252b5132 694
a40cbfa3 695* Test suite framework is starting to become reasonable.
252b5132
RH
696
697Changes in 2.0:
698
a40cbfa3 699* Mostly bug fixes.
252b5132 700
a40cbfa3 701* Some more merging of BFD and ELF code, but ELF still doesn't work.
252b5132
RH
702
703Changes in 1.94:
704
a40cbfa3
NC
705* BFD merge is partly done. Adventurous souls may try giving configure the
706 "--with-bfd-assembler" option. Currently, ELF format requires it, a.out
707 format accepts it; SPARC CPU accepts it. It's the default only for OS "elf"
708 or "solaris". (ELF isn't really supported yet. It needs work. I've got
709 some code from Utah for HP-PA ELF, and from DG for m88k ELF, but they're not
710 fully merged yet.)
252b5132 711
a40cbfa3
NC
712* The 68K opcode table has been split in half. It should now compile under gcc
713 without consuming ridiculous amounts of memory.
252b5132 714
a40cbfa3
NC
715* A couple data structures have been reduced in size. This should result in
716 saving a little bit of space at runtime.
252b5132 717
a40cbfa3
NC
718* Support for MIPS, from OSF and Ralph Campbell, has been merged in. The OSF
719 code provided ROSE format support, which I haven't merged in yet. (I can
720 make it available, if anyone wants to try it out.) Ralph's code, for BSD
721 4.4, supports a.out format. We don't have ECOFF support in just yet; it's
722 coming.
252b5132 723
a40cbfa3 724* Support for the Hitachi H8/500 has been added.
252b5132 725
a40cbfa3
NC
726* VMS host and target support should be working now, thanks chiefly to Eric
727 Youngdale.
252b5132
RH
728
729Changes in 1.93.01:
730
a40cbfa3 731* For m68k, support for more processors has been added: 68040, CPU32, 68851.
252b5132 732
a40cbfa3 733* For i386, .align is now power-of-two; was number-of-bytes.
252b5132 734
a40cbfa3
NC
735* For m68k, "%" is now accepted before register names. For COFF format, which
736 doesn't use underscore prefixes for C labels, it is required, so variable "a0"
737 can be distinguished from the register.
252b5132 738
a40cbfa3
NC
739* Last public release was 1.38. Lots of configuration changes since then, lots
740 of new CPUs and formats, lots of bugs fixed.
252b5132
RH
741
742\f
219d1afa 743Copyright (C) 2012-2018 Free Software Foundation, Inc.
5bf135a7
NC
744
745Copying and distribution of this file, with or without modification,
746are permitted in any medium without royalty provided the copyright
747notice and this notice are preserved.
748
252b5132
RH
749Local variables:
750fill-column: 79
751End: