-void
-build_target_sections_from_bfd (struct target_ops *targ, struct bfd *abfd)
-{
- unsigned count;
- struct section_table *start;
- struct section_closure cl;
-
- count = bfd_count_sections (abfd);
- target_resize_to_sections (targ, count);
- start = targ->to_sections;
- cl.end = targ->to_sections;
- bfd_map_over_sections (abfd, add_to_section_table, &cl);
- gdb_assert (cl.end - start <= count);
-}
+ const target_info &info () const override
+ { return target_bfd_target_info; }
+
+ strata stratum () const override { return file_stratum; }
+
+ void close () override;
+
+ target_xfer_status
+ xfer_partial (target_object object,
+ const char *annex, gdb_byte *readbuf,
+ const gdb_byte *writebuf,
+ ULONGEST offset, ULONGEST len,
+ ULONGEST *xfered_len) override;
+
+ target_section_table *get_section_table () override;
+
+private:
+ /* The BFD we're wrapping. */
+ gdb_bfd_ref_ptr m_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 m_table;
+};