2007-07-03 00:01:09 +02:00
|
|
|
/* Definitions for targets which report shared library events.
|
|
|
|
|
2019-01-01 07:01:51 +01:00
|
|
|
Copyright (C) 2007-2019 Free Software Foundation, Inc.
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
This file is part of GDB.
|
|
|
|
|
|
|
|
This program is free software; you can redistribute it and/or modify
|
|
|
|
it under the terms of the GNU General Public License as published by
|
2007-08-23 20:08:50 +02:00
|
|
|
the Free Software Foundation; either version 3 of the License, or
|
2007-07-03 00:01:09 +02:00
|
|
|
(at your option) any later version.
|
|
|
|
|
|
|
|
This program is distributed in the hope that it will be useful,
|
|
|
|
but WITHOUT ANY WARRANTY; without even the implied warranty of
|
|
|
|
MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the
|
|
|
|
GNU General Public License for more details.
|
|
|
|
|
|
|
|
You should have received a copy of the GNU General Public License
|
2007-08-23 20:08:50 +02:00
|
|
|
along with this program. If not, see <http://www.gnu.org/licenses/>. */
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
#include "defs.h"
|
|
|
|
#include "objfiles.h"
|
|
|
|
#include "solist.h"
|
|
|
|
#include "symtab.h"
|
|
|
|
#include "symfile.h"
|
|
|
|
#include "target.h"
|
|
|
|
#include "vec.h"
|
2007-10-24 23:16:30 +02:00
|
|
|
#include "solib-target.h"
|
2017-05-02 19:30:08 +02:00
|
|
|
#include <vector>
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
/* Private data for each loaded library. */
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
struct lm_info_target : public lm_info_base
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
|
|
|
/* The library's name. The name is normally kept in the struct
|
|
|
|
so_list; it is only here during XML parsing. */
|
2017-04-28 23:16:16 +02:00
|
|
|
std::string name;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2008-03-14 23:30:07 +01:00
|
|
|
/* The target can either specify segment bases or section bases, not
|
|
|
|
both. */
|
|
|
|
|
2007-07-03 00:01:09 +02:00
|
|
|
/* The base addresses for each independently relocatable segment of
|
|
|
|
this shared library. */
|
2017-05-02 19:30:08 +02:00
|
|
|
std::vector<CORE_ADDR> segment_bases;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2008-03-14 23:30:07 +01:00
|
|
|
/* The base addresses for each independently allocatable,
|
|
|
|
relocatable section of this shared library. */
|
2017-05-02 19:30:08 +02:00
|
|
|
std::vector<CORE_ADDR> section_bases;
|
2008-03-14 23:30:07 +01:00
|
|
|
|
2007-07-03 00:01:09 +02:00
|
|
|
/* The cached offsets for each section of this shared library,
|
2008-03-14 23:30:07 +01:00
|
|
|
determined from SEGMENT_BASES, or SECTION_BASES. */
|
2017-04-28 23:16:16 +02:00
|
|
|
section_offsets *offsets = NULL;
|
2007-07-03 00:01:09 +02:00
|
|
|
};
|
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
typedef std::vector<std::unique_ptr<lm_info_target>> lm_info_vector;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
#if !defined(HAVE_LIBEXPAT)
|
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
static lm_info_vector
|
2007-07-03 00:01:09 +02:00
|
|
|
solib_target_parse_libraries (const char *library)
|
|
|
|
{
|
|
|
|
static int have_warned;
|
|
|
|
|
|
|
|
if (!have_warned)
|
|
|
|
{
|
|
|
|
have_warned = 1;
|
|
|
|
warning (_("Can not parse XML library list; XML support was disabled "
|
|
|
|
"at compile time"));
|
|
|
|
}
|
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
return lm_info_vector ();
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
#else /* HAVE_LIBEXPAT */
|
|
|
|
|
|
|
|
#include "xml-support.h"
|
|
|
|
|
|
|
|
/* Handle the start of a <segment> element. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
library_list_start_segment (struct gdb_xml_parser *parser,
|
|
|
|
const struct gdb_xml_element *element,
|
2018-01-07 15:29:52 +01:00
|
|
|
void *user_data,
|
|
|
|
std::vector<gdb_xml_value> &attributes)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector *list = (lm_info_vector *) user_data;
|
|
|
|
lm_info_target *last = list->back ().get ();
|
2015-09-25 20:08:07 +02:00
|
|
|
ULONGEST *address_p
|
2018-01-07 15:29:52 +01:00
|
|
|
= (ULONGEST *) xml_find_attribute (attributes, "address")->value.get ();
|
2007-07-08 21:31:11 +02:00
|
|
|
CORE_ADDR address = (CORE_ADDR) *address_p;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
if (!last->section_bases.empty ())
|
2008-03-14 23:30:07 +01:00
|
|
|
gdb_xml_error (parser,
|
|
|
|
_("Library list with both segments and sections"));
|
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
last->segment_bases.push_back (address);
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
2008-03-14 23:30:07 +01:00
|
|
|
static void
|
|
|
|
library_list_start_section (struct gdb_xml_parser *parser,
|
|
|
|
const struct gdb_xml_element *element,
|
2018-01-07 15:29:52 +01:00
|
|
|
void *user_data,
|
|
|
|
std::vector<gdb_xml_value> &attributes)
|
2008-03-14 23:30:07 +01:00
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector *list = (lm_info_vector *) user_data;
|
|
|
|
lm_info_target *last = list->back ().get ();
|
2015-09-25 20:08:07 +02:00
|
|
|
ULONGEST *address_p
|
2018-01-07 15:29:52 +01:00
|
|
|
= (ULONGEST *) xml_find_attribute (attributes, "address")->value.get ();
|
2008-03-14 23:30:07 +01:00
|
|
|
CORE_ADDR address = (CORE_ADDR) *address_p;
|
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
if (!last->segment_bases.empty ())
|
2008-03-14 23:30:07 +01:00
|
|
|
gdb_xml_error (parser,
|
|
|
|
_("Library list with both segments and sections"));
|
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
last->section_bases.push_back (address);
|
2008-03-14 23:30:07 +01:00
|
|
|
}
|
|
|
|
|
2007-07-03 00:01:09 +02:00
|
|
|
/* Handle the start of a <library> element. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
library_list_start_library (struct gdb_xml_parser *parser,
|
|
|
|
const struct gdb_xml_element *element,
|
2018-01-07 15:29:52 +01:00
|
|
|
void *user_data,
|
|
|
|
std::vector<gdb_xml_value> &attributes)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector *list = (lm_info_vector *) user_data;
|
2017-04-28 23:16:16 +02:00
|
|
|
lm_info_target *item = new lm_info_target;
|
2019-01-10 18:52:39 +01:00
|
|
|
item->name
|
2018-01-07 15:29:52 +01:00
|
|
|
= (const char *) xml_find_attribute (attributes, "name")->value.get ();
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
list->emplace_back (item);
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
2008-03-14 23:30:07 +01:00
|
|
|
static void
|
|
|
|
library_list_end_library (struct gdb_xml_parser *parser,
|
|
|
|
const struct gdb_xml_element *element,
|
|
|
|
void *user_data, const char *body_text)
|
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector *list = (lm_info_vector *) user_data;
|
|
|
|
lm_info_target *lm_info = list->back ().get ();
|
2010-05-17 01:49:58 +02:00
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
if (lm_info->segment_bases.empty () && lm_info->section_bases.empty ())
|
|
|
|
gdb_xml_error (parser, _("No segment or section bases defined"));
|
2008-03-14 23:30:07 +01:00
|
|
|
}
|
|
|
|
|
|
|
|
|
2007-07-03 00:01:09 +02:00
|
|
|
/* Handle the start of a <library-list> element. */
|
|
|
|
|
|
|
|
static void
|
|
|
|
library_list_start_list (struct gdb_xml_parser *parser,
|
|
|
|
const struct gdb_xml_element *element,
|
2018-01-07 15:29:52 +01:00
|
|
|
void *user_data,
|
|
|
|
std::vector<gdb_xml_value> &attributes)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2015-06-10 18:29:05 +02:00
|
|
|
struct gdb_xml_value *version = xml_find_attribute (attributes, "version");
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2015-06-10 18:29:05 +02:00
|
|
|
/* #FIXED attribute may be omitted, Expat returns NULL in such case. */
|
2015-06-10 19:37:19 +02:00
|
|
|
if (version != NULL)
|
2015-06-10 18:29:05 +02:00
|
|
|
{
|
2018-01-07 15:29:52 +01:00
|
|
|
const char *string = (const char *) version->value.get ();
|
2015-06-10 18:29:05 +02:00
|
|
|
|
|
|
|
if (strcmp (string, "1.0") != 0)
|
|
|
|
gdb_xml_error (parser,
|
|
|
|
_("Library list has unsupported version \"%s\""),
|
2017-03-27 13:28:03 +02:00
|
|
|
string);
|
2015-06-10 18:29:05 +02:00
|
|
|
}
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
/* The allowed elements and attributes for an XML library list.
|
|
|
|
The root element is a <library-list>. */
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_attribute segment_attributes[] = {
|
2007-07-03 00:01:09 +02:00
|
|
|
{ "address", GDB_XML_AF_NONE, gdb_xml_parse_attr_ulongest, NULL },
|
|
|
|
{ NULL, GDB_XML_AF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_attribute section_attributes[] = {
|
2008-03-14 23:30:07 +01:00
|
|
|
{ "address", GDB_XML_AF_NONE, gdb_xml_parse_attr_ulongest, NULL },
|
|
|
|
{ NULL, GDB_XML_AF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_element library_children[] = {
|
2008-03-14 23:30:07 +01:00
|
|
|
{ "segment", segment_attributes, NULL,
|
|
|
|
GDB_XML_EF_REPEATABLE | GDB_XML_EF_OPTIONAL,
|
2007-07-03 00:01:09 +02:00
|
|
|
library_list_start_segment, NULL },
|
2008-03-14 23:30:07 +01:00
|
|
|
{ "section", section_attributes, NULL,
|
|
|
|
GDB_XML_EF_REPEATABLE | GDB_XML_EF_OPTIONAL,
|
|
|
|
library_list_start_section, NULL },
|
2007-07-03 00:01:09 +02:00
|
|
|
{ NULL, NULL, NULL, GDB_XML_EF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_attribute library_attributes[] = {
|
2007-07-03 00:01:09 +02:00
|
|
|
{ "name", GDB_XML_AF_NONE, NULL, NULL },
|
|
|
|
{ NULL, GDB_XML_AF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_element library_list_children[] = {
|
2007-07-03 00:01:09 +02:00
|
|
|
{ "library", library_attributes, library_children,
|
|
|
|
GDB_XML_EF_REPEATABLE | GDB_XML_EF_OPTIONAL,
|
2008-03-14 23:30:07 +01:00
|
|
|
library_list_start_library, library_list_end_library },
|
2007-07-03 00:01:09 +02:00
|
|
|
{ NULL, NULL, NULL, GDB_XML_EF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_attribute library_list_attributes[] = {
|
2015-06-10 18:29:05 +02:00
|
|
|
{ "version", GDB_XML_AF_OPTIONAL, NULL, NULL },
|
2007-07-03 00:01:09 +02:00
|
|
|
{ NULL, GDB_XML_AF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2011-08-05 18:38:40 +02:00
|
|
|
static const struct gdb_xml_element library_list_elements[] = {
|
2007-07-03 00:01:09 +02:00
|
|
|
{ "library-list", library_list_attributes, library_list_children,
|
|
|
|
GDB_XML_EF_NONE, library_list_start_list, NULL },
|
|
|
|
{ NULL, NULL, NULL, GDB_XML_EF_NONE, NULL, NULL }
|
|
|
|
};
|
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
static lm_info_vector
|
2007-07-03 00:01:09 +02:00
|
|
|
solib_target_parse_libraries (const char *library)
|
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector result;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2011-01-25 10:49:59 +01:00
|
|
|
if (gdb_xml_parse_quick (_("target library list"), "library-list.dtd",
|
|
|
|
library_list_elements, library, &result) == 0)
|
|
|
|
{
|
2019-01-17 05:46:00 +01:00
|
|
|
/* Parsed successfully. */
|
2011-01-25 10:49:59 +01:00
|
|
|
return result;
|
|
|
|
}
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
result.clear ();
|
|
|
|
return result;
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
#endif
|
|
|
|
|
|
|
|
static struct so_list *
|
|
|
|
solib_target_current_sos (void)
|
|
|
|
{
|
|
|
|
struct so_list *new_solib, *start = NULL, *last = NULL;
|
|
|
|
|
|
|
|
/* Fetch the list of shared libraries. */
|
Make target_read_alloc & al return vectors
This patch started by changing target_read_alloc_1 to return a
byte_vector, to avoid manual memory management (in target_read_alloc_1
and in the callers). To communicate failures to the callers, it
actually returns a gdb::optional<gdb::byte_vector>.
Adjusting target_read_stralloc was a bit more tricky, since it wants to
return a buffer of char, and not gdb_byte. Since you can't just cast a
gdb::byte_vector into a gdb::def_vector<char>, I made
target_read_alloc_1 templated, so both versions (that return vectors of
gdb_byte and char) are generated. Since target_read_stralloc now
returns a gdb::char_vector instead of a gdb::unique_xmalloc_ptr<char>, a
few callers need to be adjusted.
gdb/ChangeLog:
* common/byte-vector.h (char_vector): New type.
* target.h (target_read_alloc): Return
gdb::optional<byte_vector>.
(target_read_stralloc): Return gdb::optional<char_vector>.
(target_get_osdata): Return gdb::optional<char_vector>.
* target.c (target_read_alloc_1): Templatize. Replacement
manual memory management with vector.
(target_read_alloc): Change return type, adjust.
(target_read_stralloc): Change return type, adjust.
(target_get_osdata): Change return type, adjust.
* auxv.c (struct auxv_info) <length>: Remove.
<data>: Change type to gdb::optional<byte_vector>.
(auxv_inferior_data_cleanup): Free auxv_info with delete.
(get_auxv_inferior_data): Allocate auxv_info with new, adjust.
(target_auxv_search): Adjust.
(fprint_target_auxv): Adjust.
* avr-tdep.c (avr_io_reg_read_command): Adjust.
* linux-tdep.c (linux_spu_make_corefile_notes): Adjust.
(linux_make_corefile_notes): Adjust.
* osdata.c (get_osdata): Adjust.
* remote.c (remote_get_threads_with_qxfer): Adjust.
(remote_memory_map): Adjust.
(remote_traceframe_info): Adjust.
(btrace_read_config): Adjust.
(remote_read_btrace): Adjust.
(remote_pid_to_exec_file): Adjust.
* solib-aix.c (solib_aix_get_library_list): Adjust.
* solib-dsbt.c (decode_loadmap): Don't free buf.
(dsbt_get_initial_loadmaps): Adjust.
* solib-svr4.c (svr4_current_sos_via_xfer_libraries): Adjust.
* solib-target.c (solib_target_current_sos): Adjust.
* tracepoint.c (sdata_make_value): Adjust.
* xml-support.c (xinclude_start_include): Adjust.
(xml_fetch_content_from_file): Adjust.
* xml-support.h (xml_fetch_another): Change return type.
(xml_fetch_content_from_file): Change return type.
* xml-syscall.c (xml_init_syscalls_info): Adjust.
* xml-tdesc.c (file_read_description_xml): Adjust.
(fetch_available_features_from_target): Change return type.
(target_fetch_description_xml): Adjust.
(target_read_description_xml): Adjust.
2018-04-07 19:19:12 +02:00
|
|
|
gdb::optional<gdb::char_vector> library_document
|
target_stack -> current_top_target() throughout
The recent C++ification of target_ops replaced references to the old
"current_target" squashed target throughout with references to a
"target_stack" pointer. I had picked the "target_stack" name very
early in the multi-target work, and managed to stick with it, even
though it's a bit of a misnomer, since it isn't really a "target
stack" object, but a pointer into the current top target in the stack.
As I'm splitting more pieces off of the multi-target branch, I've come
to think that it's better to rename it now. A following patch will
introduce a new class to represent a target stack, and "target_stack"
would be _its_ ideal name. (In the branch, the class is called
a_target_stack to work around the clash.)
Thus this commit renames target_stack to current_top_target and
replaces all references throughout. Also, while at it,
current_top_target is made a function instead of a pointer, to make it
possible to change its internal implementation without leaking
implementation details out. In a couple patches, the implementation
of the function will change to refer to a target stack object, and
then further down the multi-target work, it'll change again to find
the right target stack for the current inferior.
gdb/ChangeLog:
2018-06-07 Pedro Alves <palves@redhat.com>
* target.h (target_stack): Delete.
(current_top_target): Declare function.
* target.c (target_stack): Delete.
(g_current_top_target): New.
(current_top_target): New function.
* auxv.c: Use current_top_target instead of target_stack
throughout.
* avr-tdep.c: Likewise.
* breakpoint.c: Likewise.
* corefile.c: Likewise.
* elfread.c: Likewise.
* eval.c: Likewise.
* exceptions.c: Likewise.
* frame.c: Likewise.
* gdbarch-selftests.c: Likewise.
* gnu-v3-abi.c: Likewise.
* ia64-tdep.c: Likewise.
* ia64-vms-tdep.c: Likewise.
* infcall.c: Likewise.
* infcmd.c: Likewise.
* infrun.c: Likewise.
* linespec.c: Likewise.
* linux-tdep.c: Likewise.
* minsyms.c: Likewise.
* ppc-linux-nat.c: Likewise.
* ppc-linux-tdep.c: Likewise.
* procfs.c: Likewise.
* regcache.c: Likewise.
* remote.c: Likewise.
* rs6000-tdep.c: Likewise.
* s390-linux-nat.c: Likewise.
* s390-tdep.c: Likewise.
* solib-aix.c: Likewise.
* solib-darwin.c: Likewise.
* solib-dsbt.c: Likewise.
* solib-spu.c: Likewise.
* solib-svr4.c: Likewise.
* solib-target.c: Likewise.
* sparc-tdep.c: Likewise.
* sparc64-tdep.c: Likewise.
* spu-tdep.c: Likewise.
* symfile.c: Likewise.
* symtab.c: Likewise.
* target-descriptions.c: Likewise.
* target-memory.c: Likewise.
* target.c: Likewise.
* target.h: Likewise.
* tracefile-tfile.c: Likewise.
* tracepoint.c: Likewise.
* valops.c: Likewise.
* valprint.c: Likewise.
* value.c: Likewise.
* windows-tdep.c: Likewise.
* mi/mi-main.c: Likewise.
2018-06-07 18:27:46 +02:00
|
|
|
= target_read_stralloc (current_top_target (), TARGET_OBJECT_LIBRARIES,
|
|
|
|
NULL);
|
Make target_read_alloc & al return vectors
This patch started by changing target_read_alloc_1 to return a
byte_vector, to avoid manual memory management (in target_read_alloc_1
and in the callers). To communicate failures to the callers, it
actually returns a gdb::optional<gdb::byte_vector>.
Adjusting target_read_stralloc was a bit more tricky, since it wants to
return a buffer of char, and not gdb_byte. Since you can't just cast a
gdb::byte_vector into a gdb::def_vector<char>, I made
target_read_alloc_1 templated, so both versions (that return vectors of
gdb_byte and char) are generated. Since target_read_stralloc now
returns a gdb::char_vector instead of a gdb::unique_xmalloc_ptr<char>, a
few callers need to be adjusted.
gdb/ChangeLog:
* common/byte-vector.h (char_vector): New type.
* target.h (target_read_alloc): Return
gdb::optional<byte_vector>.
(target_read_stralloc): Return gdb::optional<char_vector>.
(target_get_osdata): Return gdb::optional<char_vector>.
* target.c (target_read_alloc_1): Templatize. Replacement
manual memory management with vector.
(target_read_alloc): Change return type, adjust.
(target_read_stralloc): Change return type, adjust.
(target_get_osdata): Change return type, adjust.
* auxv.c (struct auxv_info) <length>: Remove.
<data>: Change type to gdb::optional<byte_vector>.
(auxv_inferior_data_cleanup): Free auxv_info with delete.
(get_auxv_inferior_data): Allocate auxv_info with new, adjust.
(target_auxv_search): Adjust.
(fprint_target_auxv): Adjust.
* avr-tdep.c (avr_io_reg_read_command): Adjust.
* linux-tdep.c (linux_spu_make_corefile_notes): Adjust.
(linux_make_corefile_notes): Adjust.
* osdata.c (get_osdata): Adjust.
* remote.c (remote_get_threads_with_qxfer): Adjust.
(remote_memory_map): Adjust.
(remote_traceframe_info): Adjust.
(btrace_read_config): Adjust.
(remote_read_btrace): Adjust.
(remote_pid_to_exec_file): Adjust.
* solib-aix.c (solib_aix_get_library_list): Adjust.
* solib-dsbt.c (decode_loadmap): Don't free buf.
(dsbt_get_initial_loadmaps): Adjust.
* solib-svr4.c (svr4_current_sos_via_xfer_libraries): Adjust.
* solib-target.c (solib_target_current_sos): Adjust.
* tracepoint.c (sdata_make_value): Adjust.
* xml-support.c (xinclude_start_include): Adjust.
(xml_fetch_content_from_file): Adjust.
* xml-support.h (xml_fetch_another): Change return type.
(xml_fetch_content_from_file): Change return type.
* xml-syscall.c (xml_init_syscalls_info): Adjust.
* xml-tdesc.c (file_read_description_xml): Adjust.
(fetch_available_features_from_target): Change return type.
(target_fetch_description_xml): Adjust.
(target_read_description_xml): Adjust.
2018-04-07 19:19:12 +02:00
|
|
|
if (!library_document)
|
2007-07-03 00:01:09 +02:00
|
|
|
return NULL;
|
|
|
|
|
|
|
|
/* Parse the list. */
|
2019-01-17 05:46:00 +01:00
|
|
|
lm_info_vector library_list
|
|
|
|
= solib_target_parse_libraries (library_document->data ());
|
2012-12-15 00:27:13 +01:00
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
if (library_list.empty ())
|
2007-07-03 00:01:09 +02:00
|
|
|
return NULL;
|
|
|
|
|
|
|
|
/* Build a struct so_list for each entry on the list. */
|
2019-01-17 05:46:00 +01:00
|
|
|
for (auto &&info : library_list)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2013-12-28 23:31:01 +01:00
|
|
|
new_solib = XCNEW (struct so_list);
|
2017-04-28 23:16:16 +02:00
|
|
|
strncpy (new_solib->so_name, info->name.c_str (),
|
|
|
|
SO_NAME_MAX_PATH_SIZE - 1);
|
2007-07-03 00:01:09 +02:00
|
|
|
new_solib->so_name[SO_NAME_MAX_PATH_SIZE - 1] = '\0';
|
2017-04-28 23:16:16 +02:00
|
|
|
strncpy (new_solib->so_original_name, info->name.c_str (),
|
2007-07-03 00:01:09 +02:00
|
|
|
SO_NAME_MAX_PATH_SIZE - 1);
|
|
|
|
new_solib->so_original_name[SO_NAME_MAX_PATH_SIZE - 1] = '\0';
|
|
|
|
|
|
|
|
/* We no longer need this copy of the name. */
|
2017-04-28 23:16:16 +02:00
|
|
|
info->name.clear ();
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2019-01-17 05:46:00 +01:00
|
|
|
new_solib->lm_info = info.release ();
|
|
|
|
|
2007-07-03 00:01:09 +02:00
|
|
|
/* Add it to the list. */
|
|
|
|
if (!start)
|
|
|
|
last = start = new_solib;
|
|
|
|
else
|
|
|
|
{
|
|
|
|
last->next = new_solib;
|
|
|
|
last = new_solib;
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
|
|
|
return start;
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
2010-01-08 23:52:04 +01:00
|
|
|
solib_target_solib_create_inferior_hook (int from_tty)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
|
|
|
/* Nothing needed. */
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
solib_target_clear_solib (void)
|
|
|
|
{
|
|
|
|
/* Nothing needed. */
|
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
solib_target_free_so (struct so_list *so)
|
|
|
|
{
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
lm_info_target *li = (lm_info_target *) so->lm_info;
|
|
|
|
|
2017-04-28 23:16:16 +02:00
|
|
|
gdb_assert (li->name.empty ());
|
|
|
|
|
|
|
|
delete li;
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
|
|
|
static void
|
|
|
|
solib_target_relocate_section_addresses (struct so_list *so,
|
2009-05-23 01:49:14 +02:00
|
|
|
struct target_section *sec)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
|
|
|
CORE_ADDR offset;
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
lm_info_target *li = (lm_info_target *) so->lm_info;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
/* Build the offset table only once per object file. We can not do
|
|
|
|
it any earlier, since we need to open the file first. */
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
if (li->offsets == NULL)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2013-05-04 08:19:31 +02:00
|
|
|
int num_sections = gdb_bfd_count_sections (so->abfd);
|
2007-07-03 00:01:09 +02:00
|
|
|
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
li->offsets
|
2015-09-25 20:08:06 +02:00
|
|
|
= ((struct section_offsets *)
|
|
|
|
xzalloc (SIZEOF_N_SECTION_OFFSETS (num_sections)));
|
2007-07-03 00:01:09 +02:00
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
if (!li->section_bases.empty ())
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
|
|
|
int i;
|
2008-03-14 23:30:07 +01:00
|
|
|
asection *sect;
|
|
|
|
int num_alloc_sections = 0;
|
|
|
|
|
|
|
|
for (i = 0, sect = so->abfd->sections;
|
|
|
|
sect != NULL;
|
|
|
|
i++, sect = sect->next)
|
|
|
|
if ((bfd_get_section_flags (so->abfd, sect) & SEC_ALLOC))
|
|
|
|
num_alloc_sections++;
|
|
|
|
|
2017-05-02 20:25:43 +02:00
|
|
|
if (num_alloc_sections != li->section_bases.size ())
|
2008-03-14 23:30:07 +01:00
|
|
|
warning (_("\
|
|
|
|
Could not relocate shared library \"%s\": wrong number of ALLOC sections"),
|
2007-07-03 00:01:09 +02:00
|
|
|
so->so_name);
|
2008-03-14 23:30:07 +01:00
|
|
|
else
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
2008-03-14 23:30:07 +01:00
|
|
|
int bases_index = 0;
|
|
|
|
int found_range = 0;
|
|
|
|
|
|
|
|
so->addr_low = ~(CORE_ADDR) 0;
|
|
|
|
so->addr_high = 0;
|
|
|
|
for (i = 0, sect = so->abfd->sections;
|
|
|
|
sect != NULL;
|
|
|
|
i++, sect = sect->next)
|
|
|
|
{
|
|
|
|
if (!(bfd_get_section_flags (so->abfd, sect) & SEC_ALLOC))
|
|
|
|
continue;
|
|
|
|
if (bfd_section_size (so->abfd, sect) > 0)
|
|
|
|
{
|
|
|
|
CORE_ADDR low, high;
|
2010-05-17 01:49:58 +02:00
|
|
|
|
2017-05-02 19:30:08 +02:00
|
|
|
low = li->section_bases[i];
|
2008-03-14 23:30:07 +01:00
|
|
|
high = low + bfd_section_size (so->abfd, sect) - 1;
|
|
|
|
|
|
|
|
if (low < so->addr_low)
|
|
|
|
so->addr_low = low;
|
|
|
|
if (high > so->addr_high)
|
|
|
|
so->addr_high = high;
|
|
|
|
gdb_assert (so->addr_low <= so->addr_high);
|
|
|
|
found_range = 1;
|
|
|
|
}
|
2017-05-02 19:30:08 +02:00
|
|
|
li->offsets->offsets[i] = li->section_bases[bases_index];
|
2008-03-14 23:30:07 +01:00
|
|
|
bases_index++;
|
|
|
|
}
|
|
|
|
if (!found_range)
|
|
|
|
so->addr_low = so->addr_high = 0;
|
|
|
|
gdb_assert (so->addr_low <= so->addr_high);
|
|
|
|
}
|
|
|
|
}
|
2017-05-02 19:30:08 +02:00
|
|
|
else if (!li->segment_bases.empty ())
|
2008-03-14 23:30:07 +01:00
|
|
|
{
|
|
|
|
struct symfile_segment_data *data;
|
2010-05-17 01:49:58 +02:00
|
|
|
|
2008-03-14 23:30:07 +01:00
|
|
|
data = get_symfile_segment_data (so->abfd);
|
|
|
|
if (data == NULL)
|
|
|
|
warning (_("\
|
|
|
|
Could not relocate shared library \"%s\": no segments"), so->so_name);
|
|
|
|
else
|
|
|
|
{
|
|
|
|
ULONGEST orig_delta;
|
|
|
|
int i;
|
|
|
|
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
if (!symfile_map_offsets_to_segments (so->abfd, data, li->offsets,
|
2017-05-02 20:25:43 +02:00
|
|
|
li->segment_bases.size (),
|
|
|
|
li->segment_bases.data ()))
|
2008-03-14 23:30:07 +01:00
|
|
|
warning (_("\
|
|
|
|
Could not relocate shared library \"%s\": bad offsets"), so->so_name);
|
|
|
|
|
|
|
|
/* Find the range of addresses to report for this library in
|
|
|
|
"info sharedlibrary". Report any consecutive segments
|
|
|
|
which were relocated as a single unit. */
|
2017-05-02 20:25:43 +02:00
|
|
|
gdb_assert (li->segment_bases.size () > 0);
|
|
|
|
orig_delta = li->segment_bases[0] - data->segment_bases[0];
|
2008-03-14 23:30:07 +01:00
|
|
|
|
|
|
|
for (i = 1; i < data->num_segments; i++)
|
|
|
|
{
|
|
|
|
/* If we have run out of offsets, assume all
|
|
|
|
remaining segments have the same offset. */
|
2017-05-02 20:25:43 +02:00
|
|
|
if (i >= li->segment_bases.size ())
|
2008-03-14 23:30:07 +01:00
|
|
|
continue;
|
|
|
|
|
|
|
|
/* If this segment does not have the same offset, do
|
|
|
|
not include it in the library's range. */
|
2017-05-02 20:25:43 +02:00
|
|
|
if (li->segment_bases[i] - data->segment_bases[i]
|
|
|
|
!= orig_delta)
|
2008-03-14 23:30:07 +01:00
|
|
|
break;
|
|
|
|
}
|
|
|
|
|
2017-05-02 20:25:43 +02:00
|
|
|
so->addr_low = li->segment_bases[0];
|
2008-03-14 23:30:07 +01:00
|
|
|
so->addr_high = (data->segment_bases[i - 1]
|
|
|
|
+ data->segment_sizes[i - 1]
|
|
|
|
+ orig_delta);
|
|
|
|
gdb_assert (so->addr_low <= so->addr_high);
|
|
|
|
|
|
|
|
free_symfile_segment_data (data);
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
}
|
|
|
|
}
|
|
|
|
|
Make various lm_info implementations inherit from a base class
The lm_info structure is used to store target specific information about
mapped libraries. It is currently defined as an opaque type in solist.h
and a pointer to it is included in solist, the target-agnostic object
representing a loaded shared library. Multiple targets define their own
implementation of lm_info.
In anticipation of using C++ stuff (e.g. vector) in the lm_info objects,
we first need to avoid different definitions of classes with the same
name (which violates the one definition rule). This patch does it by
having a base class (lm_info_base) from which all the specific lm_info
derive. Each implementation is renamed to something that makes sense
(e.g. lm_info_aix for AIX). The next logical step would probably be to
derive directly from so_list, it's not really obvious, so I'll keep that
for another day.
One special case is the Neutrino (nto) support. It uses SVR4-style
libraries, but overrides some methods. To do that, it needed to have
its own copy of SVR4's lm_info structure in nto-tdep.c, because it was
just not possible to put it in solib-svr4.h and include that file. Over
time, that copy got out of sync, which is still the case today. I can
only assume that the lm_addr function in nto-tdep.c is broken right now.
The first field of the old lm_info was a pointer (gdb_byte *), whereas
in the new lm_info it's an address in the inferior (CORE_ADDR). Trying
to use that field today probably results in a crash. With this
refactor, it's now possible to put lm_info_svr4 in solib-svr4.h and just
include it. I have adapted the code in nto-tdep.c to that it builds,
but it's probably not correct. Since I don't have the knowledge nor
setup to try this on Neutrino, somebody else would have to fix it. But
I am confident that I am not making things worse than they already are.
gdb/ChangeLog:
* solist.h (struct lm_info): Remove.
(struct lm_info_base): New class.
(struct so_list) <lm_info>: Change type to lm_info_base *.
* nto-tdep.c (struct lm_info): Remove.
(lm_addr): Adjust.
* solib-aix.c (struct lm_info): Rename to ...
(struct lm_info_aix): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_aix_p): ... this, and adjust.
(solib_aix_new_lm_info, solib_aix_xfree_lm_info,
solib_aix_parse_libraries, library_list_start_library,
solib_aix_free_library_list, solib_aix_parse_libraries,
solib_aix_get_library_list,
solib_aix_relocate_section_addresses, solib_aix_free_so,
solib_aix_get_section_offsets,
solib_aix_solib_create_inferior_hook, solib_aix_current_sos):
Adjust.
(struct solib_aix_inferior_data) <library_list>: Adjust.
* solib-darwin.c (struct lm_info): Rename to ...
(struct lm_info_darwin): ... this. Extend lm_info_base.
(darwin_current_sos, darwin_relocate_section_addresses): Adjust.
* solib-dsbt.c (struct lm_info): Rename to ...
(struct lm_info_dsbt): ... this. Extend lm_info_base.
(struct dsbt_info) <main_executable_lm_info): Adjust.
(dsbt_current_sos, dsbt_relocate_main_executable, dsbt_free_so,
dsbt_relocate_section_addresses): Adjust.
* solib-frv.c (struct lm_info): Rename to ...
(struct lm_info_frv): ... this. Extend lm_info_base.
(main_executable_lm_info): Adjust.
(frv_current_sos, frv_relocate_main_executable, frv_free_so,
frv_relocate_section_addresses, frv_fdpic_find_global_pointer,
find_canonical_descriptor_in_load_object,
frv_fdpic_find_canonical_descriptor): Adjust.
* solib-svr4.c (struct lm_info): Move to solib-svr4.h, renamed
to lm_info_svr4.
(lm_info_read, lm_addr_check, svr4_keep_data_in_core,
svr4_clear_so, svr4_copy_library_list,
library_list_start_library, svr4_default_sos, svr4_read_so_list,
svr4_current_sos, svr4_fetch_objfile_link_map,
solist_update_incremental): Adjust.
* solib-svr4.h (struct lm_info_svr4): Move here from
solib-svr4.c.
* solib-target.c (struct lm_info): Rename to ...
(struct lm_info_target): ... this. Extend lm_info_base.
(lm_info_p): Rename to ...
(lm_info_target_p): ... this.
(solib_target_parse_libraries, library_list_start_segment,
library_list_start_section, library_list_start_library,
library_list_end_library, solib_target_free_library_list,
solib_target_current_sos, solib_target_free_so,
solib_target_relocate_section_addresses): Adjust.
* windows-nat.c (struct lm_info): Rename to ...
(struct lm_info_windows): ... this. Extend lm_info_base.
(windows_make_so, handle_load_dll, handle_unload_dll,
windows_xfer_shared_libraries): Adjust.
2017-04-28 23:16:13 +02:00
|
|
|
offset = li->offsets->offsets[gdb_bfd_section_index
|
|
|
|
(sec->the_bfd_section->owner,
|
|
|
|
sec->the_bfd_section)];
|
2007-07-03 00:01:09 +02:00
|
|
|
sec->addr += offset;
|
|
|
|
sec->endaddr += offset;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
Eliminate catch_errors
If you want to use catch_errors with a function with parameters, then
currently you have to manually write a "capture" struct wrapping the
arguments and marshall/unmarshall that.
https://sourceware.org/ml/gdb-patches/2017-09/msg00834.html proposed
adjusting catch_errors to use gdb::function_view, which would allow
passing lambdas with automatic captures. However, it seems like using
TRY/CATCH directly instead ends up producing clearer and easier to
debug code. This is what this commit does.
Note that removing catch_errors exposes further cleanup opportunities
around no longer having to follow catch_errors callback type, and also
removes a few cleanups.
I didn't do anything to save/restore current_uiout because I think
that should be the responsibility of the code that changes
current_uiout in the first place.
(Another approach could be to make catch_errors a variadic template
like:
template<typename Function, typename... Args>
int catch_errors (const char *errstring, return_mask mask,
Function &&func, Args... args);
and then with:
extern void function_with_args (int, int);
extern void function_with_no_args ();
calls to the above functions would be wrapped like this:
catch_errors ("some error happened", RETURN_MASK_ERROR,
function_with_args, arg1, arg2);
catch_errors ("some error happened", RETURN_MASK_ERROR,
function_with_no_args);
but I'm thinking that that doesn't improve much if at all either.)
gdb/ChangeLog
2017-10-10 Pedro Alves <palves@redhat.com>
Tom Tromey <tom@tromey.com>
* breakpoint.c (breakpoint_cond_eval): Change return type to bool
and reverse logic.
(WP_DELETED, WP_VALUE_CHANGED, WP_VALUE_NOT_CHANGED, WP_IGNORE):
No longer macros. Instead ...
(enum wp_check_result): They're now values of this new
enumeration.
(watchpoint_check): Change return type to wp_check_result and
parameter type to bpstat.
(bpstat_check_watchpoint): Use TRY/CATCH instead of catch_errors.
(bpstat_check_breakpoint_conditions): Use TRY/CATCH instead of
catch_errors. Reverse logic of watchpoint_check call.
(breakpoint_re_set_one): Now returns void and takes a breakpoint
pointer as parameter.
(breakpoint_re_set): Use TRY/CATCH instead of catch_errors.
* common/common-exceptions.c (throw_exception_sjlj): Update
comments to avoid mentioning catch_errors.
* exceptions.c (catch_errors): Delete.
* exceptions.h: Update comments to avoid mentioning catch_errors.
(catch_errors_ftype, catch_errors): Delete.
* infrun.c (normal_stop): Use TRY/CATCH instead of catch_errors.
(hook_stop_stub): Delete.
(restore_selected_frame): Change return type to void, and
parameter type to const frame_id &.
(restore_infcall_control_state): Use TRY/CATCH instead of
catch_errors.
* main.c (captured_command_loop): Return void and remove
parameter. Remove references to catch_errors.
(captured_main): Use TRY/CATCH instead of catch_errors.
* objc-lang.c (objc_submethod_helper_data)
(find_objc_msgcall_submethod_helper): Delete.
(find_objc_msgcall_submethod): Use TRY/CATCH instead of
catch_errors.
* record-full.c (record_full_message): Return void.
(record_full_message_args, record_full_message_wrapper): Delete.
(record_full_message_wrapper_safe): Return bool and use TRY/CATCH
instead of catch_errors.
* solib-aix.c (solib_aix_open_symbol_file_object): Change
parameter type to int.
* solib-darwin.c (open_symbol_file_object): Ditto.
* solib-dsbt.c (open_symbol_file_object): Ditto.
* solib-frv.c (open_symbol_file_object): Ditto.
* solib-svr4.c (open_symbol_file_object): Ditto.
* solib-target.c (solib_target_open_symbol_file_object): Ditto.
* solib.c (update_solib_list): Use TRY/CATCH instead of
catch_errors.
* solist.h (struct target_so_ops) <open_symbol_file_object>:
Change type.
* symmisc.c (struct print_symbol_args): Remove.
(dump_symtab_1): Use TRY/CATCH instead of catch_errors.
(print_symbol): Change type.
* windows-nat.c (handle_load_dll, handle_unload_dll): Return void
and remove parameters.
(catch_errors): New.
(get_windows_debug_event): Adjust.
gdb/testsuite/ChangeLog:
2017-10-10 Pedro Alves <palves@redhat.com>
* lib/selftest-support.exp (selftest_setup): Update for
captured_command_loop's prototype change.
2017-10-10 17:45:50 +02:00
|
|
|
solib_target_open_symbol_file_object (int from_tty)
|
2007-07-03 00:01:09 +02:00
|
|
|
{
|
|
|
|
/* We can't locate the main symbol file based on the target's
|
|
|
|
knowledge; the user has to specify it. */
|
|
|
|
return 0;
|
|
|
|
}
|
|
|
|
|
|
|
|
static int
|
|
|
|
solib_target_in_dynsym_resolve_code (CORE_ADDR pc)
|
|
|
|
{
|
|
|
|
/* We don't have a range of addresses for the dynamic linker; there
|
|
|
|
may not be one in the program's address space. So only report
|
|
|
|
PLT entries (which may be import stubs). */
|
2013-06-25 00:18:32 +02:00
|
|
|
return in_plt_section (pc);
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|
|
|
|
|
2007-10-24 23:16:30 +02:00
|
|
|
struct target_so_ops solib_target_so_ops;
|
2007-07-03 00:01:09 +02:00
|
|
|
|
|
|
|
void
|
|
|
|
_initialize_solib_target (void)
|
|
|
|
{
|
|
|
|
solib_target_so_ops.relocate_section_addresses
|
|
|
|
= solib_target_relocate_section_addresses;
|
|
|
|
solib_target_so_ops.free_so = solib_target_free_so;
|
|
|
|
solib_target_so_ops.clear_solib = solib_target_clear_solib;
|
|
|
|
solib_target_so_ops.solib_create_inferior_hook
|
|
|
|
= solib_target_solib_create_inferior_hook;
|
|
|
|
solib_target_so_ops.current_sos = solib_target_current_sos;
|
|
|
|
solib_target_so_ops.open_symbol_file_object
|
|
|
|
= solib_target_open_symbol_file_object;
|
|
|
|
solib_target_so_ops.in_dynsym_resolve_code
|
|
|
|
= solib_target_in_dynsym_resolve_code;
|
2009-07-17 19:08:23 +02:00
|
|
|
solib_target_so_ops.bfd_open = solib_bfd_open;
|
2010-06-15 19:57:38 +02:00
|
|
|
|
|
|
|
/* Set current_target_so_ops to solib_target_so_ops if not already
|
|
|
|
set. */
|
|
|
|
if (current_target_so_ops == 0)
|
|
|
|
current_target_so_ops = &solib_target_so_ops;
|
2007-07-03 00:01:09 +02:00
|
|
|
}
|