From: Tom Tromey Date: Tue, 6 Mar 2012 19:51:10 +0000 (+0000) Subject: * proc-service.c (ps_pglobal_lookup): Set the current program X-Git-Url: https://git.libre-soc.org/?a=commitdiff_plain;h=c988ad8730c12b2b3b7c936e522152fe1fe188ad;p=binutils-gdb.git * proc-service.c (ps_pglobal_lookup): Set the current program space. --- diff --git a/gdb/ChangeLog b/gdb/ChangeLog index 6fe3ae9ad2a..f28fbfd6387 100644 --- a/gdb/ChangeLog +++ b/gdb/ChangeLog @@ -1,3 +1,8 @@ +2012-03-06 Tom Tromey + + * proc-service.c (ps_pglobal_lookup): Set the current program + space. + 2012-03-06 Pedro Alves * gregset.h [HAVE_SYS_PROCFS_H]: Include . diff --git a/gdb/proc-service.c b/gdb/proc-service.c index e3174144488..a1f90a88eb3 100644 --- a/gdb/proc-service.c +++ b/gdb/proc-service.c @@ -201,14 +201,24 @@ ps_pglobal_lookup (gdb_ps_prochandle_t ph, const char *obj, const char *name, psaddr_t *sym_addr) { struct minimal_symbol *ms; + struct cleanup *old_chain = save_current_program_space (); + struct inferior *inf = find_inferior_pid (ptid_get_pid (ph->ptid)); + ps_err_e result; + + set_current_program_space (inf->pspace); /* FIXME: kettenis/2000-09-03: What should we do with OBJ? */ ms = lookup_minimal_symbol (name, NULL, NULL); if (ms == NULL) - return PS_NOSYM; + result = PS_NOSYM; + else + { + *sym_addr = core_addr_to_ps_addr (SYMBOL_VALUE_ADDRESS (ms)); + result = PS_OK; + } - *sym_addr = core_addr_to_ps_addr (SYMBOL_VALUE_ADDRESS (ms)); - return PS_OK; + do_cleanups (old_chain); + return result; } /* Read SIZE bytes from the target process PH at address ADDR and copy