btrace, linux: use data_size and data_offset
authorMarkus Metzger <markus.t.metzger@intel.com>
Mon, 17 Nov 2014 10:18:05 +0000 (11:18 +0100)
committerMarkus Metzger <markus.t.metzger@intel.com>
Thu, 2 Jul 2015 10:52:19 +0000 (12:52 +0200)
In struct perf_event_mmap_page there are new fields data_size and data_offset
that give the location of the perf_event data buffer relative to the mmap
page.  Use them if they are present.

gdb/
* nat/linux-btrace.c (linux_enable_bts): Check for
PERF_ATTR_SIZE_VER5.
Check for data_offset and data_size fields.  Use them.

gdb/ChangeLog
gdb/nat/linux-btrace.c

index 4c96e8a459d99d1c9dea5efbf67a8af5427d265d..a4cce4d43e04e820b90fb55e8e90cd897b0a414c 100644 (file)
@@ -1,3 +1,9 @@
+2015-07-02  Markus Metzger  <markus.t.metzger@intel.com>
+
+       * nat/linux-btrace.c (linux_enable_bts): Check for
+       PERF_ATTR_SIZE_VER5.
+       Check for data_offset and data_size fields.  Use them.
+
 2015-07-02  Markus Metzger  <markus.t.metzger@intel.com>
 
        * NEWS: Announce new commands "record btrace pt" and "record pt".
index ddd79a329743091335aa1e253c1b7c4d3ea1a0f4..3b630f53801a104d6728e947ac2efef89eea07ec 100644 (file)
@@ -642,7 +642,7 @@ linux_enable_bts (ptid_t ptid, const struct btrace_config_bts *conf)
   struct perf_event_mmap_page *header;
   struct btrace_target_info *tinfo;
   struct btrace_tinfo_bts *bts;
-  unsigned long long size, pages;
+  unsigned long long size, pages, data_offset, data_size;
   int pid, pg;
 
   tinfo = xzalloc (sizeof (*tinfo));
@@ -704,16 +704,27 @@ linux_enable_bts (ptid_t ptid, const struct btrace_config_bts *conf)
        break;
     }
 
-  if (header == MAP_FAILED)
+  if (pages == 0)
     goto err_file;
 
+  data_offset = PAGE_SIZE;
+  data_size = size;
+
+#if defined (PERF_ATTR_SIZE_VER5)
+  if (offsetof (struct perf_event_mmap_page, data_size) <= header->size)
+    {
+      data_offset = header->data_offset;
+      data_size = header->data_size;
+    }
+#endif /* defined (PERF_ATTR_SIZE_VER5) */
+
   bts->header = header;
-  bts->bts.mem = ((const uint8_t *) header) + PAGE_SIZE;
-  bts->bts.size = size;
+  bts->bts.mem = ((const uint8_t *) header) + data_offset;
+  bts->bts.size = data_size;
   bts->bts.data_head = &header->data_head;
   bts->bts.last_head = 0;
 
-  tinfo->conf.bts.size = size;
+  tinfo->conf.bts.size = data_size;
   return tinfo;
 
  err_file: