From f8c5953ecdb948282cc8e573b729c25db60a95a8 Mon Sep 17 00:00:00 2001 From: Max Filippov Date: Wed, 21 Feb 2024 08:27:37 -0800 Subject: [PATCH 2/2] WIP Signed-off-by: Max Filippov --- ldso/dlstart.c | 7 +++++++ ldso/dynlink.c | 6 ++++-- src/internal/dynlink.h | 5 +++-- 3 files changed, 14 insertions(+), 4 deletions(-) diff --git a/ldso/dlstart.c b/ldso/dlstart.c index 259f5e18..beca953f 100644 --- a/ldso/dlstart.c +++ b/ldso/dlstart.c @@ -90,12 +90,19 @@ hidden void _dlstart_c(size_t *sp, size_t *dynv) - segs[rel_addr[1]].p_vaddr + syms[R_SYM(rel[1])].st_value; rel_addr[1] = dyn[DT_PLTGOT]; + } else if (R_TYPE(rel[1]) == REL_RELATIVE) { + size_t val = *rel_addr; + for (j=0; val-segs[j].p_vaddr >= segs[j].p_memsz; j++); + *rel_addr += segs[j].addr - segs[j].p_vaddr; } else { size_t val = syms[R_SYM(rel[1])].st_value; for (j=0; val-segs[j].p_vaddr >= segs[j].p_memsz; j++); *rel_addr = rel[2] + segs[j].addr - segs[j].p_vaddr + val; } } +#ifdef __xtensa__ + ((unsigned long *)dyn[DT_PLTGOT])[3] = segs[0].addr - segs[0].p_vaddr; +#endif #else /* If the dynamic linker is invoked as a command, its load * address is not available in the aux vector. Instead, compute diff --git a/ldso/dynlink.c b/ldso/dynlink.c index ceca3c98..25563af3 100644 --- a/ldso/dynlink.c +++ b/ldso/dynlink.c @@ -1420,6 +1420,7 @@ static void reloc_all(struct dso *p) if (!DL_FDPIC) do_relr_relocs(p, laddr(p, dyn[DT_RELR]), dyn[DT_RELRSZ]); +#if 0 if (head != &ldso && p->relro_start != p->relro_end) { long ret = __syscall(SYS_mprotect, laddr(p, p->relro_start), p->relro_end-p->relro_start, PROT_READ); @@ -1429,6 +1430,7 @@ static void reloc_all(struct dso *p) if (runtime) longjmp(*rtld_fail, 1); } } +#endif p->relocated = 1; } @@ -1485,7 +1487,7 @@ void __libc_exit_fini() if (dyn[0] & (1<