Revert ld DIGEST support
authorAlan Modra <amodra@gmail.com>
Thu, 9 Mar 2023 01:23:16 +0000 (11:53 +1030)
committerAlan Modra <amodra@gmail.com>
Fri, 10 Mar 2023 10:52:16 +0000 (21:22 +1030)
This is a hopefully temporary reversion of new ld features for
embedded processors by Ulf Samuelsson, plus some followup patches.

Squashed together from the following:

Revert "lddigest 32-bit support and gcc-4 compile errors"
This reverts commit d7ee19be87110a8f5342cec6e323d83d01c641d1.

Revert "ld: Use correct types for crc64 calculations"
This reverts commit 9a534b9f8e3d0f3cdb5a20f19ff165693fbb84d2.

Revert "Re: DIGEST: testsuite"
This reverts commit c8e85484d8a0fe9f7b88e00a6b9ae63bcb53ba32.

Revert "Regen potfiles"
This reverts commit 4d98c966f8bf305ab25badd34cb295631873cf7c.

Revert "DIGEST: Makefile.*"
This reverts commit 78ef6ab03f56ce83a606d974bb8a9f34b5d6e0b7.

Revert "DIGEST: calculation"
This reverts commit 5243990191e683d5066d3dd622c76deaba0bf15c.

Revert "DIGEST: ldlang.*: add timestamp"
This reverts commit bd9466d4aa277a469a9d8b12f0a6e6fa51678e36.

Revert "DIGEST: ldmain.c"
This reverts commit c8f8653fa7eeb3dc0769ac23039eadb5c5f09dff.

Revert "DIGEST: ldgram.y"
This reverts commit d73c01be2669e9c5267fab669a269f95a32048c9.

Revert "DIGEST: ldlex.l"
This reverts commit 48b5163a9dd5759cc87171331bbd6e902c547b5a.

Revert "DIGEST: testsuite"
This reverts commit a4135d1a4886400ea29af2da782dd8dd40ccad23.

Revert "DIGEST: Documentation"
This reverts commit 3ec28966c3e4c63704212778f96c517cbf2e0090.

Revert "DIGEST: NEWS"
This reverts commit 099bf2927d446424e8585a60cf4ce63209999aa2.

Revert "DIGEST: LICENSING"
This reverts commit 5c8a0c6654fb55926985edf3b360b62d4f20691d.

