mirror of
git://sourceware.org/git/glibc.git
synced 2025-01-18 12:16:13 +08:00
elf: Introduce _dl_relocate_object_no_relro
And make _dl_protect_relro apply RELRO conditionally. Reviewed-by: DJ Delorie <dj@redhat.com>
This commit is contained in:
parent
a796422045
commit
f2326c2ec0
@ -202,12 +202,9 @@ resolve_map (lookup_t l, struct r_scope_elem *scope[], const ElfW(Sym) **ref,
|
||||
#include "dynamic-link.h"
|
||||
|
||||
void
|
||||
_dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
|
||||
int reloc_mode, int consider_profiling)
|
||||
_dl_relocate_object_no_relro (struct link_map *l, struct r_scope_elem *scope[],
|
||||
int reloc_mode, int consider_profiling)
|
||||
{
|
||||
if (l->l_relocated)
|
||||
return;
|
||||
|
||||
struct textrels
|
||||
{
|
||||
caddr_t start;
|
||||
@ -338,17 +335,24 @@ _dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
|
||||
|
||||
textrels = textrels->next;
|
||||
}
|
||||
|
||||
/* In case we can protect the data now that the relocations are
|
||||
done, do it. */
|
||||
if (l->l_relro_size != 0)
|
||||
_dl_protect_relro (l);
|
||||
}
|
||||
|
||||
void
|
||||
_dl_relocate_object (struct link_map *l, struct r_scope_elem *scope[],
|
||||
int reloc_mode, int consider_profiling)
|
||||
{
|
||||
if (l->l_relocated)
|
||||
return;
|
||||
_dl_relocate_object_no_relro (l, scope, reloc_mode, consider_profiling);
|
||||
_dl_protect_relro (l);
|
||||
}
|
||||
|
||||
void
|
||||
_dl_protect_relro (struct link_map *l)
|
||||
{
|
||||
if (l->l_relro_size == 0)
|
||||
return;
|
||||
|
||||
ElfW(Addr) start = ALIGN_DOWN((l->l_addr
|
||||
+ l->l_relro_addr),
|
||||
GLRO(dl_pagesize));
|
||||
|
@ -1014,6 +1014,13 @@ extern void _dl_relocate_object (struct link_map *map,
|
||||
int reloc_mode, int consider_profiling)
|
||||
attribute_hidden;
|
||||
|
||||
/* Perform relocation, but do not apply RELRO. Does not check
|
||||
L->relocated. Otherwise the same as _dl_relocate_object. */
|
||||
void _dl_relocate_object_no_relro (struct link_map *map,
|
||||
struct r_scope_elem *scope[],
|
||||
int reloc_mode, int consider_profiling)
|
||||
attribute_hidden;
|
||||
|
||||
/* Protect PT_GNU_RELRO area. */
|
||||
extern void _dl_protect_relro (struct link_map *map) attribute_hidden;
|
||||
|
||||
|
Loading…
Reference in New Issue
Block a user