OpenCores
URL https://opencores.org/ocsvn/openrisc/openrisc/trunk

Subversion Repositories openrisc

[/] [openrisc/] [trunk/] [gnu-old/] [binutils-2.18.50/] [ld/] [emultempl/] [alphaelf.em] - Diff between revs 156 and 816

Go to most recent revision | Only display areas with differences | Details | Blame | View Log

Rev 156 Rev 816
# This shell script emits a C file. -*- C -*-
# This shell script emits a C file. -*- C -*-
#   Copyright 2003, 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
#   Copyright 2003, 2004, 2005, 2007, 2008 Free Software Foundation, Inc.
#
#
# This file is part of the GNU Binutils.
# This file is part of the GNU Binutils.
#
#
# This program is free software; you can redistribute it and/or modify
# 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
# it under the terms of the GNU General Public License as published by
# the Free Software Foundation; either version 3 of the License, or
# the Free Software Foundation; either version 3 of the License, or
# (at your option) any later version.
# (at your option) any later version.
#
#
# This program is distributed in the hope that it will be useful,
# This program is distributed in the hope that it will be useful,
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# but WITHOUT ANY WARRANTY; without even the implied warranty of
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the
# GNU General Public License for more details.
# GNU General Public License for more details.
#
#
# You should have received a copy of the GNU General Public License
# You should have received a copy of the GNU General Public License
# along with this program; if not, write to the Free Software
# along with this program; if not, write to the Free Software
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
# Foundation, Inc., 51 Franklin Street - Fifth Floor, Boston,
# MA 02110-1301, USA.
# MA 02110-1301, USA.
#
#
# This file is sourced from elf32.em, and defines extra alpha
# This file is sourced from elf32.em, and defines extra alpha
# specific routines.
# specific routines.
#
#
fragment <
fragment <
#include "elf/internal.h"
#include "elf/internal.h"
#include "elf/alpha.h"
#include "elf/alpha.h"
#include "elf-bfd.h"
#include "elf-bfd.h"
static bfd_boolean limit_32bit;
static bfd_boolean limit_32bit;
static bfd_boolean disable_relaxation;
static bfd_boolean disable_relaxation;
extern bfd_boolean elf64_alpha_use_secureplt;
extern bfd_boolean elf64_alpha_use_secureplt;
/* Set the start address as in the Tru64 ld.  */
/* Set the start address as in the Tru64 ld.  */
#define ALPHA_TEXT_START_32BIT 0x12000000
#define ALPHA_TEXT_START_32BIT 0x12000000
static void
static void
alpha_after_open (void)
alpha_after_open (void)
{
{
  if (bfd_get_flavour (link_info.output_bfd) == bfd_target_elf_flavour
  if (bfd_get_flavour (link_info.output_bfd) == bfd_target_elf_flavour
      && elf_object_id (link_info.output_bfd) == ALPHA_ELF_TDATA)
      && elf_object_id (link_info.output_bfd) == ALPHA_ELF_TDATA)
    {
    {
      unsigned int num_plt;
      unsigned int num_plt;
      lang_output_section_statement_type *os;
      lang_output_section_statement_type *os;
      lang_output_section_statement_type *plt_os[2];
      lang_output_section_statement_type *plt_os[2];
      num_plt = 0;
      num_plt = 0;
      for (os = &lang_output_section_statement.head->output_section_statement;
      for (os = &lang_output_section_statement.head->output_section_statement;
           os != NULL;
           os != NULL;
           os = os->next)
           os = os->next)
        {
        {
          if (os->constraint == SPECIAL && strcmp (os->name, ".plt") == 0)
          if (os->constraint == SPECIAL && strcmp (os->name, ".plt") == 0)
            {
            {
              if (num_plt < 2)
              if (num_plt < 2)
                plt_os[num_plt] = os;
                plt_os[num_plt] = os;
              ++num_plt;
              ++num_plt;
            }
            }
        }
        }
      if (num_plt == 2)
      if (num_plt == 2)
        {
        {
          plt_os[0]->constraint = elf64_alpha_use_secureplt ? 0 : -1;
          plt_os[0]->constraint = elf64_alpha_use_secureplt ? 0 : -1;
          plt_os[1]->constraint = elf64_alpha_use_secureplt ? -1 : 0;
          plt_os[1]->constraint = elf64_alpha_use_secureplt ? -1 : 0;
        }
        }
    }
    }
  gld${EMULATION_NAME}_after_open ();
  gld${EMULATION_NAME}_after_open ();
}
}
static void
static void
alpha_after_parse (void)
alpha_after_parse (void)
{
{
  if (limit_32bit && !link_info.shared && !link_info.relocatable)
  if (limit_32bit && !link_info.shared && !link_info.relocatable)
    lang_section_start (".interp",
    lang_section_start (".interp",
                        exp_binop ('+',
                        exp_binop ('+',
                                   exp_intop (ALPHA_TEXT_START_32BIT),
                                   exp_intop (ALPHA_TEXT_START_32BIT),
                                   exp_nameop (SIZEOF_HEADERS, NULL)),
                                   exp_nameop (SIZEOF_HEADERS, NULL)),
                        NULL);
                        NULL);
}
}
static void
static void
alpha_before_allocation (void)
alpha_before_allocation (void)
{
{
  /* Call main function; we're just extending it.  */
  /* Call main function; we're just extending it.  */
  gld${EMULATION_NAME}_before_allocation ();
  gld${EMULATION_NAME}_before_allocation ();
  /* Add -relax if -O, not -r, and not explicitly disabled.  */
  /* Add -relax if -O, not -r, and not explicitly disabled.  */
  if (link_info.optimize && !link_info.relocatable && !disable_relaxation)
  if (link_info.optimize && !link_info.relocatable && !disable_relaxation)
    command_line.relax = TRUE;
    command_line.relax = TRUE;
}
}
static void
static void
alpha_finish (void)
alpha_finish (void)
{
{
  if (limit_32bit)
  if (limit_32bit)
    elf_elfheader (link_info.output_bfd)->e_flags |= EF_ALPHA_32BIT;
    elf_elfheader (link_info.output_bfd)->e_flags |= EF_ALPHA_32BIT;
  gld${EMULATION_NAME}_finish ();
  gld${EMULATION_NAME}_finish ();
}
}
EOF
EOF
# Define some shell vars to insert bits of code into the standard elf
# Define some shell vars to insert bits of code into the standard elf
# parse_args and list_options functions.
# parse_args and list_options functions.
#
#
PARSE_AND_LIST_PROLOGUE='
PARSE_AND_LIST_PROLOGUE='
#define OPTION_TASO             300
#define OPTION_TASO             300
#define OPTION_NO_RELAX         (OPTION_TASO + 1)
#define OPTION_NO_RELAX         (OPTION_TASO + 1)
#define OPTION_SECUREPLT        (OPTION_NO_RELAX + 1)
#define OPTION_SECUREPLT        (OPTION_NO_RELAX + 1)
#define OPTION_NO_SECUREPLT     (OPTION_SECUREPLT + 1)
#define OPTION_NO_SECUREPLT     (OPTION_SECUREPLT + 1)
'
'
PARSE_AND_LIST_LONGOPTS='
PARSE_AND_LIST_LONGOPTS='
  { "taso", no_argument, NULL, OPTION_TASO },
  { "taso", no_argument, NULL, OPTION_TASO },
  { "no-relax", no_argument, NULL, OPTION_NO_RELAX },
  { "no-relax", no_argument, NULL, OPTION_NO_RELAX },
  { "secureplt", no_argument, NULL, OPTION_SECUREPLT },
  { "secureplt", no_argument, NULL, OPTION_SECUREPLT },
  { "no-secureplt", no_argument, NULL, OPTION_NO_SECUREPLT },
  { "no-secureplt", no_argument, NULL, OPTION_NO_SECUREPLT },
