fbbc375958
2006-04-06 H.J. Lu <hongjiu.lu@intel.com> * elfxx-ia64.c (elfNN_ia64_relax_section): Skip unneeded passes with the skip_relax_pass_0 and skip_relax_pass_1 bits in the section structure. include/ 2006-04-06 H.J. Lu <hongjiu.lu@intel.com> * bfdlink.h (bfd_link_info): Replace need_relax_finalize with relax_pass. ld/ 2006-04-06 H.J. Lu <hongjiu.lu@intel.com> * emultempl/ia64elf.em: Set link_info.relax_pass to 2. Remove link_info.need_relax_finalize. * ldlang.c (relax_sections): New. (lang_process): Use. Call relax_sections link_info.relax_pass times. * ldmain.c (main): Set link_info.relax_pass to 1. Remove link_info.need_relax_finalize.
62 lines
1.7 KiB
Text
62 lines
1.7 KiB
Text
# This shell script emits a C file. -*- C -*-
|
|
# Copyright 2003 Free Software Foundation, Inc.
|
|
#
|
|
# This file is part of GLD, the Gnu Linker.
|
|
#
|
|
# 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 2 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 ia64-elf
|
|
# specific routines.
|
|
#
|
|
# Define some shell vars to insert bits of code into the standard elf
|
|
# parse_args and list_options functions.
|
|
#
|
|
cat >>e${EMULATION_NAME}.c <<EOF
|
|
|
|
/* None zero if generating binary for Intel Itanium processor. */
|
|
static int itanium = 0;
|
|
|
|
static void
|
|
gld${EMULATION_NAME}_after_parse (void)
|
|
{
|
|
link_info.relax_pass = 2;
|
|
bfd_elf${ELFSIZE}_ia64_after_parse (itanium);
|
|
}
|
|
|
|
EOF
|
|
|
|
PARSE_AND_LIST_PROLOGUE='
|
|
#define OPTION_ITANIUM 300
|
|
'
|
|
|
|
PARSE_AND_LIST_LONGOPTS='
|
|
{ "itanium", no_argument, NULL, OPTION_ITANIUM},
|
|
'
|
|
|
|
PARSE_AND_LIST_OPTIONS='
|
|
fprintf (file, _("\
|
|
--itanium Generate code for Intel Itanium processor\n"
|
|
));
|
|
'
|
|
|
|
PARSE_AND_LIST_ARGS_CASES='
|
|
case OPTION_ITANIUM:
|
|
itanium = 1;
|
|
break;
|
|
'
|
|
|
|
LDEMUL_AFTER_PARSE=gld${EMULATION_NAME}_after_parse
|
|
. ${srcdir}/emultempl/needrelax.em
|