* bfd-target.c (struct target_bfd_data): New.
authorPedro Alves <palves@redhat.com>
Sat, 8 Aug 2009 16:32:37 +0000 (16:32 +0000)
committerPedro Alves <palves@redhat.com>
Sat, 8 Aug 2009 16:32:37 +0000 (16:32 +0000)
(target_bfd_xfer_partial): Adjust to get at the section table from
the new structure.
(target_bfd_get_section_table): Ditto.
(target_bfd_xclose): Ditto.  Get the bfd pointer from the
target_bfd_data structure, from the section table.
(target_bfd_reopen): Store a struct target_bfd_data in the
target_ops to_data field, instead of a target_section_table.

gdb/ChangeLog
gdb/bfd-target.c

index d71be0fce84f953ce23609f127d05cd47fac65b7..fdbbe83f544a61db9c183e5c35b1a813d301cf63 100644 (file)
@@ -1,3 +1,14 @@
+2009-08-08  Pedro Alves  <pedro@codesourcery.com>
+
+       * bfd-target.c (struct target_bfd_data): New.
+       (target_bfd_xfer_partial): Adjust to get at the section table from
+       the new structure.
+       (target_bfd_get_section_table): Ditto.
+       (target_bfd_xclose): Ditto.  Get the bfd pointer from the
+       target_bfd_data structure, from the section table.
+       (target_bfd_reopen): Store a struct target_bfd_data in the
+       target_ops to_data field, instead of a target_section_table.
+
 2009-08-08  Aleksandar Ristovski  <aristovski@qnx.com>
             Hui Zhu  <teawater@gmail.com>
 
index ffaa4ffe440c34f0d417af32d0255cca9c8f51ac..0e553d25893fe4b881837d1c50b7e869094bc1e9 100644 (file)
 #include "bfd-target.h"
 #include "exec.h"
 
+/* The object that is stored in the target_ops->to_data field has this
+   type.  */
+struct target_bfd_data
+{
+  /* The BFD we're wrapping.  */
+  struct bfd *bfd;
+
+  /* The section table build from the ALLOC sections in BFD.  Note
+     that we can't rely on extracting the BFD from a random section in
+     the table, since the table can be legitimately empty.  */
+  struct target_section_table table;
+};
+
 static LONGEST
 target_bfd_xfer_partial (struct target_ops *ops,
                         enum target_object object,
@@ -33,10 +46,11 @@ target_bfd_xfer_partial (struct target_ops *ops,
     {
     case TARGET_OBJECT_MEMORY:
       {
-       struct target_section_table *table = ops->to_data;
-       return section_table_xfer_memory_partial (readbuf, writebuf, offset, len,
-                                                 table->sections,
-                                                 table->sections_end,
+       struct target_bfd_data *data = ops->to_data;
+       return section_table_xfer_memory_partial (readbuf, writebuf,
+                                                 offset, len,
+                                                 data->table.sections,
+                                                 data->table.sections_end,
                                                  NULL);
       }
     default:
@@ -47,17 +61,18 @@ target_bfd_xfer_partial (struct target_ops *ops,
 static struct target_section_table *
 target_bfd_get_section_table (struct target_ops *ops)
 {
-  return ops->to_data;
+  struct target_bfd_data *data = ops->to_data;
+  return &data->table;
 }
 
 static void
 target_bfd_xclose (struct target_ops *t, int quitting)
 {
-  struct target_section_table *table = t->to_data;
-  if (table->sections)
-    bfd_close (table->sections->bfd);
-  xfree (table->sections);
-  xfree (table);
+  struct target_bfd_data *data = t->to_data;
+
+  bfd_close (data->bfd);
+  xfree (data->table.sections);
+  xfree (data);
   xfree (t);
 }
 
@@ -65,10 +80,11 @@ struct target_ops *
 target_bfd_reopen (struct bfd *bfd)
 {
   struct target_ops *t;
-  struct target_section_table *table;
+  struct target_bfd_data *data;
 
-  table = XZALLOC (struct target_section_table);
-  build_section_table (bfd, &table->sections, &table->sections_end);
+  data = XZALLOC (struct target_bfd_data);
+  data->bfd = bfd;
+  build_section_table (bfd, &data->table.sections, &data->table.sections_end);
 
   t = XZALLOC (struct target_ops);
   t->to_shortname = "bfd";
@@ -77,7 +93,7 @@ target_bfd_reopen (struct bfd *bfd)
   t->to_get_section_table = target_bfd_get_section_table;
   t->to_xfer_partial = target_bfd_xfer_partial;
   t->to_xclose = target_bfd_xclose;
-  t->to_data = table;
+  t->to_data = data;
 
   return t;
 }