mirror of
https://sourceware.org/git/binutils-gdb.git
synced 2025-01-12 12:16:04 +08:00
df5f2391f7
This patch standardizes messages in ld, to better conform to the GNU coding standard. Besides issues of capitalization and full-stops, I've - Split up help messages for target options, so that adding a new option does not mean loss of translation for all the others. - Embedded tabs have been removed, since a user might have tab stops set at other than 8 char intervals. - Added missing program name (%P). ld isn't the compiler. - Put %F and %X first (and removed %X if %F was present). These can go anywhere, but look silly in the m%Fiddle of a message, and choosing "%P%F:" in some messages but "%F%P:" in others leads to the likelihood of duplication in ld.pot. Besides, the colon belongs with %P. * emulparams/call_nop.sh, * emulparams/cet.sh, * emulparams/elf32mcore.sh, * emultempl/aarch64elf.em * emultempl/aix.em, * emultempl/alphaelf.em, * emultempl/armcoff.em, * emultempl/armelf.em, * emultempl/avrelf.em, * emultempl/beos.em, * emultempl/bfin.em, * emultempl/cr16elf.em, * emultempl/elf32.em, * emultempl/elf-generic.em, * emultempl/hppaelf.em, * emultempl/linux.em, * emultempl/lnk960.em, * emultempl/m68hc1xelf.em, * emultempl/m68kcoff.em, * emultempl/m68kelf.em, * emultempl/metagelf.em, * emultempl/mipself.em, * emultempl/mmix-elfnmmo.em, * emultempl/mmo.em, * emultempl/msp430.em, * emultempl/nds32elf.em, * emultempl/nios2elf.em, * emultempl/pe.em, * emultempl/pep.em, * emultempl/ppc32elf.em, * emultempl/ppc64elf.em, * emultempl/scoreelf.em, * emultempl/sh64elf.em, * emultempl/spuelf.em, * emultempl/sunos.em, * emultempl/tic6xdsbt.em, * emultempl/ticoff.em, * emultempl/v850elf.em, * emultempl/vms.em, * emultempl/vxworks.em, * emultempl/xtensaelf.em, * ldcref.c, * ldctor.c, * ldexp.c, * ldfile.c, * ldgram.y, * ldlang.c, * ldmain.c, * ldmisc.c, * ldwrite.c, * lexsup.c, * mri.c, * pe-dll.c, * plugin.c: Standardize error/warning messages. * testsuite/ld-arc/jli-overflow.err, * testsuite/ld-arm/cmse-implib-errors.out, * testsuite/ld-arm/cmse-new-earlier-later-implib.out, * testsuite/ld-arm/cmse-new-implib-not-sg-in-implib.out, * testsuite/ld-arm/cmse-new-wrong-implib.out, * testsuite/ld-arm/cmse-veneers-no-gnu_sgstubs.out, * testsuite/ld-arm/cmse-veneers-wrong-entryfct.out, * testsuite/ld-arm/vxworks1-static.d, * testsuite/ld-cris/tls-err-20x.d, * testsuite/ld-cris/tls-err-29.d, * testsuite/ld-cris/tls-err-31.d, * testsuite/ld-cris/tls-err-33.d, * testsuite/ld-cris/tls-err-35.d, * testsuite/ld-cris/tls-err-37.d, * testsuite/ld-cris/tls-err-39.d, * testsuite/ld-cris/tls-err-41.d, * testsuite/ld-cris/tls-err-43.d, * testsuite/ld-cris/tls-err-45.d, * testsuite/ld-cris/tls-err-47.d, * testsuite/ld-cris/tls-err-49.d, * testsuite/ld-cris/tls-err-51.d, * testsuite/ld-cris/tls-err-67.d, * testsuite/ld-elf/dwarf2.err, * testsuite/ld-elf/dwarf3.err, * testsuite/ld-elf/orphan-5.l, * testsuite/ld-elf/orphan-6.l, * testsuite/ld-i386/vxworks1-static.d, * testsuite/ld-mips-elf/bal-jalx-pic-micromips-n32.d, * testsuite/ld-mips-elf/bal-jalx-pic-micromips-n64.d, * testsuite/ld-mips-elf/bal-jalx-pic-micromips.d, * testsuite/ld-mips-elf/bal-jalx-pic-n32.d, * testsuite/ld-mips-elf/bal-jalx-pic-n64.d, * testsuite/ld-mips-elf/bal-jalx-pic.d, * testsuite/ld-mips-elf/jal-global-overflow-1.d, * testsuite/ld-mips-elf/jal-local-overflow-1.d, * testsuite/ld-mips-elf/mode-change-error-1.d, * testsuite/ld-mips-elf/unaligned-branch-2.d, * testsuite/ld-mips-elf/unaligned-branch-ignore-2.d, * testsuite/ld-mips-elf/unaligned-branch-ignore-micromips.d, * testsuite/ld-mips-elf/unaligned-branch-ignore-mips16.d, * testsuite/ld-mips-elf/unaligned-branch-ignore-r6-1.d, * testsuite/ld-mips-elf/unaligned-branch-micromips.d, * testsuite/ld-mips-elf/unaligned-branch-mips16.d, * testsuite/ld-mips-elf/unaligned-branch-r6-1.d, * testsuite/ld-mips-elf/unaligned-branch-r6-2.d, * testsuite/ld-mips-elf/unaligned-branch.d, * testsuite/ld-mips-elf/unaligned-jalx-1.d, * testsuite/ld-mips-elf/unaligned-jalx-3.d, * testsuite/ld-mips-elf/unaligned-jalx-addend-1.d, * testsuite/ld-mips-elf/unaligned-jalx-addend-3.d, * testsuite/ld-mips-elf/unaligned-jalx-addend-micromips-1.d, * testsuite/ld-mips-elf/unaligned-jalx-addend-mips16-1.d, * testsuite/ld-mips-elf/unaligned-jalx-micromips-1.d, * testsuite/ld-mips-elf/unaligned-jalx-mips16-1.d, * testsuite/ld-mips-elf/unaligned-jump-micromips.d, * testsuite/ld-mips-elf/unaligned-jump-mips16.d, * testsuite/ld-mips-elf/unaligned-jump.d, * testsuite/ld-mips-elf/unaligned-ldpc-1.d, * testsuite/ld-mips-elf/unaligned-lwpc-1.d, * testsuite/ld-mips-elf/undefined.d, * testsuite/ld-mips-elf/vxworks1-static.d, * testsuite/ld-mmix/bpo-20.d, * testsuite/ld-mmix/bpo-20m.d, * testsuite/ld-mmix/bpo-7.d, * testsuite/ld-mmix/bpo-7m.d, * testsuite/ld-mmix/bpo-8.d, * testsuite/ld-mmix/bpo-8m.d, * testsuite/ld-mmix/greg-17.d, * testsuite/ld-mmix/greg-18.d, * testsuite/ld-mmix/greg-8.d, * testsuite/ld-mmix/greg-9.d, * testsuite/ld-plugin/plugin-14.d, * testsuite/ld-plugin/plugin-15.d, * testsuite/ld-plugin/plugin-16.d, * testsuite/ld-plugin/plugin-20.d, * testsuite/ld-plugin/plugin-21.d, * testsuite/ld-plugin/plugin-22.d, * testsuite/ld-plugin/plugin-23.d, * testsuite/ld-plugin/plugin-6.d, * testsuite/ld-plugin/plugin-7.d, * testsuite/ld-plugin/plugin-8.d, * testsuite/ld-powerpc/aix-weak-3-32.d, * testsuite/ld-powerpc/aix-weak-3-64.d, * testsuite/ld-powerpc/vxworks1-static.d, * testsuite/ld-sh/vxworks1-static.d, * testsuite/ld-sparc/vxworks1-static.d, * testsuite/ld-undefined/undefined.exp, * testsuite/ld-x86-64/pie1.d: Update for changed errors and warnings. * testsuite/ld-elf/warn1.d, * testsuite/ld-elf/warn2.d: Correct regex.
154 lines
4.0 KiB
Plaintext
154 lines
4.0 KiB
Plaintext
# This shell script emits a C file. -*- C -*-
|
|
# Copyright (C) 2003-2018 Free Software Foundation, Inc.
|
|
#
|
|
# 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.
|
|
#
|
|
|
|
# This file is sourced from elf32.em, and defines extra alpha
|
|
# specific routines.
|
|
#
|
|
fragment <<EOF
|
|
|
|
#include "elf/internal.h"
|
|
#include "elf/alpha.h"
|
|
#include "elf-bfd.h"
|
|
|
|
static bfd_boolean limit_32bit;
|
|
|
|
extern bfd_boolean elf64_alpha_use_secureplt;
|
|
|
|
|
|
/* Set the start address as in the Tru64 ld. */
|
|
#define ALPHA_TEXT_START_32BIT 0x12000000
|
|
|
|
static void
|
|
alpha_after_open (void)
|
|
{
|
|
if (bfd_get_flavour (link_info.output_bfd) == bfd_target_elf_flavour
|
|
&& elf_object_id (link_info.output_bfd) == ALPHA_ELF_DATA)
|
|
{
|
|
unsigned int num_plt;
|
|
lang_output_section_statement_type *os;
|
|
lang_output_section_statement_type *plt_os[2];
|
|
|
|
num_plt = 0;
|
|
for (os = &lang_output_section_statement.head->output_section_statement;
|
|
os != NULL;
|
|
os = os->next)
|
|
{
|
|
if (os->constraint == SPECIAL && strcmp (os->name, ".plt") == 0)
|
|
{
|
|
if (num_plt < 2)
|
|
plt_os[num_plt] = os;
|
|
++num_plt;
|
|
}
|
|
}
|
|
|
|
if (num_plt == 2)
|
|
{
|
|
plt_os[0]->constraint = elf64_alpha_use_secureplt ? 0 : -1;
|
|
plt_os[1]->constraint = elf64_alpha_use_secureplt ? -1 : 0;
|
|
}
|
|
}
|
|
|
|
gld${EMULATION_NAME}_after_open ();
|
|
}
|
|
|
|
static void
|
|
alpha_after_parse (void)
|
|
{
|
|
link_info.relax_pass = 2;
|
|
if (limit_32bit
|
|
&& !bfd_link_pic (&link_info)
|
|
&& !bfd_link_relocatable (&link_info))
|
|
lang_section_start (".interp",
|
|
exp_binop ('+',
|
|
exp_intop (ALPHA_TEXT_START_32BIT),
|
|
exp_nameop (SIZEOF_HEADERS, NULL)),
|
|
NULL);
|
|
|
|
gld${EMULATION_NAME}_after_parse ();
|
|
}
|
|
|
|
static void
|
|
alpha_before_allocation (void)
|
|
{
|
|
/* Call main function; we're just extending it. */
|
|
gld${EMULATION_NAME}_before_allocation ();
|
|
|
|
/* Add -relax if -O, not -r, and not explicitly disabled. */
|
|
if (link_info.optimize
|
|
&& !bfd_link_relocatable (&link_info)
|
|
&& ! RELAXATION_DISABLED_BY_USER)
|
|
ENABLE_RELAXATION;
|
|
}
|
|
|
|
static void
|
|
alpha_finish (void)
|
|
{
|
|
if (limit_32bit)
|
|
elf_elfheader (link_info.output_bfd)->e_flags |= EF_ALPHA_32BIT;
|
|
|
|
finish_default ();
|
|
}
|
|
EOF
|
|
|
|
# Define some shell vars to insert bits of code into the standard elf
|
|
# parse_args and list_options functions.
|
|
#
|
|
PARSE_AND_LIST_PROLOGUE='
|
|
#define OPTION_TASO 300
|
|
#define OPTION_SECUREPLT (OPTION_TASO + 1)
|
|
#define OPTION_NO_SECUREPLT (OPTION_SECUREPLT + 1)
|
|
'
|
|
|
|
PARSE_AND_LIST_LONGOPTS='
|
|
{ "taso", no_argument, NULL, OPTION_TASO },
|
|
{ "secureplt", no_argument, NULL, OPTION_SECUREPLT },
|
|
{ "no-secureplt", no_argument, NULL, OPTION_NO_SECUREPLT },
|
|
'
|
|
|
|
PARSE_AND_LIST_OPTIONS='
|
|
fprintf (file, _("\
|
|
--taso Load executable in the lower 31-bit addressable\n\
|
|
virtual address range\n"));
|
|
fprintf (file, _("\
|
|
--secureplt Force PLT in text segment\n"));
|
|
fprintf (file, _("\
|
|
--no-secureplt Force PLT in data segment\n"));
|
|
'
|
|
|
|
PARSE_AND_LIST_ARGS_CASES='
|
|
case OPTION_TASO:
|
|
limit_32bit = 1;
|
|
break;
|
|
case OPTION_SECUREPLT:
|
|
elf64_alpha_use_secureplt = TRUE;
|
|
break;
|
|
case OPTION_NO_SECUREPLT:
|
|
elf64_alpha_use_secureplt = FALSE;
|
|
break;
|
|
'
|
|
|
|
# Put these extra alpha routines in ld_${EMULATION_NAME}_emulation
|
|
#
|
|
LDEMUL_AFTER_OPEN=alpha_after_open
|
|
LDEMUL_AFTER_PARSE=alpha_after_parse
|
|
LDEMUL_BEFORE_ALLOCATION=alpha_before_allocation
|
|
LDEMUL_FINISH=alpha_finish
|