diff options
author | Michael Shalayeff <mickey@cvs.openbsd.org> | 2004-06-07 15:18:20 +0000 |
---|---|---|
committer | Michael Shalayeff <mickey@cvs.openbsd.org> | 2004-06-07 15:18:20 +0000 |
commit | aaf1a21b032d5a8a898390a75bb0008c4bc1b8fb (patch) | |
tree | f04e6b80debd9c207781211ea514268d438b9a4e /libexec/ld.so | |
parent | 04fb078cd155fa471954235ed9fe677d2ee6db62 (diff) |
fixup the dlsym() return to produce a callable address (plabel) and move one comment closer to the code it talks about earlier; drahn@ ok
Diffstat (limited to 'libexec/ld.so')
-rw-r--r-- | libexec/ld.so/dlfcn.c | 14 | ||||
-rw-r--r-- | libexec/ld.so/hppa/archdep.h | 3 |
2 files changed, 12 insertions, 5 deletions
diff --git a/libexec/ld.so/dlfcn.c b/libexec/ld.so/dlfcn.c index e798d128fd7..ede4a44aa5a 100644 --- a/libexec/ld.so/dlfcn.c +++ b/libexec/ld.so/dlfcn.c @@ -1,4 +1,4 @@ -/* $OpenBSD: dlfcn.c,v 1.37 2004/06/07 15:00:38 mickey Exp $ */ +/* $OpenBSD: dlfcn.c,v 1.38 2004/06/07 15:18:19 mickey Exp $ */ /* * Copyright (c) 1998 Per Fogelstrom, Opsycon AB @@ -59,11 +59,11 @@ dlopen(const char *libname, int flags) _dl_thread_kern_stop(); object = _dl_load_shlib(libname, _dl_objects, OBJTYPE_DLO, flags); - /* this add_object should not be here, XXX */ if (object == 0) { _dl_thread_kern_go(); return((void *)0); } + /* this add_object should not be here, XXX */ _dl_add_object(object); _dl_link_sub(object, _dl_objects); _dl_thread_kern_go(); @@ -142,9 +142,15 @@ dlsym(void *handle, const char *name) retval = (void *)_dl_find_symbol(name, object, &sym, NULL, SYM_SEARCH_SELF|SYM_NOWARNNOTFOUND|SYM_NOTPLT, 0, object); - if (sym != NULL) + if (sym != NULL) { retval += sym->st_value; - else +#ifdef __hppa__ + retval = (void *)_dl_md_plabel((Elf_Addr)retval, + object->dyn.pltgot); +#endif + DL_DEB(("dlsym: %s in %s: %p\n", + name, object->load_name, retval)); + } else _dl_errno = DL_NO_SYMBOL; return (retval); } diff --git a/libexec/ld.so/hppa/archdep.h b/libexec/ld.so/hppa/archdep.h index 655acccc27b..a5008bb9f74 100644 --- a/libexec/ld.so/hppa/archdep.h +++ b/libexec/ld.so/hppa/archdep.h @@ -1,4 +1,4 @@ -/* $OpenBSD: archdep.h,v 1.1 2004/05/25 21:48:00 mickey Exp $ */ +/* $OpenBSD: archdep.h,v 1.2 2004/06/07 15:18:19 mickey Exp $ */ /* * Copyright (c) 2004 Michael Shalayeff @@ -95,5 +95,6 @@ RELOC_RELA(Elf_RelA *r, const Elf_Sym *s, Elf_Addr *p, unsigned long v) void _hppa_dl_dtors(void); void hppa_call(void *, Elf_Addr *, void (*)(void)); +Elf_Addr _dl_md_plabel(Elf_Addr, Elf_Addr *); #endif /* _HPPA_ARCHDEP_H_ */ |