OpenCores
URL https://opencores.org/ocsvn/openrisc_2011-10-31/openrisc_2011-10-31/trunk

Subversion Repositories openrisc_2011-10-31

[/] [openrisc/] [tags/] [gnu-src/] [newlib-1.18.0/] [newlib-1.18.0-or32-1.0rc1/] [newlib/] [libc/] [sys/] [linux/] [dl/] [dl-support.c] - Diff between revs 207 and 345

Only display areas with differences | Details | Blame | View Log

Rev 207 Rev 345
/* Support for dynamic linking code in static libc.
/* Support for dynamic linking code in static libc.
   Copyright (C) 1996, 97, 98, 99, 2000, 2001 Free Software Foundation, Inc.
   Copyright (C) 1996, 97, 98, 99, 2000, 2001 Free Software Foundation, Inc.
   This file is part of the GNU C Library.
   This file is part of the GNU C Library.
 
 
   The GNU C Library is free software; you can redistribute it and/or
   The GNU C Library is free software; you can redistribute it and/or
   modify it under the terms of the GNU Lesser General Public
   modify it under the terms of the GNU Lesser General Public
   License as published by the Free Software Foundation; either
   License as published by the Free Software Foundation; either
   version 2.1 of the License, or (at your option) any later version.
   version 2.1 of the License, or (at your option) any later version.
 
 
   The GNU C Library is distributed in the hope that it will be useful,
   The GNU C Library 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 GNU
   MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the GNU
   Lesser General Public License for more details.
   Lesser General Public License for more details.
 
 
   You should have received a copy of the GNU Lesser General Public
   You should have received a copy of the GNU Lesser General Public
   License along with the GNU C Library; if not, write to the Free
   License along with the GNU C Library; if not, write to the Free
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
   Software Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA
   02111-1307 USA.  */
   02111-1307 USA.  */
 
 
/* This file defines some things that for the dynamic linker are defined in
/* This file defines some things that for the dynamic linker are defined in
   rtld.c and dl-sysdep.c in ways appropriate to bootstrap dynamic linking.  */
   rtld.c and dl-sysdep.c in ways appropriate to bootstrap dynamic linking.  */
 
 
#include <errno.h>
#include <errno.h>
#include <libintl.h>
#include <libintl.h>
#include <stdlib.h>
#include <stdlib.h>
#include <unistd.h>
#include <unistd.h>
#include <dirent.h>
#include <dirent.h>
#include <pthread.h>
#include <pthread.h>
#include <ldsodefs.h>
#include <ldsodefs.h>
#include <machine/dl-machine.h>
#include <machine/dl-machine.h>
#include <dl-librecon.h>
#include <dl-librecon.h>
#include <unsecvars.h>
#include <unsecvars.h>
#include <machine/hp-timing.h>
#include <machine/hp-timing.h>
 
 
char *__progname = "newlib";
char *__progname = "newlib";
char **_dl_argv = &__progname;  /* This is checked for some error messages.  */
char **_dl_argv = &__progname;  /* This is checked for some error messages.  */
 
 
/* Name of the architecture.  */
/* Name of the architecture.  */
const char *_dl_platform;
const char *_dl_platform;
size_t _dl_platformlen;
size_t _dl_platformlen;
 
 
int _dl_debug_mask;
int _dl_debug_mask;
int _dl_lazy;
int _dl_lazy;
/* XXX I know about at least one case where we depend on the old weak
/* XXX I know about at least one case where we depend on the old weak
   behavior (it has to do with librt).  Until we get DSO groups implemented
   behavior (it has to do with librt).  Until we get DSO groups implemented
   we have to make this the default.  Bummer. --drepper  */
   we have to make this the default.  Bummer. --drepper  */
#if 0
#if 0
int _dl_dynamic_weak;
int _dl_dynamic_weak;
#else
#else
int _dl_dynamic_weak = 1;
int _dl_dynamic_weak = 1;
#endif
#endif
 
 
/* If nonzero print warnings about problematic situations.  */
/* If nonzero print warnings about problematic situations.  */
int _dl_verbose;
int _dl_verbose;
 
 
/* Structure to store information about search paths.  */
/* Structure to store information about search paths.  */
struct r_search_path *_dl_search_paths;
struct r_search_path *_dl_search_paths;
 
 
/* We never do profiling.  */
/* We never do profiling.  */
const char *_dl_profile;
const char *_dl_profile;
 
 
/* Names of shared object for which the RUNPATHs and RPATHs should be
/* Names of shared object for which the RUNPATHs and RPATHs should be
   ignored.  */
   ignored.  */