'
'
PARSE_AND_LIST_OPTIONS='
PARSE_AND_LIST_OPTIONS='
  fprintf (file, _("\
  fprintf (file, _("\
  --taso                      Load executable in the lower 31-bit addressable\n\
  --taso                      Load executable in the lower 31-bit addressable\n\
                                virtual address range.\n\
                                virtual address range.\n\
  --no-relax                  Do not relax call and gp sequences.\n\
  --no-relax                  Do not relax call and gp sequences.\n\
  --secureplt                 Force PLT in text segment.\n\
  --secureplt                 Force PLT in text segment.\n\
  --no-secureplt              Force PLT in data segment.\n\
  --no-secureplt              Force PLT in data segment.\n\
"));
"));
'
'
PARSE_AND_LIST_ARGS_CASES='
PARSE_AND_LIST_ARGS_CASES='
    case OPTION_TASO:
    case OPTION_TASO:
      limit_32bit = 1;
      limit_32bit = 1;
      break;
      break;
    case OPTION_NO_RELAX:
    case OPTION_NO_RELAX:
      disable_relaxation = TRUE;
      disable_relaxation = TRUE;
      break;
      break;
    case OPTION_SECUREPLT:
    case OPTION_SECUREPLT:
      elf64_alpha_use_secureplt = TRUE;
      elf64_alpha_use_secureplt = TRUE;
      break;
      break;
    case OPTION_NO_SECUREPLT:
    case OPTION_NO_SECUREPLT:
      elf64_alpha_use_secureplt = FALSE;
      elf64_alpha_use_secureplt = FALSE;
      break;
      break;
'
'
# Put these extra alpha routines in ld_${EMULATION_NAME}_emulation
# Put these extra alpha routines in ld_${EMULATION_NAME}_emulation
#
#
LDEMUL_AFTER_OPEN=alpha_after_open
LDEMUL_AFTER_OPEN=alpha_after_open
LDEMUL_AFTER_PARSE=alpha_after_parse
LDEMUL_AFTER_PARSE=alpha_after_parse
LDEMUL_BEFORE_ALLOCATION=alpha_before_allocation
LDEMUL_BEFORE_ALLOCATION=alpha_before_allocation
LDEMUL_FINISH=alpha_finish
LDEMUL_FINISH=alpha_finish
 
 

powered by: WebSVN 2.1.0

© copyright 1999-2024 OpenCores.org, equivalent to Oliscience, all rights reserved. OpenCores®, registered trademark.