diff options
author | Yao Qi <yao@codesourcery.com> | 2014-02-10 17:17:32 +0800 |
---|---|---|
committer | Yao Qi <yao@codesourcery.com> | 2014-02-23 11:44:27 +0800 |
commit | 1ca49d376dec6a93e879bc9456617622d7e349b3 (patch) | |
tree | 0e2564e9ec48472a73c83abb826f6ec19e7de5f7 /gdb/tracefile-tfile.c | |
parent | a283690eb7320dfe4074301c673f6cc3dd21fb11 (diff) | |
download | binutils-1ca49d376dec6a93e879bc9456617622d7e349b3.zip binutils-1ca49d376dec6a93e879bc9456617622d7e349b3.tar.gz binutils-1ca49d376dec6a93e879bc9456617622d7e349b3.tar.bz2 |
Share code on to_xfer_partial for tfile and ctf target
In the to_xfer_partial implementations of ctf and tfile, the code on
reading from read-only sections is duplicated. This patch moves it to
a separate function exec_read_partial_read_only.
gdb:
2014-02-23 Yao Qi <yao@codesourcery.com>
* ctf.c (ctf_xfer_partial): Move code to ...
* exec.c (exec_read_partial_read_only): ... it. New function.
* tracefile-tfile.c (tfile_xfer_partial): Likewise.
* tracefile.c: Include "exec.h".
* exec.h (exec_read_partial_read_only): Declare.
Diffstat (limited to 'gdb/tracefile-tfile.c')
-rw-r--r-- | gdb/tracefile-tfile.c | 36 |
1 files changed, 1 insertions, 35 deletions
diff --git a/gdb/tracefile-tfile.c b/gdb/tracefile-tfile.c index 3ef109e..02122eb 100644 --- a/gdb/tracefile-tfile.c +++ b/gdb/tracefile-tfile.c @@ -938,41 +938,7 @@ tfile_xfer_partial (struct target_ops *ops, enum target_object object, } } - /* It's unduly pedantic to refuse to look at the executable for - read-only pieces; so do the equivalent of readonly regions aka - QTro packet. */ - /* FIXME account for relocation at some point. */ - if (exec_bfd) - { - asection *s; - bfd_size_type size; - bfd_vma vma; - - for (s = exec_bfd->sections; s; s = s->next) - { - if ((s->flags & SEC_LOAD) == 0 - || (s->flags & SEC_READONLY) == 0) - continue; - - vma = s->vma; - size = bfd_get_section_size (s); - if (vma <= offset && offset < (vma + size)) - { - ULONGEST amt; - - amt = (vma + size) - offset; - if (amt > len) - amt = len; - - *xfered_len = bfd_get_section_contents (exec_bfd, s, - readbuf, offset - vma, amt); - return TARGET_XFER_OK; - } - } - } - - /* Indicate failure to find the requested memory block. */ - return TARGET_XFER_E_IO; + return exec_read_partial_read_only (readbuf, offset, len, xfered_len); } /* Iterate through the blocks of a trace frame, looking for a 'V' |