Author: markj
Date: Sat Jul 21 22:15:48 2018
New Revision: 336592
URL: https://svnweb.freebsd.org/changeset/base/336592

Log:
  Take the mapping's segment offset into account when resolving symbols.
  
  Reported by:  Jenkins, via asomers
  MFC after:    2 weeks

Modified:
  head/lib/libproc/proc_sym.c

Modified: head/lib/libproc/proc_sym.c
==============================================================================
--- head/lib/libproc/proc_sym.c Sat Jul 21 22:10:28 2018        (r336591)
+++ head/lib/libproc/proc_sym.c Sat Jul 21 22:15:48 2018        (r336592)
@@ -520,7 +520,8 @@ proc_addr2sym(struct proc_handle *p, uintptr_t addr, c
        }
 
        file = mapping->file;
-       off = file->ehdr.e_type == ET_DYN ? mapping->map.pr_vaddr : 0;
+       off = file->ehdr.e_type == ET_DYN ?
+           mapping->map.pr_vaddr - mapping->map.pr_offset : 0;
        if (addr < off)
                return (ENOENT);
        addr -= off;
@@ -623,7 +624,8 @@ proc_name2sym(struct proc_handle *p, const char *objec
        }
 
        file = mapping->file;
-       off = file->ehdr.e_type == ET_DYN ? mapping->map.pr_vaddr : 0;
+       off = file->ehdr.e_type == ET_DYN ?
+           mapping->map.pr_vaddr - mapping->map.pr_offset : 0;
 
        error = lookup_symbol_by_name(file->elf, &file->dynsymtab, symbol,
            symcopy, si);
_______________________________________________
svn-src-all@freebsd.org mailing list
https://lists.freebsd.org/mailman/listinfo/svn-src-all
To unsubscribe, send any mail to "svn-src-all-unsubscr...@freebsd.org"

Reply via email to