76 files changed:
ld/COPYING.www.libcrc.org [deleted file]
ld/COPYING.www.sunshine2k.de [deleted file]
ld/Makefile.am
ld/Makefile.in
ld/NEWS
ld/ld.texi
ld/ldcrc32.c [deleted file]
ld/ldcrc64.c [deleted file]
ld/lddigest.c [deleted file]
ld/lddigest.h [deleted file]
ld/lddigest_tab.c [deleted file]
ld/ldgram.y
ld/ldlang.c
ld/ldlang.h
ld/ldlex.l
ld/ldmain.c
ld/ldreflect.c [deleted file]
ld/ldreflect.h [deleted file]
ld/po/SRC-POTFILES.in
ld/testsuite/ld-scripts/begin_tag.inc [deleted file]
ld/testsuite/ld-scripts/crc32-poly.d [deleted file]
ld/testsuite/ld-scripts/crc32-poly.s [deleted file]
ld/testsuite/ld-scripts/crc32-poly.t [deleted file]
ld/testsuite/ld-scripts/crc32.d [deleted file]
ld/testsuite/ld-scripts/crc32.s [deleted file]
ld/testsuite/ld-scripts/crc32.t [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-contents.d [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-contents.s [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-contents.t [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-size.d [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-size.s [deleted file]
ld/testsuite/ld-scripts/crc64-bad-endian-size.t [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label-2.d [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label-2.s [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label-2.t [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label.d [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label.s [deleted file]
ld/testsuite/ld-scripts/crc64-bad-label.t [deleted file]
ld/testsuite/ld-scripts/crc64-ecma.d [deleted file]
ld/testsuite/ld-scripts/crc64-ecma.s [deleted file]
ld/testsuite/ld-scripts/crc64-ecma.t [deleted file]
ld/testsuite/ld-scripts/crc64-in-section.d [deleted file]
ld/testsuite/ld-scripts/crc64-in-section.s [deleted file]
ld/testsuite/ld-scripts/crc64-in-section.t [deleted file]
ld/testsuite/ld-scripts/crc64-iso.d [deleted file]
ld/testsuite/ld-scripts/crc64-iso.s [deleted file]
ld/testsuite/ld-scripts/crc64-iso.t [deleted file]
ld/testsuite/ld-scripts/crc64-iso_be.d [deleted file]
ld/testsuite/ld-scripts/crc64-iso_be.s [deleted file]
ld/testsuite/ld-scripts/crc64-iso_be.t [deleted file]
ld/testsuite/ld-scripts/crc64-multiple-digest.d [deleted file]
ld/testsuite/ld-scripts/crc64-multiple-digest.s [deleted file]
ld/testsuite/ld-scripts/crc64-multiple-digest.t [deleted file]
ld/testsuite/ld-scripts/crc64-poly-size.d [deleted file]
ld/testsuite/ld-scripts/crc64-poly-size.s [deleted file]
ld/testsuite/ld-scripts/crc64-poly-size.t [deleted file]
ld/testsuite/ld-scripts/crc64-poly.d [deleted file]
ld/testsuite/ld-scripts/crc64-poly.s [deleted file]
ld/testsuite/ld-scripts/crc64-poly.t [deleted file]
ld/testsuite/ld-scripts/crc64-reverse-area.d [deleted file]
ld/testsuite/ld-scripts/crc64-reverse-area.s [deleted file]
ld/testsuite/ld-scripts/crc64-reverse-area.t [deleted file]
ld/testsuite/ld-scripts/crc64-same-section.d [deleted file]
ld/testsuite/ld-scripts/crc64-same-section.s [deleted file]
ld/testsuite/ld-scripts/crc64-same-section.t [deleted file]
ld/testsuite/ld-scripts/crc64-section.d [deleted file]
ld/testsuite/ld-scripts/crc64-section.s [deleted file]
ld/testsuite/ld-scripts/crc64-section.t [deleted file]
ld/testsuite/ld-scripts/crc64-unknown-digest.d [deleted file]
ld/testsuite/ld-scripts/crc64-unknown-digest.s [deleted file]
ld/testsuite/ld-scripts/crc64-unknown-digest.t [deleted file]
ld/testsuite/ld-scripts/crc_data.inc [deleted file]
ld/testsuite/ld-scripts/digest_table.inc [deleted file]
ld/testsuite/ld-scripts/digest_table_be.inc [deleted file]
ld/testsuite/ld-scripts/end_tag.inc [deleted file]
ld/testsuite/ld-scripts/script.exp

diff --git a/ld/COPYING.www.libcrc.org b/ld/COPYING.www.libcrc.org
deleted file mode 100755 (executable)
index e8b7226..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-The GNU linker contains CRC routines that are used to implement the
-DIGEST CRC32/64 commands in the output section.
-
-The CRC routines are extracted from LIBCRC available at
-* https://www.libcrc.org/
-* https://github.com/lammertb/libcrc/tree/v2.0
-
-The license file from libcrc is below.
-================================================================================
-/*
- * Library: libcrc
- * File:    src/crc64.c
- * Author:  Lammert Bies
- *
- * This file is licensed under the MIT License as stated below
- *
- * Copyright (c) 2016 Lammert Bies
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- * Description
- * -----------
- * The source file src/crc64.c contains the routines which are needed to
- * calculate a 64 bit CRC value of a sequence of bytes.
- */
-================================================================================
-NOTE: The user could/(should) extract the CRC calculation routines
-      and add to their program.
-      The linker can add the table, but not the calculation routines.
diff --git a/ld/COPYING.www.sunshine2k.de b/ld/COPYING.www.sunshine2k.de
deleted file mode 100644 (file)
index 636496f..0000000
+++ /dev/null
@@ -1,25 +0,0 @@
-The ld.bfd linker contains code from the http://www.sunshine2k.de/ website
-This code is released under the license below
-================================================================================
-All content of this website is released under the MIT license as follows:
-
-Copyright (c) 2021 Bastian Molkenthin
-
-Permission is hereby granted, free of charge, to any person obtaining a copy
-of this software and associated documentation files (the "Software"), to deal
-in the Software without restriction, including without limitation the rights
-to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
-copies of the Software, and to permit persons to whom the Software is
-furnished to do so, subject to the following conditions:
-
-The above copyright notice and this permission notice shall be included in
-all copies or substantial portions of the Software.
-
-THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
-IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
-FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
-AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
-LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
-OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN
-THE SOFTWARE.
-================================================================================
index 00118f8da13c71710f28168be7656651be5185e9..d9449a66066e8016790f6ab1bd9b08cd712cd0ff 100644 (file)
@@ -479,14 +479,12 @@ CFILES = ldctor.c ldemul.c ldexp.c ldfile.c ldlang.c \
        ldmain.c ldmisc.c ldver.c ldwrite.c lexsup.c \
        mri.c ldcref.c pe-dll.c pep-dll.c ldlex-wrapper.c \
        plugin.c ldbuildid.c ldelf.c ldelfgen.c \
-       lddigest.c lddigest_tab.c ldcrc32.c ldcrc64.c ldreflect.c \
        pdb.c
 
 HFILES = ld.h ldctor.h ldemul.h ldexp.h ldfile.h \
        ldlang.h ldlex.h ldmain.h ldmisc.h ldver.h \
        ldwrite.h mri.h deffile.h pe-dll.h pep-dll.h \
        elf-hints-local.h plugin.h ldbuildid.h ldelf.h ldelfgen.h \
-       lddigest.h ldreflect.h \
        pdb.h
 
 GENERATED_CFILES = ldgram.c ldlex.c deffilep.c
@@ -497,8 +495,6 @@ GENERATED_HFILES = ldgram.h ldemul-list.h deffilep.h
 BUILT_SOURCES = $(GENERATED_HFILES)
 
 OFILES = ldgram.@OBJEXT@ ldlex-wrapper.@OBJEXT@ lexsup.@OBJEXT@ ldlang.@OBJEXT@ \
-       lddigest.@OBJEXT@ lddigest_tab.@OBJEXT@ \
-       ldcrc32.@OBJEXT@ ldcrc64.@OBJEXT@ ldreflect.@OBJEXT@ \
        mri.@OBJEXT@ ldctor.@OBJEXT@ ldmain.@OBJEXT@ plugin.@OBJEXT@ \
        ldwrite.@OBJEXT@ ldexp.@OBJEXT@  ldemul.@OBJEXT@ ldver.@OBJEXT@ ldmisc.@OBJEXT@ \
        ldfile.@OBJEXT@ ldcref.@OBJEXT@ ${EMULATION_OFILES} ${EMUL_EXTRA_OFILES} \
@@ -966,7 +962,6 @@ EXTRA_ld_new_SOURCES = deffilep.y ldlex.l
 EXTRA_ld_new_SOURCES += ldelf.c ldelfgen.c pdb.c pep-dll.c pe-dll.c
 
 ld_new_SOURCES = ldgram.y ldlex-wrapper.c lexsup.c ldlang.c mri.c ldctor.c ldmain.c \
-       lddigest.c lddigest_tab.c ldcrc32.c ldcrc64.c ldreflect.c \
        ldwrite.c ldexp.c ldemul.c ldver.c ldmisc.c ldfile.c ldcref.c plugin.c \
        ldbuildid.c
 ld_new_DEPENDENCIES = $(EMULATION_OFILES) $(EMUL_EXTRA_OFILES) \
index 7bf51bffa547db8f7ae8e15096eef700e9592e8f..0a2981616f01888a08d0b89fbe8186995b74a63c 100644 (file)
@@ -210,8 +210,6 @@ PROGRAMS = $(bin_PROGRAMS)
 am_ld_new_OBJECTS = ldgram.$(OBJEXT) ldlex-wrapper.$(OBJEXT) \
        lexsup.$(OBJEXT) ldlang.$(OBJEXT) mri.$(OBJEXT) \
        ldctor.$(OBJEXT) ldmain.$(OBJEXT) ldwrite.$(OBJEXT) \
-       lddigest.$(OBJEXT) lddigest_tab.$(OBJEXT) \
-       ldcrc32.$(OBJEXT) ldcrc64.$(OBJEXT) ldreflect.$(OBJEXT) \
        ldexp.$(OBJEXT) ldemul.$(OBJEXT) ldver.$(OBJEXT) \
        ldmisc.$(OBJEXT) ldfile.$(OBJEXT) ldcref.$(OBJEXT) \
        plugin.$(OBJEXT) ldbuildid.$(OBJEXT)
@@ -535,7 +533,6 @@ pdfdir = @pdfdir@
 prefix = @prefix@
 program_transform_name = @program_transform_name@
 psdir = @psdir@
-runstatedir = @runstatedir@
 sbindir = @sbindir@
 sharedstatedir = @sharedstatedir@
 srcdir = @srcdir@
@@ -981,14 +978,12 @@ CFILES = ldctor.c ldemul.c ldexp.c ldfile.c ldlang.c \
        ldmain.c ldmisc.c ldver.c ldwrite.c lexsup.c \
        mri.c ldcref.c pe-dll.c pep-dll.c ldlex-wrapper.c \
        plugin.c ldbuildid.c ldelf.c ldelfgen.c \
-       lddigest.c lddigest_tab.c ldcrc32.c ldcrc64.c ldreflect.c \
        pdb.c
 
 HFILES = ld.h ldctor.h ldemul.h ldexp.h ldfile.h \
        ldlang.h ldlex.h ldmain.h ldmisc.h ldver.h \
        ldwrite.h mri.h deffile.h pe-dll.h pep-dll.h \
        elf-hints-local.h plugin.h ldbuildid.h ldelf.h ldelfgen.h \
-       lddigest.h ldreflect.h \
        pdb.h
 
 GENERATED_CFILES = ldgram.c ldlex.c deffilep.c
@@ -998,8 +993,6 @@ GENERATED_HFILES = ldgram.h ldemul-list.h deffilep.h
 # tracking will not cause them to be built beforehand.
 BUILT_SOURCES = $(GENERATED_HFILES)
 OFILES = ldgram.@OBJEXT@ ldlex-wrapper.@OBJEXT@ lexsup.@OBJEXT@ ldlang.@OBJEXT@ \
-       lddigest.@OBJEXT@ lddigest_tab.@OBJEXT@ \
-       ldcrc32.@OBJEXT@ ldcrc64.@OBJEXT@ ldreflect.@OBJEXT@ \
        mri.@OBJEXT@ ldctor.@OBJEXT@ ldmain.@OBJEXT@ plugin.@OBJEXT@ \
        ldwrite.@OBJEXT@ ldexp.@OBJEXT@  ldemul.@OBJEXT@ ldver.@OBJEXT@ ldmisc.@OBJEXT@ \
        ldfile.@OBJEXT@ ldcref.@OBJEXT@ ${EMULATION_OFILES} ${EMUL_EXTRA_OFILES} \
@@ -1021,7 +1014,6 @@ EXTRA_ld_new_SOURCES = deffilep.y ldlex.l ldelf.c ldelfgen.c pdb.c \
        pep-dll.c pe-dll.c $(ALL_EMULATION_SOURCES) \
        $(ALL_64_EMULATION_SOURCES)
 ld_new_SOURCES = ldgram.y ldlex-wrapper.c lexsup.c ldlang.c mri.c ldctor.c ldmain.c \
-       lddigest.c lddigest_tab.c ldcrc32.c ldcrc64.c ldreflect.c \
        ldwrite.c ldexp.c ldemul.c ldver.c ldmisc.c ldfile.c ldcref.c plugin.c \
        ldbuildid.c
 
@@ -1568,12 +1560,8 @@ distclean-compile:
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ez8001.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ez8002.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldbuildid.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldcrc32.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldcrc64.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldcref.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldctor.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lddigest.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lddigest_tab.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldelf.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldelfgen.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldemul.Po@am__quote@
@@ -1585,7 +1573,6 @@ distclean-compile:
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldlex.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldmain.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldmisc.Po@am__quote@
-@AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldreflect.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldver.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/ldwrite.Po@am__quote@
 @AMDEP_TRUE@@am__include@ @am__quote@./$(DEPDIR)/lexsup.Po@am__quote@
diff --git a/ld/NEWS b/ld/NEWS
index b79023ecb95209d05de39d0096868bedc4fffae7..4b91f2c3b0a451ab23a9e761e5592b18a18ee95e 100644 (file)
--- a/ld/NEWS
+++ b/ld/NEWS
@@ -1,74 +1,5 @@
 -*- text -*-
 
-* The linker script has a new command to insert a timestamp
-  TIMESTAMP
-  inserts the current time (seconds since Epoch) as a 64-bit value
-
-* The linker script syntax has new commands for debugging a linker script
-  DEBUG ON  turns on debugging
-  DEBUG OFF turns off debugging
-
-* The linker script syntax has new commands for handling CRC-32/64 calculations
-  on the '.text' section
-  It uses code from https://www.libcrc.org/
-
-  DIGEST "<label>[#<endian>]" "CRC32"              (start, end)
-  DIGEST "<label>[#<endian>]" "CRC64-ECMA"         (start, end)
-  DIGEST "<label>[#<endian>]" "CRC64-GO-ISO"       (start, end)
-  DIGEST "<label>[#<endian>]" "CRC64-GO-ISO-R"     (start, end)
-  DIGEST "<label>[#<endian>]" "CRC64-WE"           (start, end)
-  DIGEST "<label>[#<endian>]" "CRC64-XZ"           (start, end)
-  DIGEST "<label>[#<endian>]"  POLY (<params>)     (start, end)
-  DIGEST TABLE "<label>[#<endian>]"
-
-  The CRC32, CRC64-ECMA, CRC64-ISO, CRC64-WE and POLY defines
-  the polynome to use and reserves space for the 32/64-bit CRC in the
-  current section (default ".text"). It also defines a label "<label>".
-  The endian can be specified through "#BE" or "#LE" modifiers for
-  big endian or little endian. This overrides the "-BE" or "-LE" switches on the
-  command line. If no specification is used, little endian
-  digest and table will be emitted.
-  The generated label does not include the modifier.
-
-  When generating a custom polynome you have to supply parameters
-  in the  following order
-  * size            {32 | 64 }
-  * polynome
-  * initial         initial value of crc
-  * xor value       xor with this before returning result
-  * input reflect   bitreverse input data
-  * output reflect  bitreverse result
-  * reciprocal      bitreverse polynome
-
-  These terms are explained at
-  http://www.sunshine2k.de/articles/coding/crc/understanding_crc.html
-
-  The 32 bit DIGEST <polynome> command defines some global symbols.
-  ___CRC32___ is the address of the CRC64 checksum
-  ___CRC32_START___ is the address where CRC calculation starts
-  ___CRC32_END___ The CRC calculation ends before this address.
-
-  The 64-bit DIGEST <polynome> command defines some global symbols.
-  ___CRC64___ is the address of the CRC64 checksum
-  ___CRC64_START___ is the address where CRC calculation starts
-  ___CRC64_END___ The CRC calculation ends before this address.
-
-  All three symbols must refer to addresses in the selected section.
-  If they are defined at the end of the linking process, then
-  the CRC## will be calculated between
-
-    ___CRC##_START___ .. ___CRC##_END___ -1
-
-  and the result will be inserted at ___CRC##___.
-
-  ___CRC##___ must be outside the region where CRC is calculated
-
-  The DIGEST TABLE command generates a table for CRC generation.
-  A table is not neccessary, but will speed up the calculation.
-  It defines the ___CRC##_TABLE___ symbol at the start of the table.
-  The user may choose to add this table to his code instead of using
-  the linker.
-
 * The linker script syntax has two new commands for inserting text into output
   sections:
     ASCII (<size>) "string"
@@ -110,16 +41,16 @@ Changes in 2.39:
   re-enabled via the --warn-rwx-segments option.
 
   New configure options can also control these new features:
-
+  
   --enable-warn-execstack=no
      will disable the warnings about creating an executable stack.
-
+     
   --enable-warn-execstack=yes
      will make --warn-execstack enabled by default.
-
+     
   --enable-warn-rwx-segments=no
      will make --no-warn-rwx-segments enabled by default.
-
+     
   --enable-default-execstack=no
      will stop the creation of an executable stack simply because an input file
      is missing a .note.GNU-stack section, even on architectures where this
index c21d849fe243b59b0e8df9dc017d949f91dc57a4..3367075cae841dc584aa011452a7656dce56f2b7 100644 (file)
@@ -5302,7 +5302,7 @@ __stop_SECNAME, where SECNAME is the name of the section.  These
 indicate the start address and end address of the output section
 respectively.  Note: most section names are not representable as
 C identifiers because they contain a @samp{.} character.
-@page
+
 @node Output Section Data
 @subsection Output Section Data
 @cindex data
@@ -5353,28 +5353,10 @@ whereas this will work:
 @smallexample
 SECTIONS @{@ .text : @{@ *(.text) ; LONG(1) @}@ .data : @{@ *(.data) @}@ @}@
 @end smallexample
-@page
+
 @cindex output section strings
 @kindex ASCII (@var{expression}) ``@var{string}''
 @kindex ASCIZ ``@var{string}''
-@code{ASCII strings}
-@sp 1
-@multitable @columnfractions .25 .20 .30 .20 .05
-@item
-ASCIZ
-@tab
-@tab
-"<string"
-@tab
-@item
-ASCII
-@tab
-(<size>)
-@tab
-"<string"
-@tab
-@end multitable
-@sp 1
 You can include a zero-terminated string in an output section by using
 @code{ASCIZ}.  The keyword is followed by a string which is stored at
 the current value of the location counter including adding a zero byte
@@ -5399,490 +5381,18 @@ it must be enclosed in double quotes.
 The string can have C escape characters like '\n', '\r', '\t' and
 octal numbers.  The '\"' escape is not supported.  Nor are escaped hex
 values.
-@sp 2
+
 Example 1: This is string of 16 characters and will create a 32 byte
 area:
 @smallexample
   ASCII (32) "This is 16 bytes"
 @end smallexample
-@sp 2
+
 Example 2: This is a string of 16 characters and will create a 17 byte
 area:
 @smallexample
   ASCIZ "This is 16 bytes"
 @end smallexample
-@page
-@cindex output section strings
-@kindex DIGEST "<label>[#<endian>]" "CRC64-ECMA"   (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]" "CRC64-ISO"    (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]" "CRC64-ISO-R"  (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]" "CRC64-WE"     (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]" "CRC64-XZ"     (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]" "CRC32"        (@var{expr}, @var{expr})
-@kindex DIGEST "<label>[#<endian>]"  POLY (@var{<parms>}) (@var{expr}, @var{expr})
-
-@code{CRC Calculation}
-@sp 1
-@multitable @columnfractions .20 .27 .28 .25
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC32"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC64-ECMA"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC64-GO-ISO"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC64-GO-ISO-R"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC64-WE"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-"CRC64-XZ"
-@tab
-(start, end)
-@item
-DIGEST
-@tab
-"<label>[#<endian>]"
-@tab
-POLY (<params>)
-@tab
-(start, end)
-@item
-DIGEST TABLE
-@tab
-"<label>[#<endian>]"
-@tab
-@tab
-(start, end)
-@end multitable
-
-You can calculate the CRC of a part of an output section through the
-@code{DIGEST} command. The default section is the @code{".text"} section.
-The commands take parameters for a label, a @code{polynome} and then two more,
-specifying range of the checked area.  The end address is the first address
-past the checked area.
-
-The checksum is generated in little endian format, but this can be overridden by
-adding a @code{#BE} or @code{#LE} modifier to the label string.
-The generated label does not include the modifier. The endian can also be
-specified on the command line using @code{-BE} or @code{-LE}.
-
-@sp 1
-There is one predefined 32-bit polynome
-
-@multitable @columnfractions .3 .4 .4
-@item
-* @code{CRC32}
-@tab
-@code{0x04C11DB7}
-@tab
-@end multitable
-
-There are five predefined 64-bit polynomes
-
-@multitable @columnfractions .3 .4 .4
-@item
-* @code{CRC64-ECMA}
-@tab
-@code{0x42F0E1EBA9EA3693}
-@tab
-@item
-* @code{CRC64-ISO}
-@tab
-@code{0x000000000000001B}
-@tab
-@item
-* @code{CRC64-ISO-R}
-@tab
-@code{0xD800000000000000}
-@tab
-@item
-* @code{CRC64-WE}
-@tab
-@code{0x42F0E1EBA9EA3693}
-@tab
-@item
-* @code{CRC64-XZ}
-@tab
-@code{0x42F0E1EBA9EA3693}
-@tab
-@end multitable
-@sp 1
-You can also select your own @code{polynome} using the @code{DIGEST POLY}.
-
-It takes the following @code{parameters} separated by commas.
-
-@multitable @columnfractions .3 .7
-@item
-@code{size}
-@tab
-size of CRC (32 or 64)
-@item
-@code{polynome}
-@tab
-@item
-@code{initial}
-@tab
-initial value of crc before calculation
-@item
-@code{xor}
-@tab
-xor result before return
-@item
-@code{input reflect}
-@tab
-bitreverse input data
-@item
-@code{output reflect}
-@tab
-bitreverse result (before xor'ing)
-@item
-@code{reciprocal}
-@tab
-bitreverse polynome before generating table
-@end multitable
-
-The parameters are explained in detail in
-
-@code{http://www.sunshine2k.de/articles/coding/crc/understanding_crc.html}
-
-Some of the predefined polynomes are the same, but differs in the other
-parameters.
-@page
-The 32-bit <polynome> command defines the following global symbols.
-
-@multitable @columnfractions .3 .7
-@item
-@code{___CRC32___}
-@tab
-address of the CRC32 checksum
-@item
-@code{___CRC32_START___}
-@tab
-first address in the checked area.
-@item
-@code{___CRC32_END___}
-@tab
-first address past the checked area.
-@end multitable
-@sp 2
-The 64-bit <polynome> command defines the following global symbols.
-
-@multitable @columnfractions .3 .7
-@item
-@code{___CRC64___}
-@tab
-address of the CRC64 checksum
-@item
-@code{___CRC64_START___}
-@tab
-first address in the checked area.
-@item
-@code{___CRC64_END___}
-@tab
-first address past the checked area.
-@end multitable
-@sp 2
-Note: The generated CRC value must be stored outside the checked area.
-@sp 2
-Example 1: This request a CRC check using the @code{ECMA} algorithm
-
-@smallexample
-  DIGEST "C64" "CRC64-ECMA" (START_CHECK,END_TEXT)
-@end smallexample
-
-The user can retrieve the CRC value through the @code{C64} label.
-@sp 2
-Example 2: This request a CRC check using the @code{ISO} algorithm
-
-           The checksum is stored as big endian
-
-@smallexample
-  DIGEST "C64I#BE" "CRC64-ISO" (START_CHECK,END_TEXT)
-@end smallexample
-
-The user can retrieve the big endian CRC value through the @code{C64I} label.
-@sp 2
-Example 3: This request a CRC check using a user defined @code{polynome}
-
-           The setup is the "CRC32" algorithm
-
-@smallexample
-  DIGEST "CRC" POLY (32, 0x04C11DB7,~0,~0,1,1,0) (START_CHECK,END_TEXT)
-@end smallexample
-
-The user can retrieve the CRC value through the @code{CRC} label.
-@sp 2
-Example 4: This request a CRC check using the @code{CRC32} polynome
-
-@smallexample
-  DIGEST "C32.SE" (START_CHECK,END_TEXT)
-@end smallexample
-
-The user can retrieve the CRC value through the @code{C32} label.
-
-@page
-@cindex output section strings
-@kindex DIGEST TABLE "<label>[#<endian>]"
-@page
-The @code{DIGEST TABLE} command creates a 1 or 2 kByte table for a table-driven
-CRC calculation.  This speeds up the CRC calculation over a non-table-driver
-version since you can handle 8 bits at a time, instead of 1 bit.
-
-The table generated is for the @code{polynome} selected using a
-@code{DIGEST <polynome>} command.
-
-The command will define the label supplied as a parameter.
-The table will be in small endian, unless the @code{.BE} or @code{.LE} extension
-is given to the label.
-It also defines a symbol based on the size of the polynome.
-
-@enumerate
-@item
-@code{___CRC32_TABLE___}       address of the CRC32 table, or
-@item
-@code{___CRC64_TABLE___}       address of the CRC64 table
-@end enumerate
-
-@sp 2
-Example 1: Generate a 1 kB table
-
-(assuming a previous @code{DIGEST "CRC32"} command)
-
-@smallexample
-  DIGEST TABLE "crc_tab32"
-@end smallexample
-
-The user must declare @code{extern uint32_t *crc_tab32;} in his code.
-@sp 2
-Example 2: Generate a 2 kB table in big endian format.
-
-(assuming a previous @code{DIGEST "CRC64-###"} command)
-
-@smallexample
-  DIGEST TABLE "crc_tab64.be"
-@end smallexample
-
-The user must declare @code{extern uint64_t *crc_tab64;} in his code.
-
-Using the tables:
-           The user must include CRC code in the application to test the CRC
-@sp 2
-
-@multitable @columnfractions .15 .85
-@item
-Example 1:
-@tab
-Calculating CRC-64
-@end multitable
-@sp 1
-@multitable @columnfractions .05 .95
-@item
-@tab
-Copyright (c) 2016 Lammert Bies
-@item
-@tab
-Copyright (c) 2021 Bastian Molkenthin
-@item
-@tab
-Copyright (c) 2023 Ulf Samuelsson
-@end multitable
-@sp 2
-@smallexample
-#define SHIFT(t)   ((sizeof(t)-1)*8)
-uint64_t calc_crc64
-  (algorithm_desc_t * dsc, const unsigned char *input_str, size_t num_bytes)
-@{
-  uint64_t crc;
-  const unsigned char *ptr;
-  uint64_t *crc_tab = dsc->crc_tab;
-  uint64_t index;
-
-  if ((ptr = input_str) == NULL)
-    return 0;
-
-  if (crc_tab == NULL)
-    return 0;
-
-
-  crc = dsc->initial;
-  if (dsc->reciprocal)
-    @{
-      for (uint32_t i = 0; i < num_bytes; i++)
-        @{
-          index = ((crc >> 0) ^ (uint64_t) * ptr++) & 0x00000000000000FFull;
-          crc = (crc >> 8) ^ crc_tab[index];
-        @}
-    @}
-  else
-    @{
-      uint32_t shift = SHIFT (uint64_t);
-      for (uint32_t i = 0; i < num_bytes; i++)
-        @{
-          const unsigned char c = *ptr++;
-          uint64_t rc = (uint64_t) (dsc->ireflect ? reflect8 (c) : c);
-          crc = (crc ^ (rc << shift));
-          index = (uint32_t) (crc >> shift);
-          crc = (crc << 8);
-          crc = (crc ^ (crc_tab[index]));
-        @}
-    @}
-  crc = (dsc->oreflect ? reflect64 (crc) : crc);
-  crc = crc ^ dsc->xor_val;
-  return crc;
-@}  /* calc_crc64 */
-@end smallexample
-@page
-@multitable @columnfractions .15 .85
-@item
-Example 2:
-@tab
-Calculating CRC-32
-@end multitable
-@sp 1
-@multitable @columnfractions .05 .95
-@item
-@tab
-Copyright (c) 2016 Lammert Bies
-@item
-@tab
-Copyright (c) 2021 Bastian Molkenthin
-@item
-@tab
-Copyright (c) 2023 Ulf Samuelsson
-@end multitable
-@sp 2
-@smallexample
-#define SHIFT(t)   ((sizeof(t)-1)*8)
-uint32_t
-calc_crc32 (algorithm_desc_t * dsc, const unsigned char *input_str,
-            size_t num_bytes)
-@{
-  uint32_t crc;
-  const unsigned char *ptr;
-  uint32_t index;
-  uint32_t *crc_tab = dsc->crc_tab;
-
-  if ((ptr = input_str) == NULL)
-    return 0;
-
-  if (crc_tab == NULL)
-    return 0;
-
-  crc = dsc->initial;
-
-  if (dsc->reciprocal)
-    @{
-      for (uint32_t i = 0; i < num_bytes; i++)
-        @{
-          index = ((crc >> 0) ^ (uint32_t) * ptr++) & 0x000000FFul;
-          crc = (crc >> 8) ^ crc_tab[index];
-        @}
-    @}
-  else
-    @{
-      uint32_t shift = SHIFT (uint32_t);
-      for (uint32_t i = 0; i < num_bytes; i++)
-        @{
-          const unsigned char c = *ptr++;
-          uint32_t rc = (uint32_t) (dsc->ireflect ? reflect8 (c) : c);
-          crc = (crc ^ (rc << shift));
-          index = (uint32_t) (crc >> shift);
-          crc = (crc << 8);
-          crc = (crc ^ (crc_tab[index]));
-        @}
-    @}
-  crc = (dsc->oreflect ? reflect32 (crc) : crc);
-  crc = crc ^ dsc->xor_val;
-  return crc;
-@} /* calc_crc32 */
-@end smallexample
-@page
-@multitable @columnfractions .15 .85
-@item
-Example 3:
-@tab
-Calculating CRC-32 using optimized routine
-@end multitable
-@sp 1
-@multitable @columnfractions .05 .95
-@item
-@tab
-Copyright (c) 2016 Lammert Bies
-@item
-@tab
-Copyright (c) 2021 Bastian Molkenthin
-@item
-@tab
-Copyright (c) 2023 Ulf Samuelsson
-@end multitable
-@sp 2
-@smallexample
-#define SHIFT(t)   ((sizeof(t)-1)*8)
-extern uint32_t *crc_tab;
-
-uint32_t
-calc_crc32 (const unsigned char *input_str, size_t num_bytes)
-@{
-  uint32_t crc;
-  const unsigned char *ptr;
-  uint32_t index;
-  uint32_t shift = SHIFT (uint32_t);
-
-  if ((ptr = input_str) == NULL)
-    return 0;
-
-  crc = 0xFFFFFFFF;
-  for (uint32_t i = 0; i < num_bytes; i++)
-    @{
-      const unsigned char c = *ptr++;
-      crc = (crc ^ (c << shift));
-      index = (uint32_t) (crc >> shift);
-      crc = (crc << 8);
-      crc = (crc ^ (crc_tab[index]));
-    @}
-  return crc ^ 0xFFFFFFFF;
-@} /* calc_crc32 */
-@end smallexample
-@page
-@cindex output section strings
-@kindex TIMESTAMP
-
-The @code{TIMESTAMP} command creates 64-bit integer with the number of seconds
-since Epoch (1970-01-01 00:00).
 
 @kindex FILL(@var{expression})
 @cindex holes, filling
diff --git a/ld/ldcrc32.c b/ld/ldcrc32.c
deleted file mode 100644 (file)
index 8b7de1d..0000000
+++ /dev/null
@@ -1,179 +0,0 @@
-/*
- * Library: ldlibcrc
- * Author:  Lammert Bies, Bastian Molkenthin, Ulf Samuelsson
- *
- * This file is licensed under the MIT License as stated below
- *
- * Copyright (c) 2016 Lammert Bies
- * Copyright (c) 2013 Ulf Samuelsson (ulf@emagii.com)
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- */
-
-#include "sysdep.h"
-#include "bfd.h"
-#include "lddigest.h"
-#include "ldreflect.h"
-
-#define SHIFT(t)   ((sizeof(t)-1)*8)
-/* ============ CRC-32 LIBCRC functions ======================================*/
-
-/*
- * void _init_crc32_tab (uint32_t *crc_tab,  uint32_t poly);
- *
- * For optimal speed, the CRC32 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * _init_crc32_tab is copyright (c) 2016 Lammert Bies
- */
-static void
-_init_crc32_tab (uint32_t * crc_tab, uint32_t poly)
-{
-  uint32_t crc;
-  uint32_t shift = SHIFT (uint32_t);
-  for (uint32_t i = 0; i < 256; i++)
-    {
-      crc = i << shift;
-      for (uint32_t j = 0; j < 8; j++)
-       {
-         if ((crc & 0x80000000u) != 0)
-           {
-             crc = (crc << 1) ^ poly;
-           }
-         else
-           {
-             crc = crc << 1;
-           }
-       }
-      crc_tab[i] = crc;
-    }
-}                              /* _init_crc32__tab */
-
-/*
- * void _init_crc32_reciprocal_tab (uint32_t *crc_tab,  uint32_t poly);
- *
- * For optimal speed, the CRC32 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * _init_crc32_reciprocal_tab is copyright (c) 2021 Bastian Molkenthin
- */
-static void
-_init_crc32_reciprocal_tab (uint32_t * crc_tab, uint32_t poly)
-{
-  uint32_t crc;
-  uint32_t reflected_poly = reflect32 (poly);
-  for (uint32_t i = 0; i < 256; i++)
-    {
-      crc = i;
-      for (uint32_t j = 0; j < 8; j++)
-       {
-         if (crc & 0x00000001U)
-           {
-             crc >>= 1;
-             crc ^= reflected_poly;
-           }
-         else
-           {
-             crc = crc >> 1;
-           }
-       }
-      crc_tab[i] = crc;
-    }
-}                              /* _init_crc32_reciprocal_tab */
-
-/*
- * void init_crc32_tab( void );
- *
- * For optimal speed, the CRC32 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * The table can be calculated in a normal or a reciprocal version.
- * init_crc64_tab is copyright (c) 2023 Ulf Samuelsson
- */
-uint32_t *
-init_crc32_tab (algorithm_desc_t * dsc)
-{
-  uint32_t *crc_tab = malloc (256 * sizeof (uint32_t));
-
-  if (crc_tab == NULL)
-    return NULL;
-
-  if (dsc->reciprocal)
-    {
-      _init_crc32_reciprocal_tab (crc_tab, dsc->poly.d32._0);
-    }
-  else
-    {
-      _init_crc32_tab (crc_tab, dsc->poly.d32._0);
-    }
-
-  return crc_tab;
-}                              /* init_crc32_tab */
-
-/*
- * uint32_t calc_crc32(algorithm_desc_t *dsc, const unsigned char *input_str, size_t num_bytes);
- *
- * The function calc_crc32() calculates in one pass the common 32 bit CRC value for
- * a byte string that is passed to the function together with a parameter
- * indicating the length.
- * calc_crc32 is
- *   copyright (c) 2016 Lammert Bies
- *   copyright (c) 2021 Bastian Molkenthin
- *   copyright (c) 2023 Ulf Samuelsson
- */
-uint32_t
-calc_crc32 (algorithm_desc_t * dsc, const unsigned char *input_str,
-           size_t num_bytes)
-{
-  uint32_t crc;
-  const unsigned char *ptr;
-  uint32_t index;
-  uint32_t *crc_tab = dsc->crc_tab;
-
-  if ((ptr = input_str) == NULL)
-    return 0;
-
-  if (crc_tab == NULL)
-    return 0;
-
-  crc = dsc->initial.d32._0;
-
-  if (dsc->reciprocal)
-    {
-      for (uint32_t i = 0; i < num_bytes; i++)
-       {
-         index = ((crc >> 0) ^ (uint32_t) * ptr++) & 0x000000FFul;
-         crc = (crc >> 8) ^ crc_tab[index];
-       }
-    }
-  else
-    {
-      uint32_t shift = SHIFT (uint32_t);
-      for (uint32_t i = 0; i < num_bytes; i++)
-       {
-         const unsigned char c = *ptr++;
-         uint32_t rc = (uint32_t) (dsc->ireflect ? reflect8 (c) : c);
-         crc = (crc ^ (rc << shift));
-         index = (uint32_t) (crc >> shift);
-         crc = (crc << 8);
-         crc = (crc ^ (crc_tab[index]));
-       }
-    }
-  crc = (dsc->oreflect ? reflect32 (crc) : crc);
-  crc = crc ^ dsc->xor_val.d32._0;
-  return crc;
-}                              /* calc_crc32 */
diff --git a/ld/ldcrc64.c b/ld/ldcrc64.c
deleted file mode 100644 (file)
index c94ff21..0000000
+++ /dev/null
@@ -1,180 +0,0 @@
-/*
- * Library: ldlibcrc
- * Author:  Lammert Bies, Bastian Molkenthin, Ulf Samuelsson
- *
- * This file is licensed under the MIT License as stated below
- *
- * Copyright (c) 2016 Lammert Bies
- * Copyright (c) 2021 Bastian Molkenthin
- * Copyright (c) 2023 Ulf Samuelsson (ulf@emagii.com)
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- */
-
-#include "sysdep.h"
-#include "bfd.h"
-#include "lddigest.h"
-#include "ldreflect.h"
-
-#define SHIFT(t)   ((sizeof(t)-1)*8)
-/* ============ CRC-64 LIBCRC functions ======================================*/
-
-/*
- * uint64_t *init_crc64_tab(algorithm_desc_t *dsc) ;
- *
- * For optimal speed, the CRC64 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * init_crc64_tab is copyright (c) 2016 Lammert Bies
- */
-static void
-_init_crc64_tab (uint64_t * crc_tab, uint64_t poly)
-{
-  uint64_t crc;
-  uint32_t shift = SHIFT (uint64_t);
-  for (uint64_t i = 0; i < 256; i++)
-    {
-      crc = i << shift;
-      for (uint64_t j = 0; j < 8; j++)
-       {
-         if ((crc & 0x8000000000000000ull) != 0)
-           {
-             crc = (crc << 1) ^ poly;
-           }
-         else
-           {
-             crc = crc << 1;
-           }
-       }
-      crc_tab[i] = crc;
-    }
-}                              /* _init_crc64_tab */
-
-/*
- * _init_crc64_reciprocal_tab (uint64_t *crc_tab,  uint64_t poly);
- *
- * For optimal speed, the CRC64 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * _init_crc64_reciprocal_tab is copyright (c) 2021 Bastian Molkenthin
- */
-
-static void
-_init_crc64_reciprocal_tab (uint64_t * crc_tab, uint64_t poly)
-{
-  uint64_t crc;
-  uint64_t reflected_poly = reflect64 (poly);
-  for (uint64_t i = 0; i < 256; i++)
-    {
-      crc = i;
-      for (uint64_t j = 0; j < 8; j++)
-       {
-         if ((crc & 0x0000000000000001ULL) != 0)
-           {
-             crc >>= 1;
-             crc ^= reflected_poly;
-           }
-         else
-           {
-             crc >>= 1;
-           }
-       }
-      crc_tab[i] = crc;
-    }
-}                              /* _init_crc64_reciprocal_tab */
-
-/*
- * uint64_t *init_crc64_tab(algorithm_desc_t *dsc) ;
- *
- * For optimal speed, the CRC64 calculation uses a table with pre-calculated
- * bit patterns which are used in the XOR operations in the program.
- * init_crc64_tab is copyright (c) 2023 Ulf Samuelsson
- */
-uint64_t *
-init_crc64_tab (algorithm_desc_t * dsc)
-{
-  uint64_t *crc_tab = malloc (256 * sizeof (uint64_t));
-
-  if (crc_tab == NULL)
-    return NULL;
-
-  if (dsc->reciprocal)
-    {
-      _init_crc64_reciprocal_tab (crc_tab, dsc->poly.d64);
-    }
-  else
-    {
-      _init_crc64_tab (crc_tab, dsc->poly.d64);
-    }
-  return crc_tab;
-
-}                              /* init_crc64_tab */
-
-/*
- * uint64_t calc_crc64
- *   (algorithm_desc_t *dsc, const unsigned char *input_str, size_t num_bytes);
- *
- * The function calc_crc64() calculates in one pass the 64 bit CRC value
- * for a byte string that is passed to the function together with a
- * parameter indicating the length.
- * calc_crc64 is
- *   copyright (c) 2016 Lammert Bies
- *   copyright (c) 2021 Bastian Molkenthin
- *   copyright (c) 2023 Ulf Samuelsson
- */
-uint64_t calc_crc64
-  (algorithm_desc_t * dsc, const unsigned char *input_str, size_t num_bytes)
-{
-  uint64_t crc;
-  const unsigned char *ptr;
-  uint64_t *crc_tab = dsc->crc_tab;
-  uint64_t index;
-
-  if ((ptr = input_str) == NULL)
-    return 0;
-
-  if (crc_tab == NULL)
-    return 0;
-
-
-  crc = dsc->initial.d64;
-  if (dsc->reciprocal)
-    {
-      for (uint32_t i = 0; i < num_bytes; i++)
-       {
-         index = ((crc >> 0) ^ (uint64_t) * ptr++) & 0x00000000000000FFull;
-         crc = (crc >> 8) ^ crc_tab[index];
-       }
-    }
-  else
-    {
-      uint32_t shift = SHIFT (uint64_t);
-      for (uint32_t i = 0; i < num_bytes; i++)
-       {
-         const unsigned char c = *ptr++;
-         uint64_t rc = (uint64_t) (dsc->ireflect ? reflect8 (c) : c);
-         crc = (crc ^ (rc << shift));
-         index = (uint32_t) (crc >> shift);
-         crc = (crc << 8);
-         crc = (crc ^ (crc_tab[index]));
-       }
-    }
-  crc = (dsc->oreflect ? reflect64 (crc) : crc);
-  crc = crc ^ dsc->xor_val.d64;
-  return crc;
-}                              /* calc_crc64 */
diff --git a/ld/lddigest.c b/ld/lddigest.c
deleted file mode 100644 (file)
index bd74202..0000000
+++ /dev/null
@@ -1,953 +0,0 @@
-/* Linker command language support.
-   Copyright (C) 1991-2023 Ulf Samuelsson <ulf@emagii.com>
-
-   This file is part of the GNU Binutils.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
-   MA 02110-1301, USA.  */
-
-#define        DEBUG_CRC       0
-
-#include "sysdep.h"
-#include "bfd.h"
-#include "safe-ctype.h"
-#include "obstack.h"
-#include "bfdlink.h"
-#include "ctf-api.h"
-
-#include "ld.h"
-#include "ldmain.h"
-#include "ldexp.h"
-#include "ldlang.h"
-#include <ldgram.h>
-#include "ldlex.h"
-#include "ldmisc.h"
-#include "lddigest.h"
-
-/* CRC calculation on output section */
-asection *text_section;
-unsigned char *text_contents = NULL;
-
-char *CRC_ADDRESS = NULL;
-char *CRC_START = NULL;
-char *CRC_END = NULL;
-char *CRC_TABLE = NULL;
-
-
-
-
-
-const char *digest_section = ".text";
-const char *digest_label = "___CRC_LABEL__";
-bool digest_big_endian = false;
-bool polynome_valid = false;
-
-static bool
-big_endian_host (void)
-{
-  union
-  {
-    uint32_t i;
-    char c[4];
-  } e = { 0x01000000 };
-
-  return e.c[0];
-}
-
-#if     0
-static bool
-swap_endian (void)
-{
-  if (big_endian_host ())
-    {
-      return !link_info.big_endian;
-    }
-  else
-    {
-      return link_info.big_endian;
-    }
-}
-#endif
-
-/* ============ CRC-32 public functions ======================================*/
-
-void
-lang_add_crc32_syndrome (algorithm_desc_t * a)
-{
-  CRC_ADDRESS = CRC32_ADDRESS;
-  CRC_START = CRC32_START;
-  CRC_END = CRC32_END;
-  CRC_TABLE = CRC32_TABLE;
-
-  lang_add_data (LONG, exp_intop (0)); /* Reserve room for the ECC value */
-  a->crc_tab = init_crc32_tab (a);
-  if (a->crc_tab == NULL)
-    {
-      einfo (_("%F%P: can not allocate memory for CRC table: %E\n"));
-      return;
-    }
-}
-
-static void
-lang_add_crc32_table (bool big_endian)
-{
-  /* Use a precomputed table, if one exists.  */
-  uint32_t *crc32_table = algorithm.crc_tab;
-  bool local_table = false;
-  if (crc32_table == NULL)
-    {
-      /* No luck, create a table.  */
-      crc32_table = init_crc32_tab (&algorithm);
-      if (crc32_table == NULL)
-       {
-         einfo (_("%F%P: can not allocate memory for CRC table: %E\n"));
-         return;
-       }
-      local_table = true;
-    }
-  for (int i = 0; i < 256; i++)
-    {
-      uint32_t elem = crc32_table[i];
-      if (big_endian)
-       {
-         elem = __builtin_bswap32 (elem);
-       }
-      lang_add_data (LONG, exp_intop (elem));
-    }
-  if (local_table)
-    free (crc32_table);
-}
-
-/* ============ CRC-64 public functions ======================================*/
-
-void
-lang_add_crc64_syndrome (algorithm_desc_t * a)
-{
-  CRC_ADDRESS = CRC64_ADDRESS;
-  CRC_START = CRC64_START;
-  CRC_END = CRC64_END;
-  CRC_TABLE = CRC64_TABLE;
-
-  /* Reserve room for the ECC value.  */
-  lang_add_data (QUAD, exp_intop (0));
-
-  a->crc_tab = init_crc64_tab (a);
-  if (a->crc_tab == NULL)
-    {
-      einfo (_("%F%P: can not allocate memory for CRC table: %E\n"));
-      return;
-    }
-}
-
-#if (DEBUG_CRC == 1)
-static void
-print_hash64_table (algorithm_desc_t * a)
-{
-  uint64_t *crc_tab = a->crc_tab;
-  uint32_t i;
-  if (crc_tab == NULL)
-    {
-      printf ("%-20ssBad Table\n", a->name);
-      return;
-
-    }
-
-  i = 0;
-  printf ("%03d\t", i);
-  printf ("0x%016lx, ", crc_tab[i + 0]);
-  printf ("0x%016lx, ", crc_tab[i + 1]);
-  printf ("0x%016lx, ", crc_tab[i + 2]);
-  printf ("0x%016lx\n", crc_tab[i + 3]);
-  printf ("\t...\n");
-  i = 252;
-  printf ("%03d\t", i);
-  printf ("0x%016lx, ", crc_tab[i + 0]);
-  printf ("0x%016lx, ", crc_tab[i + 1]);
-  printf ("0x%016lx, ", crc_tab[i + 2]);
-  printf ("0x%016lx\n", crc_tab[i + 3]);
-  printf ("\n");
-}
-#else
-#define print_hash64_table(x)
-#endif
-
-static void
-lang_add_crc64_table (bool big_endian)
-{
-  /* Use a precomputed table, if one exists.  */
-  uint64_t *crc64_table = algorithm.crc_tab;
-  bool local_table = false;
-
-  if (crc64_table == NULL)
-    {
-      /* No luck, create a table.  */
-      crc64_table = init_crc64_tab (&algorithm);
-      if (crc64_table == NULL)
-       {
-         einfo (_("%F%P: can not allocate memory for CRC table: %E\n"));
-         return;
-       }
-      local_table = true;
-    }
-
-  print_hash64_table (&algorithm);
-
-  for (int i = 0; i < 256; i++)
-    {
-      uint64_t elem = crc64_table[i];
-
-      if (big_endian)
-       elem = __builtin_bswap64 (elem);
-
-      if (link_info.big_endian)
-       elem = __builtin_bswap64 (elem);
-
-      if (sizeof (bfd_vma) >= QUAD_SIZE)
-       lang_add_data (QUAD, exp_intop (elem));
-      else
-       {
-         lang_add_data (LONG, exp_intop (elem >> 32));
-         lang_add_data (LONG, exp_intop (elem));
-       }
-    }
-
-  if (local_table)
-    free (crc64_table);
-}
-
-/* ============ DIGEST COMMON functions ======================================*/
-
-static uint64_t
-get_uint64 (etree_type *tree, bool *err)
-{
-  if (tree != NULL)
-    {
-      exp_fold_tree_no_dot (tree);
-
-      if (expld.result.valid_p)
-       {
-         if (expld.result.str != NULL)
-           {
-             char *end;
-             uint64_t val = strtoull (expld.result.str, &end, 16);
-             if (!*end)
-               return val;
-           }
-         else
-           {
-             if (expld.result.section != NULL)
-               expld.result.value += expld.result.section->vma;
-             return expld.result.value;
-           }
-       }
-    }
-  *err = true;
-  return 0;
-}
-
-void
-lang_add_digest (etree_type *size,
-                etree_type *poly,
-                etree_type *initial,
-                etree_type *xor_val,
-                etree_type *ireflect,
-                etree_type *oreflect,
-                etree_type *reciprocal)
-{
-  if (algorithm.crc_algo != no_algo)   /* We only allow one CRC <polynom> */
-    {
-      einfo (_("%X%P: Duplicate digest \"%s\"\n"), "in POLY command");
-      return;
-    }
-
-  bool err = false;
-  algorithm.name = "CUSTOM";
-  algorithm.big_endian = digest_big_endian;
-  algorithm.crc_size = get_uint64 (size, &err);
-  algorithm.poly.d64 = get_uint64 (poly, &err);
-  algorithm.initial.d64 = get_uint64 (initial, &err);
-  algorithm.xor_val.d64 = get_uint64 (xor_val, &err);
-  algorithm.ireflect = get_uint64 (ireflect, &err);
-  algorithm.oreflect = get_uint64 (oreflect, &err);
-  algorithm.crc_tab = NULL;
-  algorithm.reciprocal = get_uint64 (reciprocal, &err);
-  algorithm.expected.d64 = 0;
-
-  if (err)
-    {
-      einfo (_("%F%P: Invalid DIGEST arg\n"));
-      return;
-    }
-
-  if (algorithm.crc_size == 64)
-    {
-      algorithm.crc_algo = crc_algo_64;
-      lang_add_crc64_syndrome (&algorithm);
-    }
-  else if (algorithm.crc_size == 32)
-    {
-      algorithm.crc_algo = crc_algo_32;
-      algorithm.poly.d32._0 = algorithm.poly.d64;
-      algorithm.poly.d32._1 = 0;
-      algorithm.initial.d32._0 = algorithm.initial.d64;
-      algorithm.initial.d32._1 = 0;
-      algorithm.xor_val.d32._0 = algorithm.xor_val.d64;
-      algorithm.xor_val.d32._1 = 0;
-      lang_add_crc32_syndrome (&algorithm);
-    }
-  else
-    {
-      einfo (_("%F%P: Invalid Size in DIGEST\n"));
-      return;
-    }
-}
-
-static bool
-id_start_char (char c)
-{
-  bool OK = false;
-  if (('a' <= c) && (c <= 'z'))
-    OK |= true;
-  if (('A' <= c) && (c <= 'Z'))
-    OK |= true;
-  if ('_' == c)
-    OK |= true;
-  if ('-' == c)
-    OK |= true;
-  if ('.' == c)
-    OK |= true;
-  return OK;
-}
-
-static bool
-id_char (char c)
-{
-  bool OK = false;
-  if (('0' <= c) && (c <= '9'))
-    OK |= true;
-  OK |= id_start_char (c);
-  return OK;
-}
-
-const char *
-lang_get_label (const char *label, bool *big_endian)
-{
-  char *newlabel;
-  const char *p = &label[1];
-  char c;
-
-  *big_endian = false;         /* unless told otherwise */
-  if (command_line.endian == ENDIAN_BIG)
-    {
-      *big_endian = true;
-    }
-  if (command_line.endian == ENDIAN_LITTLE)
-    {
-      *big_endian = false;
-    }
-  c = *label;
-
-  if (!id_start_char (c))
-    {
-      einfo (_("%X%P: Illegal label \"%s\" in digest command\n"), label);
-      return "__CRC_LABEL__";
-    }
-
-  for (uint32_t i = 1; *p; i++)        /* ignore '.' in first character */
-    {
-      c = *p;
-      if (c == '#')
-       {
-         bool bad_endian = false;
-         newlabel = strndup (label, i);        /* Memory leak */
-         p++;
-         if (strlen (p) == 2)
-           {
-             char c0 = *p++;
-             char c1 = *p;
-             bool be = ((c0 == 'B') || (c0 == 'b')) &
-               ((c1 == 'E') || (c1 == 'e'));
-             bool le = ((c0 == 'L') || (c0 == 'l')) &
-               ((c1 == 'E') || (c1 == 'e'));
-             if (be)
-               {
-                 *big_endian = true;
-               }
-             else if (le)
-               {
-                 *big_endian = false;
-               }
-             else
-               {
-                 bad_endian = true;
-               }
-           }
-         else
-           {
-             bad_endian = true;
-           }
-         if (bad_endian)
-           {
-             einfo (_("%X%P: bad 'endian' \"%s\" in digest label\n"), label);
-           }
-         return newlabel;
-       }
-      else if (!id_char (c))
-       {
-         einfo (_("%X%P: Illegal label \"%s\" in digest command\n"), label);
-         return "__CRC_LABEL__";
-       }
-      else
-       {
-         p++;
-       }
-    }
-  return label;
-}
-
-bool
-lang_set_digest (char *digest)
-{
-  if (algorithm.crc_algo != no_algo)   /* We only allow one CRC <polynom> */
-    {
-      einfo (_("%X%P: Duplicate digest \"%s\"\n"), digest);
-      return false;
-    }
-
-  for (poly_t a = (poly_t) 0; a < MAXALGO; a++)
-    {
-#if (DEBUG_CRC == 1)
-      printf ("Comparing \"%s\" with \"%s\": ", digest, algorithms[a].name);
-#endif
-      if (!strcmp (digest, algorithms[a].name))
-       {
-#if (DEBUG_CRC == 1)
-         printf ("OK\n");
-#endif
-         memcpy (&algorithm, &algorithms[a], sizeof (algorithm_desc_t));
-         algorithm.big_endian = digest_big_endian;
-         if (algorithm.crc_size == 64)
-           {
-             lang_add_crc64_syndrome (&algorithm);
-           }
-         else if (algorithm.crc_size == 32)
-           {
-             lang_add_crc32_syndrome (&algorithm);
-           }
-
-         return true;
-       }
-#if (DEBUG_CRC == 1)
-      else
-       {
-         printf ("FAIL\n");
-       }
-#endif
-    }
-  einfo (_("%X%P: Unknown digest \"%s\"\n"), digest);
-  return false;
-}
-
-void
-lang_add_digest_table (bool big_endian)
-{
-  if (algorithm.crc_algo == crc_algo_32)
-    {
-      lang_add_crc32_table (big_endian);
-    }
-  else if (algorithm.crc_algo == crc_algo_64)
-    {
-      lang_add_crc64_table (big_endian);
-    }
-}
-
-/* ============ CRC DEBUG functions ==========================================*/
-
-#if (DEBUG_CRC == 1)
-static void
-debug_hex (char *prompt, unsigned char *section, bfd_vma address, bfd_vma sz)
-{
-  bfd_vma *vma_section = (bfd_vma *) section;
-  bfd_vma size = (sz) / sizeof (bfd_vma);
-  printf ("%s:\n", prompt);
-  for (bfd_vma i = 0; i < size; i += 8)
-    {
-      printf ("0x%08lx: 0x%016lx 0x%016lx 0x%016lx 0x%016lx\n",
-             address + (i * sizeof (bfd_vma)),
-             vma_section[i + 0],
-             vma_section[i + 1], vma_section[i + 2], vma_section[i + 3]);
-    }
-}
-
-static void
-debug_crc_header (char *prompt)
-{
-  debug_hex (prompt, text_contents, text_section->vma, 64);
-}
-
-static void
-debug_crc_update (bfd_vma crc, bfd_vma crc_addr)
-{
-  printf ("CRC [0x%016lx] update at 0x%08lx succeeded\n", crc, crc_addr);
-}
-
-static bool get_text_section_contents (void);
-static void
-debug_full_textsection (void)
-{
-
-  /* In order to see the updated content, we have to fetch it again */
-
-  if (!get_text_section_contents ())
-    {
-      debug_crc_header ("After CRC");
-      debug_hex ("Full Section After CRC",
-                text_contents, text_section->vma, text_section->size);
-      free (text_contents);
-    }
-}
-
-
-static void
-print_crc64_algorithm (algorithm_desc_t * a, const unsigned char *crc_data,
-                      uint64_t crc)
-{
-  printf ("64:%-16s, data=\"%s\", ", a->name, crc_data);
-  printf ("poly=0x%016lx i=0x%1x xor=0x%1x .ir=%u .or=%u .rp=%u ",
-         a->poly.d64,
-         a->initial.d32._0 & 0xF,
-         a->xor_val.d32._0 & 0xF, a->ireflect, a->oreflect, a->reciprocal);
-  printf ("checksum=0x%016lx, expected=0x%016lx\n", crc, a->expected.d64);
-}
-
-static void
-print_section (asection * a)
-{
-  uint32_t len = strlen (a->name);
-  char *name = malloc (len + 4);
-  char *p = name;
-  if (p != NULL)
-    {
-      *p++ = '"';
-      for (uint32_t i = 0; i < len; i++)
-       {
-         *p++ = a->name[i];
-       }
-      *p++ = '"';
-      *p++ = ':';
-      *p++ = '\0';
-    }
-  else
-    {
-      p = "\"?\"";
-    }
-  printf ("%-20s [0x%08lx .. 0x%08lx]\n", name, a->lma, a->lma + a->size - 1);
-  free (name);
-}
-
-static void
-print_section_list (void)
-{
-  bfd *list = link_info.output_bfd;
-  asection *elem;
-  if (strcmp (digest_section, ".foo"))
-    return;
-
-  for (elem = list->sections; elem != NULL; elem = elem->next)
-    {
-      if (elem->name != NULL)
-       {
-         print_section (elem);
-       }
-    }
-}
-
-#else
-#define        debug_hex(p,s,a,sz)
-#define debug_crc_header(p)
-#define debug_crc_update(c, a)
-#define debug_full_textsection()
-#define print_section(a)
-#define print_section_list()
-#endif
-
-/* ============ Access functions for inserting checksum in text section=======*/
-
-static bool
-get_section_by_address (bfd_vma addr)
-{
-  bfd *list = link_info.output_bfd;
-  for (asection * elem = list->sections; elem != NULL; elem = elem->next)
-    {
-      bfd_vma lma = elem->lma;
-      bfd_vma end = lma + elem->size;
-
-      if ((addr >= lma) && (addr < end))
-       {
-         digest_section = elem->name;
-         return true;
-       }
-    }
-  return false;
-}
-
-static bool
-get_text_section_contents (void)
-{
-  /*
-   * Get the '.text' section
-   * Is there a risk that CRC needs to be calculated on more than .text?
-   * We do not support that...
-   */
-  print_section_list ();
-
-  text_section =
-    bfd_get_section_by_name (link_info.output_bfd, digest_section);
-  if (text_section == NULL)
-    {
-      einfo (_("%X%P: cannot retrieve '%s' section for CRC calculation\n"),
-            digest_section);
-      return false;
-    }
-
-  /* Get the contents of the '.text' area so we can calculate the CRC */
-  if (!bfd_malloc_and_get_section (link_info.output_bfd,
-                                  text_section->output_section,
-                                  (bfd_byte **) & text_contents))
-    {
-      einfo (_("%X%P: '%s' section contents unavailable\n"
-              "CRC generation aborted\n"), digest_section);
-      return false;
-    }
-
-#if (DEBUG_CRC == 1)
-  print_section (text_section);
-/*
-  printf ("%s: [0x%08lx .. 0x%08lx]\n",
-         text_section->name,
-         text_section->lma, text_section->lma + text_section->size - 1);
- */
-#endif
-  return true;
-}
-
-/* Set variable in the '.text' area */
-static bool
-set_crc32_checksum (uint32_t crc, bfd_vma addr)
-{
-  uint32_t real_crc = crc;
-  if (big_endian_host ())
-    {
-      if (algorithm.big_endian)
-       {
-         /* We are OK */
-       }
-      else
-       {
-         real_crc = __builtin_bswap32 (crc);
-       }
-    }
-  else
-    {
-      if (algorithm.big_endian)
-       {
-         real_crc = __builtin_bswap32 (crc);
-       }
-      else
-       {
-         /* We are OK */
-       }
-    }
-
-  return (bfd_set_section_contents (link_info.output_bfd,
-                                   text_section->output_section,
-                                   &real_crc, addr, sizeof (uint32_t)));
-}
-
-static bool
-set_crc64_checksum (uint64_t crc, bfd_vma addr)
-{
-  uint64_t real_crc = crc;
-  if (big_endian_host ())
-    {
-      if (algorithm.big_endian)
-       {
-         /* We are OK */
-       }
-      else
-       {
-         real_crc = __builtin_bswap64 (crc);
-       }
-    }
-  else
-    {
-      if (algorithm.big_endian)
-       {
-         real_crc = __builtin_bswap64 (crc);
-       }
-      else
-       {
-         /* We are OK */
-       }
-    }
-  /* True if OK */
-  return (bfd_set_section_contents (link_info.output_bfd,
-                                   text_section->output_section,
-                                   &real_crc, addr, sizeof (uint64_t)));
-}
-
-static bool
-set_crc_checksum (uint64_t crc, bfd_vma addr, int size)
-{
-  bool status;
-  if (size == 64)
-    {
-      status = set_crc64_checksum (crc, addr);
-    }
-  else
-    {
-      status = set_crc32_checksum ((uint32_t) crc, addr);
-    }
-  return status;
-}
-
-static bool
-symbol_lookup (char *name, bfd_vma * val)
-{
-  struct bfd_link_hash_entry *h;
-  *val = 0ull;
-  h = bfd_link_hash_lookup (link_info.hash, name, false, false, true);
-  if (h != NULL)
-    {
-      if (((h->type == bfd_link_hash_defined) ||
-          (h->type == bfd_link_hash_defweak)) &&
-         (h->u.def.section->output_section != NULL))
-       {
-         *val = (h->u.def.value
-                 + bfd_section_vma (h->u.def.section->output_section)
-                 + h->u.def.section->output_offset);
-         return true;
-       }
-    }
-  return false;
-}
-
-/* ============ CRC common functions =========================================*/
-/*
- * Multiplexing function for calculating CRC with different algorithms
- * 'algorithm.crc_algo'
- */
-static uint64_t
-calculate_crc (const unsigned char *input_str, size_t num_bytes)
-{
-  if (algorithm.crc_algo == crc_algo_64)
-    {
-      if (algorithm.crc_tab != NULL)
-       {
-         return calc_crc64 (&algorithm, input_str, num_bytes);
-       }
-    }
-  else if (algorithm.crc_algo == crc_algo_32)
-    {
-      if (algorithm.crc_tab != NULL)
-       {
-         return calc_crc32 (&algorithm, input_str, num_bytes);
-       }
-    }
-  /* This should never happen */
-  return 0;
-}
-
-static bool
-invalid_crc_parameters (bfd_vma crc_addr,
-                       bfd_vma crc_area_start,
-                       bfd_vma crc_area_end)
-{
-  bool crc_in_section;
-  bfd_vma crc_size = algorithm.crc_size / 8;
-  /* Get limits of '.text' section */
-  bfd_vma text_start = text_section->lma;
-  bfd_vma text_end = text_section->lma + text_section->size;
-
-  /* All three symbols must be inside the '.text' section */
-  crc_in_section =
-    ((crc_addr >= text_start) && ((crc_addr + crc_size) <= text_end)) &&
-    ((crc_area_start >= text_start) && (crc_area_start <= text_end)) &&
-    ((crc_area_end >= text_start) && (crc_area_end <= text_end));
-
-  if (!crc_in_section)
-    {
-      einfo (_("%X%P: The CRC digest and table should be inside the '%s' "
-              "section\n"), digest_section);
-      /*
-       * Maybe we should printout the text section start and end
-       * as well as the boundaries of the CRC check area.
-       */
-      return true;
-    }
-
-  /*
-   * CRC checksum must be outside the checked area
-   * We must check that they do not overlap in the beginning
-   */
-  {
-    bool crc_valid = false;
-    if ((crc_addr + crc_size) < crc_area_start)
-      {
-       crc_valid = true;
-      }
-    else if (crc_addr >= crc_area_end)
-      {
-       crc_valid = true;
-      }
-    if (!crc_valid)
-      {
-       einfo (_("%X%P: CRC located inside checked area\n"), NULL);
-       return true;
-      }
-  }
-
-  if (crc_area_start > crc_area_end)
-    {
-      einfo (_("%X%P: CRC area starts after its end location\n"), NULL);
-      return true;
-    }
-
-  return false;
-}
-
-void
-lang_generate_crc (void)
-{
-  bfd_vma crc_addr, crc_area_start, crc_area_end;
-  uint64_t crc;
-  bool can_do_crc;
-
-  /* Return immediately, if CRC is not requested */
-  if (algorithm.crc_algo == no_algo)
-    return;
-
-  /*
-   * These symbols must be present, for CRC to be generated
-   * They should all have been defined in a CRC## <syndrome> statement
-   * If they are not defined, then there is an internal error.
-   * Should we consider using symbols which cannot be parsed by the linker?
-   * I.E. CRC-64 is never an identifier
-   */
-  can_do_crc = symbol_lookup (CRC_ADDRESS, &crc_addr) &&
-    symbol_lookup (CRC_START, &crc_area_start) &&
-    symbol_lookup (CRC_END, &crc_area_end);
-
-  if (!can_do_crc)
-    {
-      einfo (_("%X%P: Internal Error - __CRC#___ symbols not defined\n"),
-            NULL);
-      return;
-    }
-
-  if (!get_section_by_address (crc_addr))      /* update digest_section, if needed */
-    {
-      einfo (_("%X%P: The CRC digest and table must be inside the '%s' "
-              "section\n"), digest_section);
-    }
-
-  if (!get_text_section_contents ())
-    {
-      /* Error messages inside check */
-      return;
-    }
-
-  /* Check that the addresses make sense */
-  if (invalid_crc_parameters (crc_addr, crc_area_start, crc_area_end))
-    {
-      /* Error messages inside check */
-      return;
-    }
-
-  /* Calculate and set the CRC */
-  {
-    /*
-     * The '.text' area does not neccessarily start at 0x00000000,
-     * so we have to shift the indices.
-     */
-    bfd_vma _crc_addr = crc_addr - text_section->vma;
-    bfd_vma _crc_area_start = crc_area_start - text_section->vma;
-    bfd_vma _crc_area_end = crc_area_end - text_section->vma;
-
-
-    /* This is the CRC calculation which we worked so hard for */
-    debug_crc_header ("Before CRC");
-
-    print_hash64_table (&algorithm);
-
-#if (DEBUG_CRC == 1)
-    crc = calculate_crc ((const unsigned char *) "123456789", 9);
-#else
-    crc = calculate_crc (&text_contents[_crc_area_start],
-                        _crc_area_end - _crc_area_start);
-#endif
-
-#if (DEBUG_CRC == 1)
-    printf ("size  = 0x%08u\n", (uint32_t) (_crc_area_end - _crc_area_start));
-    printf ("start = 0x%016lx\n", _crc_area_start);
-    printf ("end   = 0x%016lx\n", _crc_area_end);
-    printf ("crc   = 0x%016lx\n", crc);
-
-    print_crc64_algorithm (&algorithm, &text_contents[_crc_area_start], crc);
-#endif
-
-    /*
-     * The contents of the '.text' section are no longer needed.
-     * It is a copy of the section contents, and will therefore be stale
-     * after we updated the section with the CRC checksum.
-     * Remove it before we set the CRC checksum, to simplify the code logic.
-     */
-    free (text_contents);
-    if (set_crc_checksum (crc, _crc_addr, algorithm.crc_size))
-      {
-       debug_crc_update (crc, crc_addr);
-      }
-    else
-      {
-       einfo (_("%X%P: updating CRC in section '%s' failed\n"),
-              digest_section);
-      }
-  }
-
-  debug_full_textsection ();
-}
-
-/* ============ END CRC common functions =====================================*/
-
-void
-lang_generate_digest (void)
-{
-  /* Return immediately, if CRC is not requested */
-#if (DEBUG_CRC == 1)
-  printf ("%s: BEGIN\n", __FUNCTION__);
-#endif
-  if (algorithm.crc_algo == no_algo)
-    return;
-
-  /* Handle 32/64-bit CRCs */
-  if ((algorithm.crc_algo == crc_algo_32)
-      || (algorithm.crc_algo == crc_algo_64))
-    {
-      lang_generate_crc ();
-    }
-#if (DEBUG_CRC == 1)
-  printf ("%s: END\n", __FUNCTION__);
-#endif
-}
diff --git a/ld/lddigest.h b/ld/lddigest.h
deleted file mode 100755 (executable)
index 8f2889f..0000000
+++ /dev/null
@@ -1,192 +0,0 @@
-/*
- * Library: libcrc
- * Author:  Lammert Bies, Ulf Samuelsson
- *
- * This file is licensed under the MIT License as stated below
- *
- * Copyright (c) 2016 Lammert Bies
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- */
-
-#ifndef LDDIGEST_H
-#define LDDIGEST_H
-
-#include <stddef.h>
-#include <stdint.h>
-#include <stdbool.h>
-#include "bfd.h"
-
-#define        CRC_POLY_64_ECMA        0x42F0E1EBA9EA3693ull   /* Normal */
-#define        CRC_POLY_64_ECMA_EXP    0x6C40DF5F0B497347ull   /* CRC when testing "123456789" */
-#define        CRC_POLY_64_ECMA_R      0xC96C5795D7870F42ull   /* Reversed */
-
-#define        CRC_POLY_64_ISO         0x000000000000001Bull   /* Normal */
-#define        CRC_POLY_64_ISO_EXP     0xB90956C775A41001ull   /* CRC when testing "123456789" */
-#define        CRC_POLY_64_ISO_R       0xD800000000000000ull   /* Reversed */
-
-#define        CRC_POLY_64_WE          0x42F0E1EBA9EA3693ull   /* Normal */
-#define        CRC_POLY_64_WE_EXP      0x62EC59E3F1A4F00Aull   /* CRC when testing "123456789" */
-
-#define        CRC_POLY_64_XZ          0x42F0E1EBA9EA3693ull   /* Normal */
-#define        CRC_POLY_64_XZ_EXP      0x995DC9BBDF1939FAull   /* CRC when testing "123456789" */
-
-#define        CRC_START_64            0x0000000000000000ull
-#define        CRC_START_64_ECMA       0x0000000000000000ull
-#define        CRC_START_64_WE         0xFFFFFFFFFFFFFFFFull
-#define        CRC_START_64_INV        0xFFFFFFFFFFFFFFFFull
-#define        CRC_END_64              0x0000000000000000ull
-#define        CRC_END_64_INV          0xFFFFFFFFFFFFFFFFull
-
-#define        CRC_START_32            0xFFFFFFFFul
-#define        CRC_END_32              0xFFFFFFFFul
-
-#define        CRC64_ADDRESS           "___CRC64___"
-#define        CRC64_START             "___CRC64_START___"
-#define        CRC64_END               "___CRC64_END___"
-#define        CRC64_TABLE             "___CRC64_TABLE___"
-
-#define        CRC_POLY_32             0x04C11DB7ul    /* Normal */
-#define        CRC_POLY_32_R           0xEDB88320ul    /* Reversed */
-
-#define        CRC_START_32_INV        0xFFFFFFFFul
-#define        CRC_END_32_INV    0xFFFFFFFFul
-
-#define        CRC32_ADDRESS           "___CRC32___"
-#define        CRC32_START             "___CRC32_START___"
-#define        CRC32_END               "___CRC32_END___"
-#define        CRC32_TABLE             "___CRC32_TABLE___"
-
-typedef enum algorithm
-{
-  no_algo = 0,
-  sha_algo_1 = 1,
-  crc_algo_32 = 4,
-  crc_algo_64 = 8,
-  sha_algo_256 = 256,
-  sha_algo_512
-} algo_t;
-
-typedef enum
-{
-  CRC64_ECMA,
-  CRC64_WE,
-  CRC64_XZ,
-  CRC64_ISO,
-  CRC64_ISO_R,
-  CRC32,
-  MAXALGO
-} poly_t;
-
-typedef struct
-{
-  uint8_t _0;
-  uint8_t _1;
-  uint8_t _2;
-  uint8_t _3;
-  uint8_t _4;
-  uint8_t _5;
-  uint8_t _6;
-  uint8_t _7;
-} uint8_ut;
-
-typedef struct
-{
-  uint16_t _0;
-  uint16_t _1;
-  uint16_t _2;
-  uint16_t _3;
-} uint16_ut;
-
-typedef struct
-{
-  uint32_t _0;
-  uint32_t _1;
-} uint32_ut;
-
-typedef union
-{
-  uint64_t d64;
-  uint32_ut d32;
-  uint16_ut d16;
-  uint8_ut d8;
-} int_t;
-
-typedef struct
-{
-  algo_t crc_algo;
-  uint32_t crc_size;
-  const char *name;
-  int_t poly;
-  int_t initial;
-  int_t xor_val;
-  bool ireflect;
-  bool oreflect;
-  bool reciprocal;
-  void *crc_tab;
-  int_t expected;
-  bool big_endian;
-} algorithm_desc_t;
-
-extern char *CRC_ADDRESS;
-extern char *CRC_START;
-extern char *CRC_END;
-extern char *CRC_TABLE;
-extern const algorithm_desc_t algorithms[];
-extern algorithm_desc_t algorithm;
-
-extern const char *digest_label;
-extern bool digest_big_endian;
-extern bool polynome_valid;
-
-/* In ldcrc32.c.  */
-extern uint32_t * init_crc32_tab
-  (algorithm_desc_t *);
-extern uint32_t calc_crc32
-  (algorithm_desc_t *, const unsigned char *, size_t);
-extern void lang_add_crc32_syndrome
-  (algorithm_desc_t *);
-
-/* In ldcrc64.c.  */
-extern uint64_t * init_crc64_tab
-  (algorithm_desc_t *);
-extern uint64_t calc_crc64
-  (algorithm_desc_t *, const unsigned char *, size_t);
-extern void lang_add_crc64_syndrome
-  (algorithm_desc_t * );
-
-/* In lddigest.c  */
-union etree_union;
-extern void lang_add_digest
-  (union etree_union *, union etree_union *, union etree_union *,
-   union etree_union *, union etree_union *, union etree_union *,
-   union etree_union *);
-extern bool lang_set_digest
-  (char *);
-extern void lang_add_digest_table
-  (bool);
-extern const char * lang_get_label
-  (const char *, bool *);
-extern void lang_generate_crc
-  (void);
-extern void lang_generate_digest
-  (void);
-
-#endif /* LDDIGEST_H */
diff --git a/ld/lddigest_tab.c b/ld/lddigest_tab.c
deleted file mode 100644 (file)
index b286a3c..0000000
+++ /dev/null
@@ -1,136 +0,0 @@
-/* Linker command language support.
-   Copyright (C) 1991-2023 Ulf Samuelsson <ulf@emagii.com>
-
-   This file is part of the GNU Binutils.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
-   MA 02110-1301, USA.  */
-
-#include "sysdep.h"
-#include "bfd.h"
-#include "safe-ctype.h"
-#include "obstack.h"
-#include "bfdlink.h"
-#include "ctf-api.h"
-
-#include "ld.h"
-#include "ldmain.h"
-#include "ldexp.h"
-#include "ldlang.h"
-#include <ldgram.h>
-#include "ldlex.h"
-#include "ldmisc.h"
-#include "lddigest.h"
-
-const algorithm_desc_t algorithms[MAXALGO+1] =
-{
-  [CRC64_ECMA] =
-       {
-               crc_algo_64, 64, "CRC64-ECMA",
-               .poly.d64 = CRC_POLY_64_ECMA,
-               .initial.d64 = CRC_START_64,
-               .xor_val.d64 = CRC_END_64,
-               .ireflect = false,
-               .oreflect = false,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0x6c40df5f0b497347
-       },
-  [CRC64_WE] =
-       {
-               crc_algo_64, 64, "CRC64-WE",
-               .poly.d64 = CRC_POLY_64_WE,
-               .initial.d64 = CRC_START_64_INV,
-               .xor_val.d64 = CRC_END_64_INV,
-               .ireflect = false,
-               .oreflect = false,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0x62ec59e3f1a4f00a
-       },
-  [CRC64_XZ] =
-       {
-               crc_algo_64, 64, "CRC64-XZ",
-               .poly.d64 = CRC_POLY_64_XZ,
-               .initial.d64 = CRC_START_64_INV,
-               .xor_val.d64 = CRC_END_64_INV,
-               .ireflect = true,
-               .oreflect = true,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0x995dc9bbdf1939fa
-       },
-  [CRC64_ISO] =
-       {
-               crc_algo_64, 64, "CRC64-GO-ISO",
-               .poly.d64 = CRC_POLY_64_ISO,
-               .initial.d64 = CRC_START_64_INV,
-               .xor_val.d64 = CRC_END_64_INV,
-               .ireflect = true,
-               .oreflect = true,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0xb90956c775a41001
-       },
-  [CRC64_ISO_R] =
-       {
-               crc_algo_64, 64, "CRC64-GO-ISO-R",
-               .poly.d64 = CRC_POLY_64_ISO,
-               .initial.d64 = CRC_START_64_INV,
-               .xor_val.d64 = CRC_END_64_INV,
-               .ireflect = false,
-               .oreflect = false,
-               .reciprocal = true,
-               .crc_tab = NULL,
-               .expected.d64 = 0xb90956c775a41001
-       },
-  [CRC32] =
-       {
-               crc_algo_32, 32, "CRC32",
-               .poly.d32 = { CRC_POLY_32, 0 },
-               .initial.d64 = CRC_START_32_INV,
-               .xor_val.d32 = { CRC_END_32_INV, 0 },
-               .ireflect = true,
-               .oreflect = true,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0xCBF43926
-       },
-  [MAXALGO] =
-       {
-               no_algo, 0, "",
-               .poly.d64 = 0,
-               .initial.d64 = 0,
-               .xor_val.d64 = 0,
-               .ireflect = false,
-               .oreflect = false,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0
-       }
-};
-
-algorithm_desc_t algorithm =
-{
-               no_algo, 0, "",
-               .poly.d64 = 0,
-               .initial.d64 = 0,
-               .xor_val.d64 = 0,
-               .ireflect = false,
-               .oreflect = false,
-               .reciprocal = false,
-               .crc_tab = NULL,
-               .expected.d64 = 0
-};
index 93aff6eeb766b39040a2e0e11650e340765bc583..26e56fe15660088c5d9e2bd52d0c1f973684ec76 100644 (file)
@@ -41,7 +41,6 @@
 #include "mri.h"
 #include "ldctor.h"
 #include "ldlex.h"
-#include "lddigest.h"
 
 #ifndef YYDEBUG
 #define YYDEBUG 1
@@ -131,9 +130,6 @@ static int error_index;
 %token DATA_SEGMENT_ALIGN DATA_SEGMENT_RELRO_END DATA_SEGMENT_END
 %token SORT_BY_NAME SORT_BY_ALIGNMENT SORT_NONE
 %token SORT_BY_INIT_PRIORITY
-%token DIGEST POLY POLYI TABLE
-%token TIMESTAMP
-%token DEBUG ON OFF
 %token '{' '}'
 %token SIZEOF_HEADERS OUTPUT_FORMAT FORCE_COMMON_ALLOCATION OUTPUT_ARCH
 %token INHIBIT_COMMON_ALLOCATION FORCE_GROUP_ALLOCATION
@@ -672,7 +668,7 @@ statement:
                {
                  lang_add_data ((int) $1, $3);
                }
-       | ASCII '(' mustbe_exp ')' NAME
+        | ASCII '(' mustbe_exp ')' NAME
                {
                  /* 'value' is a memory leak, do we care?  */
                  etree_type *value = $3;
@@ -689,31 +685,6 @@ statement:
                {
                  lang_add_fill ($3);
                }
-       | DIGEST NAME
-               { /* CRC_ADDRESS is set in <polynome>, but polynome reserves space, so we use a temporary */
-                 digest_label = lang_get_label ($2, &digest_big_endian);
-                 lang_add_assignment (exp_assign (digest_label, exp_nameop (NAME, "."), false));
-               }
-               polynome '(' mustbe_exp ',' mustbe_exp ')'
-               {
-                 if (polynome_valid)
-                   {
-                     lang_add_assignment (exp_assign (CRC_ADDRESS, exp_nameop (NAME, digest_label), false));
-                     lang_add_assignment (exp_assign (CRC_START, $6, false));
-                     lang_add_assignment (exp_assign (CRC_END,   $8, false));
-                   }
-               }
-       | DIGEST TABLE NAME
-               {
-                 bool       big_endian;
-                 const char *label = lang_get_label($3, &big_endian);
-                 lang_add_assignment (exp_assign (label, exp_nameop (NAME,"."), false));
-                 lang_add_digest_table (big_endian);
-               }
-       | TIMESTAMP
-               {
-                 lang_add_timestamp ();
-               }
        | ASSERT_K
                { ldlex_expression (); }
          '(' exp ',' NAME ')' separator
@@ -721,43 +692,13 @@ statement:
                  ldlex_popstate ();
                  lang_add_assignment (exp_assert ($4, $6));
                }
-       | DEBUG ON
-               {
-                 yydebug = 1;
-               }
-       | DEBUG OFF
-               {
-                 yydebug = 0;
-               }
        | INCLUDE filename
                {
                  ldfile_open_command_file ($2);
                }
-
          statement_list_opt END
        ;
 
-polynome:
-       NAME
-               {
-                 polynome_valid = lang_set_digest ($1);
-               }
-       | POLY '(' mustbe_exp ','
-                  mustbe_exp ',' mustbe_exp ',' mustbe_exp ','
-                  mustbe_exp ',' mustbe_exp ',' mustbe_exp ')'
-               {
-                 lang_add_digest (
-                       $3,     /* size                 */
-                       $5,     /* polynome             */
-                       $7,     /* initial value        */
-                       $9,     /* xor     value        */
-                       $11,    /* input   reflected    */
-                       $13,    /* output  reflected    */
-                       $15     /* reciprocal           */
-                       );
-                 polynome_valid = true;
-               }
-
 statement_list:
                statement_list statement
        |       statement
index 77917027f83ba20aefc93147ee46e249317cca8b..295de015da9dc94a2de131de9fe0f9d042b43afc 100644 (file)
@@ -20,7 +20,6 @@
 
 #include "sysdep.h"
 #include <limits.h>
-#include <time.h>
 #include "bfd.h"
 #include "libiberty.h"
 #include "filenames.h"
@@ -8521,13 +8520,6 @@ lang_add_string (size_t size, const char *s)
   free (string);
 }
 
-/* Store the time of linking in the image */
-void
-lang_add_timestamp (void)
-{
-  lang_add_data (QUAD, exp_intop ((bfd_vma) time (0)));
-}
-
 /* Create a new reloc statement.  RELOC is the BFD relocation type to
    generate.  HOWTO is the corresponding howto structure (we could
    look this up, but the caller has already done so).  SECTION is the
index ef785ae5cad4717e9693f35475edfcd7e0f60832..2300fa5b2a34498b0df4c90b5ed152ec4b314682 100644 (file)
@@ -649,8 +649,6 @@ extern void lang_add_data
 extern bfd_vma charcount(const char *s);
 extern void lang_add_string
   (size_t, const char *s);
-extern void lang_add_timestamp
-  (void);
 extern void lang_add_reloc
   (bfd_reloc_code_real_type, reloc_howto_type *, asection *, const char *,
    union etree_union *);
index a240538be6b9bed21d997128e88a03b083b57d94..910e7ea3b8b8da748dd29b276934572e4d1743ee 100644 (file)
@@ -298,13 +298,6 @@ V_IDENTIFIER [*?.$_a-zA-Z\[\]\-\!\^\\]([*?.$_a-zA-Z0-9\[\]\-\!\^\\]|::)*
 <SCRIPT>"AFTER"                                { RTOKEN(AFTER); }
 <SCRIPT>"BEFORE"                       { RTOKEN(BEFORE); }
 <WILD>"FILL"                           { RTOKEN(FILL); }
-<WILD>"DIGEST"                         { RTOKEN(DIGEST); }
-<WILD>"POLY"                           { RTOKEN(POLY); }
-<WILD>"TABLE"                          { RTOKEN(TABLE); }
-<WILD>"TIMESTAMP"                      { RTOKEN(TIMESTAMP); }
-<WILD>"DEBUG"                          { RTOKEN(DEBUG); }
-<WILD>"ON"                             { RTOKEN(ON); }
-<WILD>"OFF"                            { RTOKEN(OFF); }
 <SCRIPT>"STARTUP"                      { RTOKEN(STARTUP); }
 <SCRIPT>"OUTPUT_FORMAT"                        { RTOKEN(OUTPUT_FORMAT); }
 <SCRIPT>"OUTPUT_ARCH"                  { RTOKEN(OUTPUT_ARCH); }
index 6bd17c8746954be4f8fc637e7e14cc59de8c4f27..25cc89b72f90aaafacbba4ab1111a5c90fd7470a 100644 (file)
@@ -34,7 +34,6 @@
 #include "ldwrite.h"
 #include "ldexp.h"
 #include "ldlang.h"
-#include "lddigest.h"
 #include <ldgram.h>
 #include "ldlex.h"
 #include "ldfile.h"
@@ -528,7 +527,6 @@ main (int argc, char **argv)
 
   ldwrite ();
 
-  lang_generate_digest();              /* Calculate and store CRC on request */
   if (config.map_file != NULL)
     lang_map ();
   if (command_line.cref)
diff --git a/ld/ldreflect.c b/ld/ldreflect.c
deleted file mode 100644 (file)
index 0601e2a..0000000
+++ /dev/null
@@ -1,99 +0,0 @@
-/* Linker command language support.
-   Copyright (C) 1991-2023 Ulf Samuelsson <ulf@emagii.com>
-
-   This file is part of the GNU Binutils.
-
-   This program is free software; you can redistribute it and/or modify
-   it under the terms of the GNU General Public License as published by
-   the Free Software Foundation; either version 3 of the License, or
-   (at your option) any later version.
-
-   This program is distributed in the hope that it will be useful,
-   but WITHOUT ANY WARRANTY; without even the implied warranty of
-   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
-   GNU General Public License for more details.
-
-   You should have received a copy of the GNU General Public License
-   along with this program; if not, write to the Free Software
-   Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
-   MA 02110-1301, USA.  */
-
-#include <stdint.h>
-#include <stdlib.h>
-#include "ldreflect.h"
-
-uint8_t reflect_tab[256] = {
-  0x00, 0x80, 0x40, 0xC0, 0x20, 0xA0, 0x60, 0xE0,
-  0x10, 0x90, 0x50, 0xD0, 0x30, 0xB0, 0x70, 0xF0,
-  0x08, 0x88, 0x48, 0xC8, 0x28, 0xA8, 0x68, 0xE8,
-  0x18, 0x98, 0x58, 0xD8, 0x38, 0xB8, 0x78, 0xF8,
-  0x04, 0x84, 0x44, 0xC4, 0x24, 0xA4, 0x64, 0xE4,
-  0x14, 0x94, 0x54, 0xD4, 0x34, 0xB4, 0x74, 0xF4,
-  0x0C, 0x8C, 0x4C, 0xCC, 0x2C, 0xAC, 0x6C, 0xEC,
-  0x1C, 0x9C, 0x5C, 0xDC, 0x3C, 0xBC, 0x7C, 0xFC,
-  0x02, 0x82, 0x42, 0xC2, 0x22, 0xA2, 0x62, 0xE2,
-  0x12, 0x92, 0x52, 0xD2, 0x32, 0xB2, 0x72, 0xF2,
-  0x0A, 0x8A, 0x4A, 0xCA, 0x2A, 0xAA, 0x6A, 0xEA,
-  0x1A, 0x9A, 0x5A, 0xDA, 0x3A, 0xBA, 0x7A, 0xFA,
-  0x06, 0x86, 0x46, 0xC6, 0x26, 0xA6, 0x66, 0xE6,
-  0x16, 0x96, 0x56, 0xD6, 0x36, 0xB6, 0x76, 0xF6,
-  0x0E, 0x8E, 0x4E, 0xCE, 0x2E, 0xAE, 0x6E, 0xEE,
-  0x1E, 0x9E, 0x5E, 0xDE, 0x3E, 0xBE, 0x7E, 0xFE,
-  0x01, 0x81, 0x41, 0xC1, 0x21, 0xA1, 0x61, 0xE1,
-  0x11, 0x91, 0x51, 0xD1, 0x31, 0xB1, 0x71, 0xF1,
-  0x09, 0x89, 0x49, 0xC9, 0x29, 0xA9, 0x69, 0xE9,
-  0x19, 0x99, 0x59, 0xD9, 0x39, 0xB9, 0x79, 0xF9,
-  0x05, 0x85, 0x45, 0xC5, 0x25, 0xA5, 0x65, 0xE5,
-  0x15, 0x95, 0x55, 0xD5, 0x35, 0xB5, 0x75, 0xF5,
-  0x0D, 0x8D, 0x4D, 0xCD, 0x2D, 0xAD, 0x6D, 0xED,
-  0x1D, 0x9D, 0x5D, 0xDD, 0x3D, 0xBD, 0x7D, 0xFD,
-  0x03, 0x83, 0x43, 0xC3, 0x23, 0xA3, 0x63, 0xE3,
-  0x13, 0x93, 0x53, 0xD3, 0x33, 0xB3, 0x73, 0xF3,
-  0x0B, 0x8B, 0x4B, 0xCB, 0x2B, 0xAB, 0x6B, 0xEB,
-  0x1B, 0x9B, 0x5B, 0xDB, 0x3B, 0xBB, 0x7B, 0xFB,
-  0x07, 0x87, 0x47, 0xC7, 0x27, 0xA7, 0x67, 0xE7,
-  0x17, 0x97, 0x57, 0xD7, 0x37, 0xB7, 0x77, 0xF7,
-  0x0F, 0x8F, 0x4F, 0xCF, 0x2F, 0xAF, 0x6F, 0xEF,
-  0x1F, 0x9F, 0x5F, 0xDF, 0x3F, 0xBF, 0x7F, 0xFF
-};
-
-uint8_t
-reflect8 (uint8_t val)
-{
-  return reflect_tab[val];
-}
-
-uint16_t
-reflect16 (uint16_t val)
-{
-  uint16_t result;
-  result = ((uint16_t) reflect_tab[(val >> 0) & 0xFF]) << 8;
-  result |= ((uint16_t) reflect_tab[(val >> 8) & 0xFF]) << 0;
-  return result;
-}
-
-uint32_t
-reflect32 (uint32_t val)
-{
-  uint32_t result;
-  result = ((uint32_t) reflect_tab[(val >> 0) & 0xFF]) << 24;
-  result |= ((uint32_t) reflect_tab[(val >> 8) & 0xFF]) << 16;
-  result |= ((uint32_t) reflect_tab[(val >> 16) & 0xFF]) << 8;
-  result |= ((uint32_t) reflect_tab[(val >> 24) & 0xFF]) << 0;
-  return result;
-}
-
-uint64_t
-reflect64 (uint64_t val)
-{
-  uint64_t result;
-  result = ((uint64_t) reflect_tab[(val >> 0) & 0xFF]) << 56;
-  result |= ((uint64_t) reflect_tab[(val >> 8) & 0xFF]) << 48;
-  result |= ((uint64_t) reflect_tab[(val >> 16) & 0xFF]) << 40;
-  result |= ((uint64_t) reflect_tab[(val >> 24) & 0xFF]) << 32;
-  result |= ((uint64_t) reflect_tab[(val >> 32) & 0xFF]) << 24;
-  result |= ((uint64_t) reflect_tab[(val >> 40) & 0xFF]) << 16;
-  result |= ((uint64_t) reflect_tab[(val >> 48) & 0xFF]) << 8;
-  result |= ((uint64_t) reflect_tab[(val >> 56) & 0xFF]) << 0;
-  return result;
-}
diff --git a/ld/ldreflect.h b/ld/ldreflect.h
deleted file mode 100644 (file)
index a3f834d..0000000
+++ /dev/null
@@ -1,37 +0,0 @@
-/*
- * File:    reflect.h
- * Author:  Ulf Samuelsson <ulf@emagii.com>
- *
- * This file is licensed under the MIT License as stated below
- *
- * Copyright (c) 2013 Ulf Samuelsson (ulf@emagii.com)
- *
- * Permission is hereby granted, free of charge, to any person obtaining a copy
- * of this software and associated documentation files (the "Software"), to deal
- * in the Software without restriction, including without limitation the rights
- * to use, copy, modify, merge, publish, distribute, sublicense, and/or sell
- * copies of the Software, and to permit persons to whom the Software is
- * furnished to do so, subject to the following conditions:
- *
- * The above copyright notice and this permission notice shall be included in all
- * copies or substantial portions of the Software.
- *
- * THE SOFTWARE IS PROVIDED "AS IS", WITHOUT WARRANTY OF ANY KIND, EXPRESS OR
- * IMPLIED, INCLUDING BUT NOT LIMITED TO THE WARRANTIES OF MERCHANTABILITY,
- * FITNESS FOR A PARTICULAR PURPOSE AND NONINFRINGEMENT. IN NO EVENT SHALL THE
- * AUTHORS OR COPYRIGHT HOLDERS BE LIABLE FOR ANY CLAIM, DAMAGES OR OTHER
- * LIABILITY, WHETHER IN AN ACTION OF CONTRACT, TORT OR OTHERWISE, ARISING FROM,
- * OUT OF OR IN CONNECTION WITH THE SOFTWARE OR THE USE OR OTHER DEALINGS IN THE
- * SOFTWARE.
- *
- */
-
-#ifndef REFLECT_H
-#define REFLECT_H
-
-uint8_t reflect8 (uint8_t val);
-uint16_t reflect16 (uint16_t val);
-uint32_t reflect32 (uint32_t val);
-uint64_t reflect64 (uint64_t val);
-
-#endif /* REFLECT_H */
index 429b9374014ea5cc162e362997a753608491ca33..61871ad6a2b976b8826e9ea6cfd68ef69a10a63d 100644 (file)
@@ -3,14 +3,9 @@ elf-hints-local.h
 ld.h
 ldbuildid.c
 ldbuildid.h
-ldcrc32.c
-ldcrc64.c
 ldcref.c
 ldctor.c
 ldctor.h
-lddigest.c
-lddigest.h
-lddigest_tab.c
 ldelf.c
 ldelf.h
 ldelfgen.c
@@ -29,8 +24,6 @@ ldmain.c
 ldmain.h
 ldmisc.c
 ldmisc.h
-ldreflect.c
-ldreflect.h
 ldver.c
 ldver.h
 ldwrite.c
diff --git a/ld/testsuite/ld-scripts/begin_tag.inc b/ld/testsuite/ld-scripts/begin_tag.inc
deleted file mode 100644 (file)
index ef395bb..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-      BYTE(0x43);
-      BYTE(0x4F);
-      BYTE(0x44);
-      BYTE(0x45);
-      BYTE(0xDE);
-      BYTE(0xAD);
-      BYTE(0xBE);
-      BYTE(0xEF);
-      QUAD(0);
diff --git a/ld/testsuite/ld-scripts/crc32-poly.d b/ld/testsuite/ld-scripts/crc32-poly.d
deleted file mode 100644 (file)
index 726534d..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-#source: crc32-poly.s
-#ld: -T crc32-poly.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#notarget: [is_aout_format]
-#xfail: tic4x-*-* tic54x-*-*
-#skip: ns32k-pc532-macho, pdp11-dec-aout, powerpc-ibm-aix5.2.0
-#skip: rs6000-aix4.3.3, alpha-linuxecoff
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 cbf43926 00000000 00000000 00000000  ..9&............
- 1220 cbf43926 00000000 00000000 00000000  ..9&............
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 1c00 454e4420 5441424c 45000000 00000000  END TABLE.......
- 1c10 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc32-poly.s b/ld/testsuite/ld-scripts/crc32-poly.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc32-poly.t b/ld/testsuite/ld-scripts/crc32-poly.t
deleted file mode 100644 (file)
index a2b7d13..0000000
+++ /dev/null
@@ -1,42 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0xCB);
-      BYTE(0xF4);
-      BYTE(0x39);
-      BYTE(0x26);
-      LONG(0x0);
-      QUAD(0x0);
-
-
-      crc32 = .;
-      DIGEST "_CRC32#BE" POLY(32, 0x04C11DB7, 0xFFFFFFFF,0xFFFFFFFF,1,1,0 )(ecc_start , ecc_end)
-      LONG(0);
-      QUAD(0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc32.d b/ld/testsuite/ld-scripts/crc32.d
deleted file mode 100644 (file)
index e35eaf8..0000000
+++ /dev/null
@@ -1,26 +0,0 @@
-#source: crc32.s
-#ld: -T crc32.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#notarget: [is_aout_format]
-#xfail: tic4x-*-* tic54x-*-*
-#skip: ns32k-pc532-macho, pdp11-dec-aout, powerpc-ibm-aix5.2.0
-#skip: rs6000-aix4.3.3, alpha-linuxecoff
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 cbf43926 00000000 00000000 00000000  ..9&............
- 1220 cbf43926 00000000 00000000 00000000  ..9&............
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 1c00 454e4420 5441424c 45000000 00000000  END TABLE.......
- 1c10 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc32.s b/ld/testsuite/ld-scripts/crc32.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc32.t b/ld/testsuite/ld-scripts/crc32.t
deleted file mode 100644 (file)
index b218ef1..0000000
+++ /dev/null
@@ -1,41 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0xCB);
-      BYTE(0xF4);
-      BYTE(0x39);
-      BYTE(0x26);
-      LONG(0x0);
-      QUAD(0x0);
-
-      crc32 = .;
-      DIGEST "_CRC32#BE" "CRC32" (ecc_start , ecc_end);
-      LONG(0);
-      QUAD(0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-contents.d b/ld/testsuite/ld-scripts/crc64-bad-endian-contents.d
deleted file mode 100644 (file)
index 148297d..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-bad-endian-size.s
-#ld: -T crc64-bad-endian-size.t
-# error: .*: bad 'endian' .* in digest label.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-contents.s b/ld/testsuite/ld-scripts/crc64-bad-endian-contents.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-contents.t b/ld/testsuite/ld-scripts/crc64-bad-endian-contents.t
deleted file mode 100644 (file)
index 8eecaf0..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#NE" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-size.d b/ld/testsuite/ld-scripts/crc64-bad-endian-size.d
deleted file mode 100644 (file)
index 148297d..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-bad-endian-size.s
-#ld: -T crc64-bad-endian-size.t
-# error: .*: bad 'endian' .* in digest label.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-size.s b/ld/testsuite/ld-scripts/crc64-bad-endian-size.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-bad-endian-size.t b/ld/testsuite/ld-scripts/crc64-bad-endian-size.t
deleted file mode 100644 (file)
index 8f9cd60..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BEG" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label-2.d b/ld/testsuite/ld-scripts/crc64-bad-label-2.d
deleted file mode 100644 (file)
index 0758461..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-bad-label-2.s
-#ld: -T crc64-bad-label-2.t
-# error: .*: Illegal label .* in digest command.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label-2.s b/ld/testsuite/ld-scripts/crc64-bad-label-2.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label-2.t b/ld/testsuite/ld-scripts/crc64-bad-label-2.t
deleted file mode 100644 (file)
index 19782bf..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC^64#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label.d b/ld/testsuite/ld-scripts/crc64-bad-label.d
deleted file mode 100644 (file)
index 37c2bb2..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-bad-label.s
-#ld: -T crc64-bad-label.t
-# error: .*: Illegal label .* in digest command.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label.s b/ld/testsuite/ld-scripts/crc64-bad-label.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-bad-label.t b/ld/testsuite/ld-scripts/crc64-bad-label.t
deleted file mode 100644 (file)
index 8c0941c..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "0_CRC64#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-ecma.d b/ld/testsuite/ld-scripts/crc64-ecma.d
deleted file mode 100644 (file)
index 1c92ff7..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-#source: crc64-ecma.s
-#ld: -T crc64-ecma.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1220 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 2000 454e4420 5441424c 45000000 00000000  END TABLE.......
- 2010 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc64-ecma.s b/ld/testsuite/ld-scripts/crc64-ecma.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-ecma.t b/ld/testsuite/ld-scripts/crc64-ecma.t
deleted file mode 100644 (file)
index 2a82039..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-in-section.d b/ld/testsuite/ld-scripts/crc64-in-section.d
deleted file mode 100644 (file)
index ede5d52..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-in-section.s
-#ld: -T crc64-in-section.t
-#error: .*: CRC located inside checked area
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-in-section.s b/ld/testsuite/ld-scripts/crc64-in-section.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-in-section.t b/ld/testsuite/ld-scripts/crc64-in-section.t
deleted file mode 100644 (file)
index e2e8cd9..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      bad_start = .;
-      DIGEST "_CRC64#BE" "CRC64-ECMA" (bad_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-iso.d b/ld/testsuite/ld-scripts/crc64-iso.d
deleted file mode 100644 (file)
index af416d0..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-#source: crc64-iso.s
-#ld: -T crc64-iso.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 b90956c7 75a41001 00000000 00000000  ..V.u...........
- 1220 b90956c7 75a41001 00000000 00000000  ..V.u...........
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 2000 454e4420 5441424c 45000000 00000000  END TABLE.......
- 2010 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc64-iso.s b/ld/testsuite/ld-scripts/crc64-iso.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-iso.t b/ld/testsuite/ld-scripts/crc64-iso.t
deleted file mode 100644 (file)
index 20dedc4..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0xb9);
-      BYTE(0x09);
-      BYTE(0x56);
-      BYTE(0xc7);
-      BYTE(0x75);
-      BYTE(0xa4);
-      BYTE(0x10);
-      BYTE(0x01);
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" "CRC64-GO-ISO" (ecc_start , ecc_end)
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-iso_be.d b/ld/testsuite/ld-scripts/crc64-iso_be.d
deleted file mode 100644 (file)
index 0707aae..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-#source: crc64-iso_be.s
-#ld: -T crc64-iso_be.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 0110a475 c75609b9 00000000 00000000  ...u.V..........
- 1220 0110a475 c75609b9 00000000 00000000  ...u.V..........
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 2000 454e4420 5441424c 45000000 00000000  END TABLE.......
- 2010 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc64-iso_be.s b/ld/testsuite/ld-scripts/crc64-iso_be.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-iso_be.t b/ld/testsuite/ld-scripts/crc64-iso_be.t
deleted file mode 100644 (file)
index 22cc37c..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x01);
-      BYTE(0x10);
-      BYTE(0xa4);
-      BYTE(0x75);
-      BYTE(0xc7);
-      BYTE(0x56);
-      BYTE(0x09);
-      BYTE(0xb9);
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64" "CRC64-GO-ISO" (ecc_start , ecc_end)
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table_be.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-multiple-digest.d b/ld/testsuite/ld-scripts/crc64-multiple-digest.d
deleted file mode 100644 (file)
index c027914..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-multiple-digest.s
-#ld: -T crc64-multiple-digest.t
-# error: .*: Duplicate digest .*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-multiple-digest.s b/ld/testsuite/ld-scripts/crc64-multiple-digest.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-multiple-digest.t b/ld/testsuite/ld-scripts/crc64-multiple-digest.t
deleted file mode 100644 (file)
index 49c1119..0000000
+++ /dev/null
@@ -1,45 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64A#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-      DIGEST "_CRC64B#BE" "CRC64-ISO" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-poly-size.d b/ld/testsuite/ld-scripts/crc64-poly-size.d
deleted file mode 100644 (file)
index 1c7b3c4..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-poly-size.s
-#ld: -T crc64-poly-size.t
-# error: .*: Invalid Size in DIGEST
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-poly-size.s b/ld/testsuite/ld-scripts/crc64-poly-size.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-poly-size.t b/ld/testsuite/ld-scripts/crc64-poly-size.t
deleted file mode 100644 (file)
index 8dad718..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" POLY(80,0x42F0E1EBA9EA3693,0,0,0,0,0)(ecc_start , ecc_end)
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-poly.d b/ld/testsuite/ld-scripts/crc64-poly.d
deleted file mode 100644 (file)
index b54ac47..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-#source: crc64-poly.s
-#ld: -T crc64-poly.t
-#objdump: -s -j .text
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
-
-.*:     file format .*
-
-Contents of section .text:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1220 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 2000 454e4420 5441424c 45000000 00000000  END TABLE.......
- 2010 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc64-poly.s b/ld/testsuite/ld-scripts/crc64-poly.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-poly.t b/ld/testsuite/ld-scripts/crc64-poly.t
deleted file mode 100644 (file)
index fb357ca..0000000
+++ /dev/null
@@ -1,43 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" POLY(64,0x42F0E1EBA9EA3693,0,0,0,0,0)(ecc_start , ecc_end)
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-reverse-area.d b/ld/testsuite/ld-scripts/crc64-reverse-area.d
deleted file mode 100644 (file)
index 4f2a3d1..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-reverse-area.s
-#ld: -T crc64-reverse-area.t
-# error: .*: CRC area starts after its end location.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-reverse-area.s b/ld/testsuite/ld-scripts/crc64-reverse-area.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-reverse-area.t b/ld/testsuite/ld-scripts/crc64-reverse-area.t
deleted file mode 100644 (file)
index 27aef44..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" "CRC64-ECMA" (ecc_end, ecc_start);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-same-section.d b/ld/testsuite/ld-scripts/crc64-same-section.d
deleted file mode 100644 (file)
index 779f24a..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-same-section.s
-#ld: -T crc64-same-section.t
-#error: .*: The CRC digest and table should be inside the .*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-same-section.s b/ld/testsuite/ld-scripts/crc64-same-section.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-same-section.t b/ld/testsuite/ld-scripts/crc64-same-section.t
deleted file mode 100644 (file)
index 47c96f5..0000000
+++ /dev/null
@@ -1,47 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .crc ALIGN (0x200) :
-    {
-      crc64 = .;
-      DIGEST "_CRC64#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-    } > rom
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-section.d b/ld/testsuite/ld-scripts/crc64-section.d
deleted file mode 100644 (file)
index fe1f83c..0000000
+++ /dev/null
@@ -1,23 +0,0 @@
-#source: crc64-section.s
-#ld: -T crc64-section.t
-#objdump: -s -j .foo
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
-
-.*:     file format .*
-
-Contents of section .foo:
- 1200 434f4445 deadbeef 00000000 00000000  CODE............
- 1210 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1220 6c40df5f 0b497347 00000000 00000000  l@._.IsG........
- 1230 00000000 00000000 deadbeef 434f4445  ............CODE
- 1240 31323334 35363738 3900ffff ffffffff  123456789.......
- 1250 434f4445 00000000 00000000 00000000  CODE............
- 1260 ffffffff ffffffff ffffffff ffffffff  .*
-#...
- 17e0 434f4445 deadbeef 00000000 00000000  CODE............
- 17f0 44494745 53542054 41424c45 00000000  DIGEST TABLE....
-#...
- 2000 454e4420 5441424c 45000000 00000000  END TABLE.......
- 2010 00000000 00000000 deadbeef 434f4445  ............CODE
-#pass
diff --git a/ld/testsuite/ld-scripts/crc64-section.s b/ld/testsuite/ld-scripts/crc64-section.s
deleted file mode 100644 (file)
index 99ff9f8..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .foo
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-section.t b/ld/testsuite/ld-scripts/crc64-section.t
deleted file mode 100644 (file)
index 7cfcdf7..0000000
+++ /dev/null
@@ -1,56 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .foo ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" "CRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      ecc_start = .;
-      ASCIZ "123456789"
-      ecc_end = . - 1;
-      . = ALIGN(0x10);
-
-      entry = .;
-      *(.foo)
-      . = ALIGN(0x100);
-      BYTE(1);
-      INCLUDE "digest_table.inc"
-    } > rom
-  .text ALIGN (0x200) :
-    {
-      *(.text)
-      QUAD(0x0)
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc64-unknown-digest.d b/ld/testsuite/ld-scripts/crc64-unknown-digest.d
deleted file mode 100644 (file)
index 2e41758..0000000
+++ /dev/null
@@ -1,5 +0,0 @@
-#source: crc64-unknown-digest.s
-#ld: -T crc64-unknown-digest.t
-# error: .*: Unknown digest.*
-#target: [is_elf_format] [is_coff_format]
-#skip: tic4x-*-* tic54x-*-*
diff --git a/ld/testsuite/ld-scripts/crc64-unknown-digest.s b/ld/testsuite/ld-scripts/crc64-unknown-digest.s
deleted file mode 100644 (file)
index e4ffb15..0000000
+++ /dev/null
@@ -1,21 +0,0 @@
-    .extern ecc_start
-       .section .text
-main:
-       .byte 0x43
-       .byte 0x4F
-       .byte 0x44
-       .byte 0x45
-    .long 0
-    .long 0
-    .long 0
-       .section .data
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xde
-    .byte 0xad
-    .byte 0xbe
-    .byte 0xef
-       .section .bss
-       .long 0
diff --git a/ld/testsuite/ld-scripts/crc64-unknown-digest.t b/ld/testsuite/ld-scripts/crc64-unknown-digest.t
deleted file mode 100644 (file)
index 9f4c900..0000000
+++ /dev/null
@@ -1,44 +0,0 @@
-MEMORY {
-  rom : ORIGIN = 0x000000, LENGTH = 0x4000
-  ram : ORIGIN = 0x008000, LENGTH = 0x1000
-}
-
-_start = 0x000000;
-SECTIONS
-{
-  . = 0x1000 + SIZEOF_HEADERS;
-  .text ALIGN (0x200) :
-
-    {
-      FILL(0xFF)
-      header = .;
-      INCLUDE "begin_tag.inc"
-
-      expected = .;
-      BYTE(0x6C);
-      BYTE(0x40);
-      BYTE(0xDF);
-      BYTE(0x5F);
-      BYTE(0x0B);
-      BYTE(0x49);
-      BYTE(0x73);
-      BYTE(0x47);
-
-      QUAD(0x0);
-
-      crc64 = .;
-      DIGEST "_CRC64#BE" "TCRC64-ECMA" (ecc_start , ecc_end);
-      QUAD(0x0);
-
-      INCLUDE "end_tag.inc"
-
-      INCLUDE "crc_data.inc"
-
-      INCLUDE "digest_table.inc"
-    } > rom
-
-  .data : AT (0x008000) { *(.data) } >ram /* NO default AT>rom */
-  . = ALIGN(0x20);
-  .bss : { *(.bss) } >ram /* NO default AT>rom */
-  /DISCARD/ : { *(*) }
-}
diff --git a/ld/testsuite/ld-scripts/crc_data.inc b/ld/testsuite/ld-scripts/crc_data.inc
deleted file mode 100644 (file)
index 176a468..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-      ecc_start = .;
-      ASCIZ "123456789"
-      ecc_end = . - 1;
-      . = ALIGN(0x10);
-
-      entry = .;
-      *(.text)
-      . = ALIGN(0x100);
-      BYTE(1);
diff --git a/ld/testsuite/ld-scripts/digest_table.inc b/ld/testsuite/ld-scripts/digest_table.inc
deleted file mode 100644 (file)
index fb40a4f..0000000
+++ /dev/null
@@ -1,6 +0,0 @@
-      . = ALIGN(2048) - 32;
-      INCLUDE "begin_tag.inc"
-      ASCII (16) "DIGEST TABLE"
-      DIGEST TABLE "CRCTAB"
-      ASCII (16) "END TABLE"
-      INCLUDE "end_tag.inc"
diff --git a/ld/testsuite/ld-scripts/digest_table_be.inc b/ld/testsuite/ld-scripts/digest_table_be.inc
deleted file mode 100644 (file)
index eec712d..0000000
+++ /dev/null
@@ -1,6 +0,0 @@
-      . = ALIGN(2048) - 32;
-      INCLUDE "begin_tag.inc"
-      ASCII (16) "DIGEST TABLE"
-      DIGEST TABLE "CRCTAB.BE"
-      ASCII (16) "END TABLE"
-      INCLUDE "end_tag.inc"
diff --git a/ld/testsuite/ld-scripts/end_tag.inc b/ld/testsuite/ld-scripts/end_tag.inc
deleted file mode 100644 (file)
index 4c80854..0000000
+++ /dev/null
@@ -1,9 +0,0 @@
-      QUAD(0);
-      BYTE(0xDE);
-      BYTE(0xAD);
-      BYTE(0xBE);
-      BYTE(0xEF);
-      BYTE(0x43);
-      BYTE(0x4F);
-      BYTE(0x44);
-      BYTE(0x45);
index 64767d87f83b2c5579c16e535ce76842b35cb08b..56e12da8e616c566793fc798835e545fb8c8bbe1 100644 (file)
@@ -229,23 +229,6 @@ foreach test_script $test_script_list {
 
 run_dump_test "asciz"
 run_dump_test "ascii"
-run_dump_test "crc64-ecma"
-run_dump_test "crc64-iso"
-run_dump_test "crc64-iso_be"
-run_dump_test "crc64-poly"
-run_dump_test "crc32"
-run_dump_test "crc32-poly"
-run_dump_test "crc64-reverse-area"
-run_dump_test "crc64-in-section"
-run_dump_test "crc64-same-section"
-run_dump_test "crc64-multiple-digest"
-run_dump_test "crc64-unknown-digest"
-run_dump_test "crc64-poly-size"
-run_dump_test "crc64-bad-label"
-run_dump_test "crc64-bad-label-2"
-run_dump_test "crc64-bad-endian-size"
-run_dump_test "crc64-bad-endian-contents"
-
 run_dump_test "align-with-input"
 run_dump_test "pr20302"
 run_dump_test "output-section-types"