const char *_dl_inhibit_rpath;
const char *_dl_inhibit_rpath;
 
 
/* The map for the object we will profile.  */
/* The map for the object we will profile.  */
struct link_map *_dl_profile_map;
struct link_map *_dl_profile_map;
 
 
/* This is the address of the last stack address ever used.  */
/* This is the address of the last stack address ever used.  */
void *__libc_stack_end;
void *__libc_stack_end;
 
 
/* Path where the binary is found.  */
/* Path where the binary is found.  */
const char *_dl_origin_path;
const char *_dl_origin_path;
 
 
/* Nonzero if runtime lookup should not update the .got/.plt.  */
/* Nonzero if runtime lookup should not update the .got/.plt.  */
int _dl_bind_not;
int _dl_bind_not;
 
 
/* Initially empty list of loaded objects.  */
/* Initially empty list of loaded objects.  */
struct link_map *_dl_loaded;
struct link_map *_dl_loaded;
/* Number of object in the _dl_loaded list.  */
/* Number of object in the _dl_loaded list.  */
unsigned int _dl_nloaded;
unsigned int _dl_nloaded;
 
 
/* Fake scope.  In dynamically linked binaries this is the scope of the
/* Fake scope.  In dynamically linked binaries this is the scope of the
   main application but here we don't have something like this.  So
   main application but here we don't have something like this.  So
   create a fake scope containing nothing.  */
   create a fake scope containing nothing.  */
struct r_scope_elem _dl_initial_searchlist;
struct r_scope_elem _dl_initial_searchlist;
/* Variable which can be used in lookup to process the global scope.  */
/* Variable which can be used in lookup to process the global scope.  */
struct r_scope_elem *_dl_global_scope[2] = { &_dl_initial_searchlist, NULL };
struct r_scope_elem *_dl_global_scope[2] = { &_dl_initial_searchlist, NULL };
/* This is a global pointer to this structure which is public.  It is
/* This is a global pointer to this structure which is public.  It is
   used by dlopen/dlclose to add and remove objects from what is regarded
   used by dlopen/dlclose to add and remove objects from what is regarded
   to be the global scope.  */
   to be the global scope.  */
struct r_scope_elem *_dl_main_searchlist = &_dl_initial_searchlist;
struct r_scope_elem *_dl_main_searchlist = &_dl_initial_searchlist;
 
 
/* Nonzero during startup.  */
/* Nonzero during startup.  */
int _dl_starting_up = 1;
int _dl_starting_up = 1;
 
 
/* We expect less than a second for relocation.  */
/* We expect less than a second for relocation.  */
#ifdef HP_SMALL_TIMING_AVAIL
#ifdef HP_SMALL_TIMING_AVAIL
# undef HP_TIMING_AVAIL
# undef HP_TIMING_AVAIL
# define HP_TIMING_AVAIL HP_SMALL_TIMING_AVAIL
# define HP_TIMING_AVAIL HP_SMALL_TIMING_AVAIL
#endif
#endif
 
 
/* Initial value of the CPU clock.  */
/* Initial value of the CPU clock.  */
#ifndef HP_TIMING_NONAVAIL
#ifndef HP_TIMING_NONAVAIL
hp_timing_t _dl_cpuclock_offset;
hp_timing_t _dl_cpuclock_offset;
#endif
#endif
 
 
/* During the program run we must not modify the global data of
/* During the program run we must not modify the global data of
   loaded shared object simultanously in two threads.  Therefore we
   loaded shared object simultanously in two threads.  Therefore we
   protect `_dl_open' and `_dl_close' in dl-close.c.
   protect `_dl_open' and `_dl_close' in dl-close.c.
 
 
   This must be a recursive lock since the initializer function of
   This must be a recursive lock since the initializer function of
   the loaded object might as well require a call to this function.
   the loaded object might as well require a call to this function.
   At this time it is not anymore a problem to modify the tables.  */
   At this time it is not anymore a problem to modify the tables.  */
