Add support for stable secure gateway veneers addresses
[external/binutils.git] / ld / NEWS
1 -*- text -*-
2
3 Changes in 2.28:
4
5 * Add --in-implib=<infile> to the ARM linker to enable specifying a set of
6   Secure Gateway veneers that must exist in the output import library specified
7   by --out-implib=<outfile> and the address they must have.  As such,
8   --in-implib is only supported in combination with --cmse-implib.
9
10 * Extended the --out-implib=<file> option, previously restricted to x86 PE
11   targets, to any ELF based target.  This allows the generation of an import
12   library for an ELF executable, which can then be used by another application
13   to link against the executable.
14
15 Changes in 2.27:
16
17 * Add a configure option --enable-relro to decide whether -z relro should
18   be enabled in ELF linker by default.  Default to yes for all Linux
19   targets except FRV, HPPA, IA64 and MIPS.
20
21 * Support for -z noreloc-overflow in the x86-64 ELF linker to disable
22   relocation overflow check.
23
24 * Add -z common/-z nocommon options for ELF targets to control whether to
25   convert common symbols to the STT_COMMON type during a relocatable link.
26
27 * Support for -z nodynamic-undefined-weak in the x86 ELF linker, which
28   avoids dynamic relocations against undefined weak symbols in executable.
29
30 * The NOCROSSREFSTO command was added to the linker script language.
31
32 * Add --no-apply-dynamic-relocs to the AArch64 linker to do not apply link-time
33   values for dynamic relocations.
34
35 Changes in 2.26:
36
37 * Add --fix-stm32l4xx-629360 to the ARM linker to enable a link-time
38   workaround for a bug in the bus matrix / memory controller for some of
39   the STM32 Cortex-M4 based products (STM32L4xx)
40
41 * Add a configure option --enable-compressed-debug-sections={all,ld} to
42   decide whether DWARF debug sections should be compressed by default.
43
44 * Add support for the ARC EM/HS, and ARC600/700 architectures.
45
46 * Experimental support for linker garbage collection (--gc-sections)
47   has been enabled for COFF and PE based targets.
48
49 * New command line option for ELF targets to compress DWARF debug
50   sections, --compress-debug-sections=[none|zlib|zlib-gnu|zlib-gabi].
51
52 * New command line option, --orphan-handling=[place|warn|error|discard], to
53   adjust how orphan sections are handled.  The default is 'place' which gives
54   the current behaviour, 'warn' and 'error' issue a warning or error
55   respectively when orphan sections are found, and 'discard' will discard all
56   orphan sections.
57
58 * Add support for LLVM plugin.
59
60 * Add --print-memory-usage option to report memory blocks usage.
61
62 * Add --require-defined option, it's like --undefined except the new symbol
63   must be defined by the end of the link.
64
65 Changes in 2.25:
66
67 * PE binaries now once again contain real timestamps by default.  To disable
68   the inclusion of a timestamp in a PE binary, use the --no-insert-timestamp
69   command line option.
70
71 * Replace support for openrisc and or32 with support for or1k.
72
73 * Add support for the --build-id command line option to COFF based targets.
74
75 * x86/x86_64 pe-coff now supports the --build-id option.
76
77 * Add support for the Andes NDS32.
78
79 Changes in 2.24:
80
81 * Add LOG2CEIL() builtin function to the linker script language
82
83 * Add support for the Texas Instruments MSP430X processor.
84
85 * Add support for Altera Nios II.
86
87 * Add support for the V850E3V5 architecture.
88
89 * Add support for the Imagination Technologies Meta processor.
90
91 * --enable-new-dtags no longer generates old dtags in addition to new dtags.
92
93 * Remove linker support for MIPS ECOFF targets.
94
95 * Add ALIGN_WITH_INPUT to the linker script language to force the alignment of
96   an output section to use the maximum alignment of all its input sections.
97
98 Changes in 2.23:
99
100 * Enable compressed debug section feature for x86/x86_64 pe-coff.
101
102 * Add support for the 64-bit ARM architecture: AArch64.
103
104 * Added SORT_NONE to the linker script language to disable section sorting.
105
106 * Add a linker-provided symbol when producing ELF output, '__ehdr_start'
107   to point to the ELF file header (and nearby program headers) in the
108   program's memory image.
109
110 * Add support for S12X processor.
111
112 * Add support for the VLE extension to the PowerPC architecture.
113
114 * Add support for the Freescale XGATE architecture.
115
116 * Add option -f FILE on AIX (for response file).
117
118 * Add support for the Renesas RL78 architecture.
119
120 * Add support for the Adapteva EPIPHANY architecture.
121
122 Changes in 2.22:
123
124 * --copy-dt-needed-entries is no longer enabled by default.  Instead
125   --no-copy-dt-needed-entries is the default.
126
127 * INPUT_SECTION_FLAGS has been added to the linker script language
128   to allow selection of input sections by section header section flags.
129
130 * Add support for the Tilera TILEPro and TILE-Gx architectures.
131
132 * Added SORT_BY_INIT_PRIORITY to the linker script language to permit
133   sorting sections by numerical value of the GCC init_priority attribute
134   encoded in the section name.
135
136 Changes in 2.21:
137
138 * Linker script expression evaluation is somewhat more sane.  This may
139   break scripts that depend on quirks of the old expression evaluation.
140
141 * Turn off underscoring for x86_64 PE+-COFF targets.  For old behavior the
142   option --enable-leading-mingw64-underscores can be used on configure of
143   bfd.
144
145 * Add support for the TMS320C6000 (TI C6X) processor family.
146
147 * --add-needed renamed to --copy-dt-needed-entries in order to avoid confusion
148   with --as-needed option.
149
150 * Extend .def file syntax by '== <ID>' for imports and exports. This allows
151   to alias the import/export table name written in PE image.
152
153 * Add --exclude-all-symbols option to PE based linkers.  This prevents all
154   symbols from automatically being exported.
155
156 * Add support for the Renesas RX processor.
157
158 * Add support for alpha-vms target.
159
160 Changes in 2.20:
161
162 * GNU/Linux targets now support the STB_GNU_UNIQUE symbol binding.  This is a
163   GNU extension to the standard set of ELF symbol bindings.  The binding will
164   be passed on to the dynamic linker which will make sure that in the entire
165   process there is just one symbol with the given name and type in use.
166
167 * PE targets now support a GNU extension to allow the alignment of common
168   common symbols to be specified.  This support uses custom options in
169   the .drectve section, which will be disregarded by the native tools.
170
171 * PE targets now add primitive support for ELF version scripts; symbols
172   are not versioned, but the local and global symbol visibility directives
173   are respected when filtering symbols in auto-export mode.
174
175 * New option --no-export-dynamic to undo the effect of the -E and
176   --export-dynamic options.
177
178 * ELF: --warn-alternate-em option to warn if an object has alternate
179   ELF machine code.
180
181 * New script function REGION_ALIAS to add alias names to memory regions.
182
183 * PE targets no longer make use of the long section names PE extension to
184   the COFF format when generating executable images, by default.  The old
185   (slightly non-conformant) behaviour can still be invoked by using the
186   new '--enable-long-section-names' command-line option.  It is also enabled
187   automatically in the presence of un-stripped debug information, as GDB
188   needs to be able to find the debug info sections by their full names.
189
190 * For GNU/Linux systems the linker will now avoid processing any relocations
191   made against symbols of the STT_GNU_IFUNC type and instead emit them into
192   the resulting binary for processing by the loader.
193
194 * --as-needed now links in a dynamic library if it satisfies undefined
195   symbols in regular objects, or in other dynamic libraries.  In the
196   latter case the library is not linked if it is found in a DT_NEEDED
197   entry of one of the libraries already linked.
198
199 * Add a new command line option, -Ttext-segment ADDR, for ELF targets
200   to set the address of the first byte of the text segment.
201
202 * Add support for Sunplus score architecture.
203
204 * Add new option --use-nul-prefixed-import-tables to ld for PE targets to
205   allow fallback to old import table generation with null element prefix.
206
207 * Windows PE systems now support a new --exclude-modules-for-implib option,
208   allowing users to partition object files and archive members between a DLL
209   and its associated import library as they are generated during linking.
210
211 * Add support for Lattice Mico32 (lm32) architecture.
212
213 * Add CR16 ELF --embedded-relocs (used to embedded relocations into binaries
214   for Embedded-PIC code) option.
215
216 * Add to the PE/PE+ targets the support of two different kinds of
217   pseudo-relocations.  They can be selected by the switches
218   --enable-runtime-pseudo-reloc-v1 and --enable-runtime-pseudo-reloc-v2.
219   For the switch --enable-runtime-pseudo-reloc it uses for 32-bit
220   runtime pseudo relocation version one, for 64-bit the version two.
221
222 Changes in 2.19:
223
224 * Linker scripts support a new INSERT command that makes it easier to
225   augment the default script.
226
227 * Linker script input section filespecs may now specify a file within an
228   archive by writing "archive:file".
229
230 * The --sort-common switch now has an optional argument which specifies the
231   direction of sorting.
232
233 * The M68K linker now supports multiple GOT generation schemes controlled via
234   the --got=<type> command line option.
235
236 * The ARM EABI linker will now generate stubs for function calls to symbols
237   that are too far away.  The placement of the stubs is controlled by a new
238   linker command line option: --stub-group-size=N.
239
240 Changes in 2.18:
241
242 * Linker sources now released under version 3 of the GNU General Public
243   License.
244
245 * ELF: New --build-id option to generate a unique per-binary identifier
246   embedded in a note section.
247
248 * Added support for National Semicondutor CompactRISC (ie CR16) target.
249
250 * -l:foo now searches the library path for a filename called foo,
251   without converting it to libfoo.a or libfoo.so.
252
253 * Add a new command line option '--default-script=FILE' or '-dT FILE'
254   which specifies a replacement for the built in, default linker
255   script.
256
257 * ELF: Add -Bsymbolic-functions, --dynamic-list-cpp-new, which puts C++
258   operator new and delete on the dynamic list, and --dynamic-list-data,
259   builtin list for --dynamic-list, which puts global data symbols on the
260   dynamic list.
261
262 * Add support for x86_64 PE+ target.
263
264 * Add support for Score target.
265
266 * ELF: Add --dynamic-list option to specify a list of global symbols
267   whose references shouldn't be bound to the definition within the
268   shared library, or a list of symbols which should be added to the
269   symbol table in the executable.
270
271 * The default output section LMA has changed for allocatable sections from
272   being equal to VMA, to keeping the difference between LMA and VMA the same as
273   the previous output section in the same region.  This is a more useful
274   default when using overlays and other cases where you specify an LMA
275   differing from the VMA for some sections.
276
277 * New switch: --print-gc-sections to list any sections removed by garabge
278   collection.
279
280 * ARM: Added --vfp11-denorm-fix option to work around an erratum in current
281   VFP11 coprocessors.
282
283 Changes in 2.17:
284
285 * Support for the Infineon XC16X has been added by KPIT Cummins Infosystems.
286
287 * Modify the Linux linker search order to better match ld.so search order.
288   Look for DT_NEEDED libraries in paths specified by ld.so.conf before
289   searching the default directories, rather than vice versa.
290   Use $prefix/etc/ld.so.conf if it exists, otherwise /etc/ld.so.conf.
291
292 * PE-COFF: Forward exports from DLL's can now be specified in .def files
293   passed directly to ld.
294
295 * Support for the Z80 processor family has been added.
296
297 * Add support for the "@<file>" syntax to the command line, so that extra
298   switches can be read from <file>.
299
300 Changes in 2.16:
301
302 * Support for the R_ARM_V4BX relocation as defined in the ARM AAELF
303   specification has been added via the --fix-v4bx command-line option.
304
305 * New linker script construct AS_NEEDED(), which sets the --as-needed flag
306   for input files listed inside of it.
307
308 * A new command-line option, --sysroot, can be used to override the
309   default sysroot location.  It only applies to toolchains that were
310   configured using --with-sysroot.
311
312 * New linker script functions: ORIGIN() and LENGTH() which return information
313   about a specified memory region.
314
315 * Port to MAXQ processor contributed by HCL Tech.
316
317 * Added SEGMENT_START to the linker script language to permit the user to
318   override the base address for a segment from the command-line.
319
320 * ELF: --warn-shared-textrel option to warn if adding a DT_TEXTREL to a shared
321   object.
322
323 * Added SORT_BY_NAME and SORT_BY_ALIGNMENT to the linker script
324   language to permit sorting sections by section name or section
325   maximum alignment.
326
327 * Added a new linker command line switch, --sort-section name|alignment,
328   to sort sections by section name or maximum alignment.
329
330 * ELF: --add-needed/--no-add-needed options to control if a DT_NEEDED tag
331   should be added when a shared library comes from DT_NEEDED tags.
332
333 * Support for the crx-elf target added.
334
335 * Support for the sh-symbianelf target added.
336
337 * A new linker command line switch has been added which allows the hash table
338   size to be set to a suitable prime value near to its argument.  This switch
339   is --hash-size=<NUMBER>.  Also if the switch --reduce-memory-overheads is
340   used, and --hash-size has not been used, then the default value will be set
341   to 1021.
342
343 * Linker map files are now generated with an O(N) algorithm for finding symbols
344   that are defined in each section.  This uses about 40% more memory for
345   symbols than the old O(N^2) algorithm.  You can use the new
346   --reduce-memory-overheads option to select the old algorithm; this option
347   might also be used in the future to select similar tradeoffs.
348
349 Changes in 2.15:
350
351 * ELF: --as-needed/--no-as-needed options to control if a DT_NEEDED tag should
352   be added only when a shared library is referenced.
353
354 * PE: --large-address-aware option to indicate executables support virtual
355   addresses greater than 2 gigabytes.
356
357 * DWARF 2 support for i386pe added.
358
359 * The linker script operator DEFINED() will now yield 1 only for a symbol that
360   is defined before the statement where DEFINED is used.
361
362 * The MIPS --embedded-relocs (used to embed relocations into binaries for
363   Embedded-PIC code) is deprecated and will be removed in a future release.
364
365 * cr16c support added by NSC.
366
367 * m32r Linux (ELF) support added by Renesas.
368
369 * Improved linker's handling of unresolved symbols.  The switch
370   --unresolved-symbols=<method> has been added to tell the linker when it
371   should report them and the switch --warn-unresolved-symbols has been added to
372   make reports be issued as warning messages rather than errors.
373
374 Changes in 2.14:
375
376 * Added support for Xtensa architecture.
377
378 * Added --with-sysroot configure switch to specify a target system root, for
379   linking against a target filesystem image.
380
381 * Added --accept-unknown-linker-format to restore old linker behaviour (pre
382   2.14) of silently accepting and linking in any files in an unknown binary
383   file format.
384
385 * Added --no-omagic to undo the effects of the -N option.
386
387 * Support for Texas Instruments TMS320C4x and TMS320C3x series of
388   DSP's contributed by Michael Hayes and Svein E. Seldal.
389
390 * Added --with-lib-path configure switch to specify default value for
391   LIB_PATH.
392
393 * ARM port to QNX operating system added by Graeme Peterson.
394
395 * IP2K support added by Denis Chertykov.
396
397 Changes in 2.13:
398
399 * Support for the Fujitsu FRV architecture added by Red Hat. Models for FR400
400   and FR500 included.
401
402 Changes in version 2.13:
403
404 * DEC VAX ELF support, by Matt Thomas.
405
406 Changes in version 2.12:
407
408 * Support for Don Knuth's MMIX, by Hans-Peter Nilsson.
409
410 * Support for the OpenRISC 32-bit embedded processor by OpenCores.
411
412 * Support for -z nocopyreloc in the x86 ELF linker, which disables
413   production of copy relocs.  Warning: using this option may result in
414   non-sharable applications.
415
416 * Support for -z combreloc in the ELF linker, which puts dynamic
417   relocations against the same symbol together, so that dynamic linker
418   can use an one-entry symbol lookup cache.
419
420 * Support for ELF SHF_MERGE section merging, by Jakub Jelinek.
421
422 Changes in version 2.11:
423
424 * Support for AMD x86-64 architecture, by Jan Hubicka, SuSE Labs.
425
426 * Support added for eliminating duplicate DWARF2 debug information by
427   having the compiler generate the information in sections called
428   .gnu.linkonce.wi.XXXX where XXXX is a checksum for the contents.  The
429   linker then merges these sections together into the normal .debug_info
430   section.
431
432 * The native ELF linker now searches the directories in DT_RUNPATH or
433   DT_RPATH of a shared library for shared libraries needed by it.
434
435 * TI C54x support, by Timothy Wall.
436
437 * Added command line switch --section-start to set the start address of any
438   specified section.
439
440 * Added ability to emit full relocation information in linked executables,
441   enabled by --emit-relocs.  Some post-linkage optimization tools need
442   this information in order to be able to correctly identify and perform
443   symbol relative addressing in the event of changes in section contents
444   (instructions being added or deleted, extending data sections, etc.)
445
446 * Support for i860, by Jason Eckhardt (preliminary, alpha quality).
447
448 * Support for CRIS (Axis Communications ETRAX series).
449
450 * Support for PDP-11 and 2.11BSD a.out format, by Lars Brinkhoff.
451
452 Changes in version 2.10:
453
454 * Added AT> to the linker script language to allow load-time allocation of
455   sections into regions.
456
457 * Added garbage collection of unused sections, enabled by --gc-sections.
458   It does require a bit of backend support; currently implemented are
459   arm-elf, avr-elf, d10v-elf, fr30-elf, i386-elf, m32r-elf, m68k-elf,
460   mcore-elf, mips-elf, mn10300-elf, ppc-elf, sh-elf, sparc-elf, and v850-elf.
461   Others will ignore the option.
462
463 * Added SORT to the linker script language to permit sorting sections by file
464   name or section name.
465
466 * Added EXTERN to the linker script language as an equivalent to the -u
467   command-line option.
468
469 * Added ASSERT to the linker script language.
470
471 * Added EXCLUDE_FILE to the linker script language for further control over
472   wildcard file names.
473
474 * Added -O option to optimize linker output (as of this writing, this only
475   affects ELF shared library generation).
476
477 * The -e option now accepts a number as well as a symbol name.
478
479 * Added --no-undefined option to disallow undefined symbols when creating a
480   shared library.
481
482 * The linker now issues a warning, not an error, for an undefined symbol when
483   using -Bsymbolic; use the new --no-undefined option to get the old
484   behaviour.
485
486 * Added --demangle and --no-demangle options.
487
488 Changes in version 2.9:
489
490 * Added SQUAD to the linker script language.
491
492 * New option --no-warn-mismatch.
493
494 * The MEMORY command now parses the attributes to determine where sections that
495   are not placed in a specific memory region are placed.
496
497 Changes in version 2.8:
498
499 * Linker scripts may now contain shell wildcard characters for file and section
500   names.
501
502 * The linker now supports symbol versions in ELF.
503
504 * The NOCROSSREFS command was added to the linker script language.
505
506 * The LOADADDR expression was added to the linker script language.
507
508 * MAX and MIN functions were added to the linker script language.
509
510 * The OVERLAY construct was added to the linker script language.
511
512 * New option --warn-section-align to warn when the address of an output section
513   changes due to alignment of an input section.
514
515 * New options --filter/-F and --auxiliary/-f.
516
517 Changes in version 2.7:
518
519 * New option --cref to print out a cross reference table.
520
521 * New option --wrap SYMBOL.
522
523 * New option --no-whole-archive, to turn off the effect of --whole-archive.
524
525 * Input sections assigned to the output section /DISCARD/ in the linker script
526   are not included in the output file.
527
528 * The SunOS and ELF linkers now merge stabs debugging information which uses
529   the N_BINCL and N_EINCL stab types.  This reduces the amount of debugging
530   information generated.
531
532 Changes in version 2.6:
533
534 * When an ELF section name is representable as a C identifier (this is not true
535 of most ELF section names), the linker will automatically define symbols
536 __start_SECNAME and __stop_SECNAME, where SECNAME is the section name, at the
537 beginning and the end of the section.  This is used by glibc.
538
539   Addendum: Current versions of the linker (at least for version 2.18 onwards
540 and possibly much earlier as well) place two restrictions on this feature:  The
541 symbols are only implemented for orphaned sections, not for explicitly placed
542 sections and they are PROVIDEd rather than being defined.
543
544 * When an ELF section named .gnu.warning is encountered in an input file, the
545 contents of the section are displayed as an error message, and the section is
546 not copied into the output file.  This is used by glibc.
547
548 * When an ELF section named .gnu.warning.SYMBOL is encountered in an input
549 file, and the symbol SYMBOL is referenced by some object file, the contents of
550 the section are displayed as an error message.  The section is not copied into
551 the output file, unless doing a relocatable or shared link.  This is used by
552 glibc.
553
554 * New options -split-by-reloc and -split-by-file.
555
556 * The linker now supports linking PIC compiled code on SPARC SunOS.  It can
557 also create SPARC SunOS shared libraries, and, like the native SunOS linker,
558 will do so whenever there is an undefined symbol in the link and neither the -e
559 nor the -r option was used.
560
561 * The -rpath option may be used on SunOS to set the list of directories to be
562 searched at run time.  This overrides the default of building the list from the
563 -L options.
564
565 * The COFF linker now combines debugging information for structs, unions, and
566 enums, so that even if the same type is defined in multiple input files it will
567 only be defined once in the output file.  The --traditional-format switch will
568 prevent this optimization.
569
570 Changes in version 2.5:
571
572 * The linker now supports linking against SunOS shared libraries.  It still can
573 not link SunOS PIC (Position Independent Code) files, so it can not be used to
574 generate shared libraries.
575
576 * The linker now supports linking against ELF shared libraries for the i386
577 (UnixWare) and SPARC (Solaris).  It can also link ELF PIC files, and can be
578 used to generate shared libraries.  Shared library generation is not well
579 tested; please report any problems encountered.  The linker is now enabled for
580 Solaris again.
581
582 * Eric Youngdale has contributed Linux support code, including linking against
583 Linux a.out shared libraries.  The linker produces Linux QMAGIC binaries.
584
585 * The ELF backend has been converted to the new linker code.  To use the new
586 ELF linker, each particular target requires a relocation function.  So far,
587 this function has been written for i386 (UnixWare), SPARC (Solaris) MIPS (Irix
588 5), and HPPA ELF targets.
589
590 * The -( (--start-group) and -) (--end-group) options have been added to
591 support searching a group of archives as though they were a single archive.
592 This can also be used in a linker script, as GROUP ( files ).
593
594 * When a file is named on the command line, and the linker does not recognize
595 it as an object file, the linker will now treat the file as a linker script
596 file.  A linker script named in this way augments, but does not replace, the
597 default linker script.
598
599 * The -warn-once option was added.  It causes the linker to only warn once per
600 undefined symbol, rather than once per reference.
601
602 * The COFF backend has been converted to the new linker code.  As with ELF, to
603 use the new linker, each particular target requires a relocation function.  So
604 far, this function has been written for the i386, m68k, a29k and SH targets.
605
606 * The -V flag was made a synonym for -v, for SVR4 compatibility.  The old -V
607 behaviour is available via --verbose.
608
609 Changes in version 2.4:
610
611 * New linker code, by Steve Chamberlain and Ian Taylor.  For a.out and ecoff
612   formats (so far), this should result in considerable savings in time
613   and memory used while linking; slightly poorer performance than
614   before for formats not converted yet.
615
616 * Command-line parsing is no longer done with flex.  This means
617   oddball characters in filenames won't get treated as argument
618   separators.
619
620 * HP-PA ELF support, by Jeff Law.  (No SOM support yet.)
621
622 * Mach i386 support, by David Mackenzie.
623
624 * Irix 4 shared libraries are now supported (Irix 5 uses ELF, and ELF shared
625   libraries are not yet supported).
626
627 * COFF shared libraries (as on SCO) should work as well.
628
629 * The linker is disabled for Solaris.  (Actually, it was in 2.3 also, I just
630   forgot to note it.)  Some of their C library routines don't work when
631   statically linked, and the GNU linker doesn't support dynamic linking yet.
632
633 Changes in version 2.3:
634
635 * Weak symbols are now supported.
636
637 * ELF support has been added.  The linker has been bootstrapped on
638   UnixWare and Solaris.
639
640 * Alpha OSF/1 support has been added (non dynamic linking only).
641
642 Changes in version 2.2:
643
644 * The `bfd' library has been updated to reduce a.out-format string
645   table size.  The effect of this is that files linked from many input
646   files with duplicate symbols (`-g' debugging records, or identical
647   static symbols) should be much smaller.
648
649 Changes in version 2.1:
650
651 * The ld -ySYMBOL flag (to trace references to SYMBOL) is now implemented.
652
653 * There is now support for writing ECOFF files, so ld and the
654   other utilities should work on Risc/Ultrix and Irix.
655
656 \f
657 Copyright (C) 2012-2016 Free Software Foundation, Inc.
658
659 Copying and distribution of this file, with or without modification,
660 are permitted in any medium without royalty provided the copyright
661 notice and this notice are preserved.
662
663 Local variables:
664 fill-column: 79
665 End: