mirror of
https://sourceware.org/git/glibc.git
synced 2025-10-24 13:33:08 +03:00
I've moved the TILE-Gx and TILEPro ports to the main sysdeps hierarchy,
along with the linux-generic ports infrastructure. Beyond the README
update, the move was just
git mv ports/sysdeps/tile sysdeps/tile
git mv ports/sysdeps/unix/sysv/linux/tile \
sysdeps/unix/sysv/linux/tile
git mv ports/sysdeps/unix/sysv/linux/generic \
sysdeps/unix/sysv/linux/generic
I updated the relevant ChangeLogs along the lines of the ARM move
in commit c6bfe5c4d7
and tested the 64-bit tilegx build to confirm that
there were no changes in "objdump -dr" output in the shared objects.
85 lines
2.1 KiB
C
85 lines
2.1 KiB
C
/* Variable initialization. Tile version.
|
|
Copyright (C) 2001-2014 Free Software Foundation, Inc.
|
|
This file is part of the GNU C Library.
|
|
|
|
The GNU C Library is free software; you can redistribute it and/or
|
|
modify it under the terms of the GNU Lesser General Public
|
|
License as published by the Free Software Foundation; either
|
|
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,
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
|
|
Lesser General Public License for more details.
|
|
|
|
You should have received a copy of the GNU Lesser General Public
|
|
License along with the GNU C Library. If not, see
|
|
<http://www.gnu.org/licenses/>. */
|
|
|
|
#include <ldsodefs.h>
|
|
|
|
#ifdef SHARED
|
|
|
|
void
|
|
_dl_var_init (void *array[])
|
|
{
|
|
/* It has to match "variables" below. */
|
|
enum
|
|
{
|
|
DL_PAGESIZE = 0
|
|
};
|
|
|
|
GLRO(dl_pagesize) = *((size_t *) array[DL_PAGESIZE]);
|
|
}
|
|
|
|
#else
|
|
|
|
static void *variables[] =
|
|
{
|
|
&GLRO(dl_pagesize)
|
|
};
|
|
|
|
static void
|
|
_dl_unprotect_relro (struct link_map *l)
|
|
{
|
|
ElfW(Addr) start = ((l->l_addr + l->l_relro_addr)
|
|
& ~(GLRO(dl_pagesize) - 1));
|
|
ElfW(Addr) end = ((l->l_addr + l->l_relro_addr + l->l_relro_size)
|
|
& ~(GLRO(dl_pagesize) - 1));
|
|
|
|
if (start != end)
|
|
__mprotect ((void *) start, end - start, PROT_READ | PROT_WRITE);
|
|
}
|
|
|
|
void
|
|
_dl_static_init (struct link_map *l)
|
|
{
|
|
struct link_map *rtld_map = l;
|
|
struct r_scope_elem **scope;
|
|
const ElfW(Sym) *ref = NULL;
|
|
lookup_t loadbase;
|
|
void (*f) (void *[]);
|
|
size_t i;
|
|
|
|
loadbase = _dl_lookup_symbol_x ("_dl_var_init", l, &ref, l->l_local_scope,
|
|
NULL, 0, 1, NULL);
|
|
|
|
for (scope = l->l_local_scope; *scope != NULL; scope++)
|
|
for (i = 0; i < (*scope)->r_nlist; i++)
|
|
if ((*scope)->r_list[i] == loadbase)
|
|
{
|
|
rtld_map = (*scope)->r_list[i];
|
|
break;
|
|
}
|
|
|
|
if (ref != NULL)
|
|
{
|
|
f = (void (*) (void *[])) DL_SYMBOL_ADDRESS (loadbase, ref);
|
|
_dl_unprotect_relro (rtld_map);
|
|
f (variables);
|
|
_dl_protect_relro (rtld_map);
|
|
}
|
|
}
|
|
|
|
#endif
|