__LOCK_INIT_RECURSIVE(, _dl_load_lock)
__LOCK_INIT_RECURSIVE(, _dl_load_lock)
 
 
 
 
#ifdef HAVE_AUX_VECTOR
#ifdef HAVE_AUX_VECTOR
extern int _dl_clktck;
extern int _dl_clktck;
 
 
void
void
internal_function
internal_function
_dl_aux_init (ElfW(auxv_t) *av)
_dl_aux_init (ElfW(auxv_t) *av)
{
{
  for (; av->a_type != AT_NULL; ++av)
  for (; av->a_type != AT_NULL; ++av)
    switch (av->a_type)
    switch (av->a_type)
      {
      {
      case AT_PAGESZ:
      case AT_PAGESZ:
        _dl_pagesize = av->a_un.a_val;
        _dl_pagesize = av->a_un.a_val;
        break;
        break;
      case AT_CLKTCK:
      case AT_CLKTCK:
        _dl_clktck = av->a_un.a_val;
        _dl_clktck = av->a_un.a_val;
        break;
        break;
      }
      }
}
}
#endif
#endif
 
 
void non_dynamic_init (void) __attribute__ ((unused));
void non_dynamic_init (void) __attribute__ ((unused));
 
 
void
void
non_dynamic_init (void)
non_dynamic_init (void)
{
{
  if (HP_TIMING_AVAIL)
  if (HP_TIMING_AVAIL)
    HP_TIMING_NOW (_dl_cpuclock_offset);
    HP_TIMING_NOW (_dl_cpuclock_offset);
 
 
  if (!_dl_pagesize)
  if (!_dl_pagesize)
    _dl_pagesize = __getpagesize ();
    _dl_pagesize = __getpagesize ();
 
 
  _dl_verbose = *(getenv ("LD_WARN") ?: "") == '\0' ? 0 : 1;
  _dl_verbose = *(getenv ("LD_WARN") ?: "") == '\0' ? 0 : 1;
 
 
  /* Initialize the data structures for the search paths for shared
  /* Initialize the data structures for the search paths for shared
     objects.  */
     objects.  */
  _dl_init_paths (getenv ("LD_LIBRARY_PATH"));
  _dl_init_paths (getenv ("LD_LIBRARY_PATH"));
 
 
  _dl_lazy = *(getenv ("LD_BIND_NOW") ?: "") == '\0';
  _dl_lazy = *(getenv ("LD_BIND_NOW") ?: "") == '\0';
 
 
  _dl_bind_not = *(getenv ("LD_BIND_NOT") ?: "") != '\0';
  _dl_bind_not = *(getenv ("LD_BIND_NOT") ?: "") != '\0';
 
 
  _dl_dynamic_weak = *(getenv ("LD_DYNAMIC_WEAK") ?: "") == '\0';
  _dl_dynamic_weak = *(getenv ("LD_DYNAMIC_WEAK") ?: "") == '\0';
 
 
#ifdef DL_PLATFORM_INIT
#ifdef DL_PLATFORM_INIT
  DL_PLATFORM_INIT;
  DL_PLATFORM_INIT;
#endif
#endif
 
 
  /* Now determine the length of the platform string.  */
  /* Now determine the length of the platform string.  */
  if (_dl_platform != NULL)
  if (_dl_platform != NULL)
    _dl_platformlen = strlen (_dl_platform);
    _dl_platformlen = strlen (_dl_platform);
}
}
text_set_element (__libc_subinit, non_dynamic_init);
text_set_element (__libc_subinit, non_dynamic_init);
 
 
const struct r_strlenpair *
const struct r_strlenpair *
internal_function
internal_function
_dl_important_hwcaps (const char *platform, size_t platform_len, size_t *sz,
_dl_important_hwcaps (const char *platform, size_t platform_len, size_t *sz,
                      size_t *max_capstrlen)
                      size_t *max_capstrlen)
{
{
  static struct r_strlenpair result;
  static struct r_strlenpair result;
  static char buf[1];
  static char buf[1];
 
 
  result.str = buf;     /* Does not really matter.  */
  result.str = buf;     /* Does not really matter.  */
  result.len = 0;
  result.len = 0;
 
 
  *sz = 1;
  *sz = 1;
  return &result;
  return &result;
}
}
 
 

powered by: WebSVN 2.1.0

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