diff options
author | Markus Metzger <mmetzger@sourceware.org> | 2013-03-11 08:25:58 +0000 |
---|---|---|
committer | Markus Metzger <mmetzger@sourceware.org> | 2013-03-11 08:25:58 +0000 |
commit | 3e3aea48e21e35069ec893c4b5d49de494f8329c (patch) | |
tree | 0faabad15e928132abeb1bb86253d39b685068c8 /gdb/amd64-linux-nat.c | |
parent | 7c97f91ebf5a08c0163d6b097373acc91a986a29 (diff) | |
download | gdb-3e3aea48e21e35069ec893c4b5d49de494f8329c.zip gdb-3e3aea48e21e35069ec893c4b5d49de494f8329c.tar.gz gdb-3e3aea48e21e35069ec893c4b5d49de494f8329c.tar.bz2 |
Install the btrace target ops for i386-linux-nat and amd64-linux-nat.
gdb/
* amd64-linux-nat.c: Include btrace.h and linux-btrace.h.
(amd64_linux_enable_btrace): New.
(amd64_linux_disable_btrace): New.
(amd64_linux_teardown_btrace): New.
(_initialize_amd64_linux_nat): Initialize btrace ops.
* i386-linux.nat.c: Include btrace.h and linux-btrace.h.
(i386_linux_enable_btrace): New.
(i386_linux_disable_btrace): New.
(i386_linux_teardown_btrace): New.
(_initialize_i386_linux_nat): Initialize btrace ops.
* config/i386/linux.mh: Add linux-btrace.o.
* config/i386/linux64.mh: Add linux-btrace.o.
Diffstat (limited to 'gdb/amd64-linux-nat.c')
-rw-r--r-- | gdb/amd64-linux-nat.c | 51 |
1 files changed, 51 insertions, 0 deletions
diff --git a/gdb/amd64-linux-nat.c b/gdb/amd64-linux-nat.c index 3d1983b..8dfe7c5 100644 --- a/gdb/amd64-linux-nat.c +++ b/gdb/amd64-linux-nat.c @@ -25,6 +25,8 @@ #include "regset.h" #include "linux-nat.h" #include "amd64-linux-tdep.h" +#include "linux-btrace.h" +#include "btrace.h" #include "gdb_assert.h" #include "gdb_string.h" @@ -1119,6 +1121,48 @@ amd64_linux_read_description (struct target_ops *ops) } } +/* Enable branch tracing. */ + +static struct btrace_target_info * +amd64_linux_enable_btrace (ptid_t ptid) +{ + struct btrace_target_info *tinfo; + struct gdbarch *gdbarch; + + errno = 0; + tinfo = linux_enable_btrace (ptid); + + if (tinfo == NULL) + error (_("Could not enable branch tracing for %s: %s."), + target_pid_to_str (ptid), safe_strerror (errno)); + + /* Fill in the size of a pointer in bits. */ + gdbarch = target_thread_architecture (ptid); + tinfo->ptr_bits = gdbarch_ptr_bit (gdbarch); + + return tinfo; +} + +/* Disable branch tracing. */ + +static void +amd64_linux_disable_btrace (struct btrace_target_info *tinfo) +{ + int errcode = linux_disable_btrace (tinfo); + + if (errcode != 0) + error (_("Could not disable branch tracing: %s."), safe_strerror (errcode)); +} + +/* Teardown branch tracing. */ + +static void +amd64_linux_teardown_btrace (struct btrace_target_info *tinfo) +{ + /* Ignore errors. */ + linux_disable_btrace (tinfo); +} + /* Provide a prototype to silence -Wmissing-prototypes. */ void _initialize_amd64_linux_nat (void); @@ -1157,6 +1201,13 @@ _initialize_amd64_linux_nat (void) t->to_read_description = amd64_linux_read_description; + /* Add btrace methods. */ + t->to_supports_btrace = linux_supports_btrace; + t->to_enable_btrace = amd64_linux_enable_btrace; + t->to_disable_btrace = amd64_linux_disable_btrace; + t->to_teardown_btrace = amd64_linux_teardown_btrace; + t->to_read_btrace = linux_read_btrace; + /* Register the target. */ linux_nat_add_target (t); linux_nat_set_new_thread (t, amd64_linux_new_thread); |