Jan Kratochvil dc6b8f4
Index: gdb-7.11.90.20160904/gdb/nat/linux-btrace.h
Jan Kratochvil a4c8bca
===================================================================
Jan Kratochvil dc6b8f4
--- gdb-7.11.90.20160904.orig/gdb/nat/linux-btrace.h	2016-09-04 04:02:13.000000000 +0200
Jan Kratochvil dc6b8f4
+++ gdb-7.11.90.20160904/gdb/nat/linux-btrace.h	2016-09-04 20:11:47.375275492 +0200
Jan Kratochvil 92d45fc
@@ -28,6 +28,177 @@
Jan Kratochvil a4c8bca
 #  include <linux/perf_event.h>
Jan Kratochvil a4c8bca
 #endif
Jan Kratochvil a4c8bca
 
Jan Kratochvil a4c8bca
+#ifdef PERF_ATTR_SIZE_VER5_BUNDLE
Jan Kratochvil a4c8bca
+#ifndef HAVE_LINUX_PERF_EVENT_H
Jan Kratochvil a4c8bca
+# error "PERF_ATTR_SIZE_VER5_BUNDLE && !HAVE_LINUX_PERF_EVENT_H"
Jan Kratochvil a4c8bca
+#endif
Jan Kratochvil a4c8bca
+#ifndef PERF_ATTR_SIZE_VER5
Jan Kratochvil 92d45fc
+#define PERF_ATTR_SIZE_VER5
Jan Kratochvil a4c8bca
+#define perf_event_mmap_page perf_event_mmap_page_bundle
Jan Kratochvil a4c8bca
+// kernel-headers-3.10.0-493.el7.x86_64/usr/include/linux/perf_event.h
Jan Kratochvil a4c8bca
+/*
Jan Kratochvil a4c8bca
+ * Structure of the page that can be mapped via mmap
Jan Kratochvil a4c8bca
+ */
Jan Kratochvil a4c8bca
+struct perf_event_mmap_page {
Jan Kratochvil a4c8bca
+	__u32	version;		/* version number of this structure */
Jan Kratochvil a4c8bca
+	__u32	compat_version;		/* lowest version this is compat with */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * Bits needed to read the hw events in user-space.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   u32 seq, time_mult, time_shift, index, width;
Jan Kratochvil a4c8bca
+	 *   u64 count, enabled, running;
Jan Kratochvil a4c8bca
+	 *   u64 cyc, time_offset;
Jan Kratochvil a4c8bca
+	 *   s64 pmc = 0;
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   do {
Jan Kratochvil a4c8bca
+	 *     seq = pc->lock;
Jan Kratochvil a4c8bca
+	 *     barrier()
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *     enabled = pc->time_enabled;
Jan Kratochvil a4c8bca
+	 *     running = pc->time_running;
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *     if (pc->cap_usr_time && enabled != running) {
Jan Kratochvil a4c8bca
+	 *       cyc = rdtsc();
Jan Kratochvil a4c8bca
+	 *       time_offset = pc->time_offset;
Jan Kratochvil a4c8bca
+	 *       time_mult   = pc->time_mult;
Jan Kratochvil a4c8bca
+	 *       time_shift  = pc->time_shift;
Jan Kratochvil a4c8bca
+	 *     }
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *     index = pc->index;
Jan Kratochvil a4c8bca
+	 *     count = pc->offset;
Jan Kratochvil a4c8bca
+	 *     if (pc->cap_user_rdpmc && index) {
Jan Kratochvil a4c8bca
+	 *       width = pc->pmc_width;
Jan Kratochvil a4c8bca
+	 *       pmc = rdpmc(index - 1);
Jan Kratochvil a4c8bca
+	 *     }
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *     barrier();
Jan Kratochvil a4c8bca
+	 *   } while (pc->lock != seq);
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * NOTE: for obvious reason this only works on self-monitoring
Jan Kratochvil a4c8bca
+	 *       processes.
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u32	lock;			/* seqlock for synchronization */
Jan Kratochvil a4c8bca
+	__u32	index;			/* hardware event identifier */
Jan Kratochvil a4c8bca
+	__s64	offset;			/* add to hardware event value */
Jan Kratochvil a4c8bca
+	__u64	time_enabled;		/* time event active */
Jan Kratochvil a4c8bca
+	__u64	time_running;		/* time event on cpu */
Jan Kratochvil a4c8bca
+	union {
Jan Kratochvil a4c8bca
+		__u64	capabilities;
Jan Kratochvil a4c8bca
+		struct {
Jan Kratochvil a4c8bca
+			__u64	cap_bit0		: 1, /* Always 0, deprecated, see commit 860f085b74e9 */
Jan Kratochvil a4c8bca
+				cap_bit0_is_deprecated	: 1, /* Always 1, signals that bit 0 is zero */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+				cap_user_rdpmc		: 1, /* The RDPMC instruction can be used to read counts */
Jan Kratochvil a4c8bca
+				cap_user_time		: 1, /* The time_* fields are used */
Jan Kratochvil a4c8bca
+				cap_user_time_zero	: 1, /* The time_zero field is used */
Jan Kratochvil a4c8bca
+				cap_____res		: 59;
Jan Kratochvil a4c8bca
+		};
Jan Kratochvil a4c8bca
+	};
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * If cap_user_rdpmc this field provides the bit-width of the value
Jan Kratochvil a4c8bca
+	 * read using the rdpmc() or equivalent instruction. This can be used
Jan Kratochvil a4c8bca
+	 * to sign extend the result like:
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   pmc <<= 64 - width;
Jan Kratochvil a4c8bca
+	 *   pmc >>= 64 - width; // signed shift right
Jan Kratochvil a4c8bca
+	 *   count += pmc;
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u16	pmc_width;
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * If cap_usr_time the below fields can be used to compute the time
Jan Kratochvil a4c8bca
+	 * delta since time_enabled (in ns) using rdtsc or similar.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   u64 quot, rem;
Jan Kratochvil a4c8bca
+	 *   u64 delta;
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   quot = (cyc >> time_shift);
Jan Kratochvil a4c8bca
+	 *   rem = cyc & (((u64)1 << time_shift) - 1);
Jan Kratochvil a4c8bca
+	 *   delta = time_offset + quot * time_mult +
Jan Kratochvil a4c8bca
+	 *              ((rem * time_mult) >> time_shift);
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * Where time_offset,time_mult,time_shift and cyc are read in the
Jan Kratochvil a4c8bca
+	 * seqcount loop described above. This delta can then be added to
Jan Kratochvil a4c8bca
+	 * enabled and possible running (if index), improving the scaling:
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   enabled += delta;
Jan Kratochvil a4c8bca
+	 *   if (index)
Jan Kratochvil a4c8bca
+	 *     running += delta;
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   quot = count / running;
Jan Kratochvil a4c8bca
+	 *   rem  = count % running;
Jan Kratochvil a4c8bca
+	 *   count = quot * enabled + (rem * enabled) / running;
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u16	time_shift;
Jan Kratochvil a4c8bca
+	__u32	time_mult;
Jan Kratochvil a4c8bca
+	__u64	time_offset;
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * If cap_usr_time_zero, the hardware clock (e.g. TSC) can be calculated
Jan Kratochvil a4c8bca
+	 * from sample timestamps.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   time = timestamp - time_zero;
Jan Kratochvil a4c8bca
+	 *   quot = time / time_mult;
Jan Kratochvil a4c8bca
+	 *   rem  = time % time_mult;
Jan Kratochvil a4c8bca
+	 *   cyc = (quot << time_shift) + (rem << time_shift) / time_mult;
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * And vice versa:
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   quot = cyc >> time_shift;
Jan Kratochvil a4c8bca
+	 *   rem  = cyc & (((u64)1 << time_shift) - 1);
Jan Kratochvil a4c8bca
+	 *   timestamp = time_zero + quot * time_mult +
Jan Kratochvil a4c8bca
+	 *               ((rem * time_mult) >> time_shift);
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u64	time_zero;
Jan Kratochvil a4c8bca
+	__u32	size;			/* Header size up to __reserved[] fields. */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+		/*
Jan Kratochvil a4c8bca
+		 * Hole for extension of the self monitor capabilities
Jan Kratochvil a4c8bca
+		 */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	__u8	__reserved[118*8+4];	/* align to 1k. */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * Control data for the mmap() data buffer.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * User-space reading the @data_head value should issue an smp_rmb(),
Jan Kratochvil a4c8bca
+	 * after reading this value.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * When the mapping is PROT_WRITE the @data_tail value should be
Jan Kratochvil a4c8bca
+	 * written by userspace to reflect the last read data, after issueing
Jan Kratochvil a4c8bca
+	 * an smp_mb() to separate the data read from the ->data_tail store.
Jan Kratochvil a4c8bca
+	 * In this case the kernel will not over-write unread data.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * See perf_output_put_handle() for the data ordering.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * data_{offset,size} indicate the location and size of the perf record
Jan Kratochvil a4c8bca
+	 * buffer within the mmapped area.
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u64   data_head;		/* head in the data section */
Jan Kratochvil a4c8bca
+	__u64	data_tail;		/* user-space written tail */
Jan Kratochvil a4c8bca
+	__u64	data_offset;		/* where the buffer starts */
Jan Kratochvil a4c8bca
+	__u64	data_size;		/* data buffer size */
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
+	/*
Jan Kratochvil a4c8bca
+	 * AUX area is defined by aux_{offset,size} fields that should be set
Jan Kratochvil a4c8bca
+	 * by the userspace, so that
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 *   aux_offset >= data_offset + data_size
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * prior to mmap()ing it. Size of the mmap()ed area should be aux_size.
Jan Kratochvil a4c8bca
+	 *
Jan Kratochvil a4c8bca
+	 * Ring buffer pointers aux_{head,tail} have the same semantics as
Jan Kratochvil a4c8bca
+	 * data_{head,tail} and same ordering rules apply.
Jan Kratochvil a4c8bca
+	 */
Jan Kratochvil a4c8bca
+	__u64	aux_head;
Jan Kratochvil a4c8bca
+	__u64	aux_tail;
Jan Kratochvil a4c8bca
+	__u64	aux_offset;
Jan Kratochvil a4c8bca
+	__u64	aux_size;
Jan Kratochvil a4c8bca
+};
Jan Kratochvil a4c8bca
+#endif // PERF_ATTR_SIZE_VER5
Jan Kratochvil a4c8bca
+#endif // PERF_ATTR_SIZE_VER5_BUNDLE
Jan Kratochvil a4c8bca
+
Jan Kratochvil a4c8bca
 struct target_ops;
Jan Kratochvil a4c8bca
 
Jan Kratochvil a4c8bca
 #if HAVE_LINUX_PERF_EVENT_H
Jan Kratochvil dc6b8f4
Index: gdb-7.11.90.20160904/gdb/configure
Jan Kratochvil a4c8bca
===================================================================
Jan Kratochvil dc6b8f4
--- gdb-7.11.90.20160904.orig/gdb/configure	2016-09-04 20:11:47.238274285 +0200
Jan Kratochvil dc6b8f4
+++ gdb-7.11.90.20160904/gdb/configure	2016-09-04 20:11:47.378275519 +0200
Jan Kratochvil dc6b8f4
@@ -10601,7 +10601,7 @@
Jan Kratochvil a4c8bca
 
Jan Kratochvil a4c8bca
 #include <linux/perf_event.h>
Jan Kratochvil a4c8bca
 #ifndef PERF_ATTR_SIZE_VER5
Jan Kratochvil a4c8bca
-# error
Jan Kratochvil a4c8bca
+// error // PERF_ATTR_SIZE_VER5_BUNDLE is not available here - Fedora+RHEL
Jan Kratochvil a4c8bca
 #endif
Jan Kratochvil a4c8bca
 
Jan Kratochvil a4c8bca
 _ACEOF
Jan Kratochvil dc6b8f4
Index: gdb-7.11.90.20160904/gdb/configure.ac
Jan Kratochvil a4c8bca
===================================================================
Jan Kratochvil dc6b8f4
--- gdb-7.11.90.20160904.orig/gdb/configure.ac	2016-09-04 20:11:47.238274285 +0200
Jan Kratochvil dc6b8f4
+++ gdb-7.11.90.20160904/gdb/configure.ac	2016-09-04 20:11:47.379275528 +0200
Jan Kratochvil dc6b8f4
@@ -1461,7 +1461,7 @@
Jan Kratochvil a4c8bca
   AC_PREPROC_IFELSE(AC_LANG_SOURCE([[
Jan Kratochvil a4c8bca
 #include <linux/perf_event.h>
Jan Kratochvil a4c8bca
 #ifndef PERF_ATTR_SIZE_VER5
Jan Kratochvil a4c8bca
-# error
Jan Kratochvil a4c8bca
+// error // PERF_ATTR_SIZE_VER5_BUNDLE is not available here - Fedora+RHEL
Jan Kratochvil a4c8bca
 #endif
Jan Kratochvil a4c8bca
   ]]), [perf_event=yes], [perf_event=no])
Jan Kratochvil a4c8bca
   if test "$perf_event" != yes; then
Jan Kratochvil dc6b8f4
Index: gdb-7.11.90.20160904/gdb/gdb.c
Jan Kratochvil dc6b8f4
===================================================================
Jan Kratochvil dc6b8f4
--- gdb-7.11.90.20160904.orig/gdb/gdb.c	2016-09-04 04:02:13.000000000 +0200
Jan Kratochvil dc6b8f4
+++ gdb-7.11.90.20160904/gdb/gdb.c	2016-09-04 20:12:28.018633552 +0200
Jan Kratochvil dc6b8f4
@@ -20,11 +20,19 @@
Jan Kratochvil dc6b8f4
 #include "main.h"
Jan Kratochvil dc6b8f4
 #include "interps.h"
Jan Kratochvil dc6b8f4
 
Jan Kratochvil dc6b8f4
+#ifdef PERF_ATTR_SIZE_VER5_BUNDLE
Jan Kratochvil dc6b8f4
+extern "C" void __libipt_init(void);
Jan Kratochvil dc6b8f4
+#endif
Jan Kratochvil dc6b8f4
+
Jan Kratochvil dc6b8f4
 int
Jan Kratochvil dc6b8f4
 main (int argc, char **argv)
Jan Kratochvil 92d45fc
 {
Jan Kratochvil 92d45fc
   struct captured_main_args args;
Jan Kratochvil 92d45fc
 
Jan Kratochvil aacdec2
+#ifdef PERF_ATTR_SIZE_VER5_BUNDLE
Jan Kratochvil 92d45fc
+  __libipt_init();
Jan Kratochvil aacdec2
+#endif
Jan Kratochvil 92d45fc
+
Jan Kratochvil 92d45fc
   memset (&args, 0, sizeof args);
Jan Kratochvil 92d45fc
   args.argc = argc;
Jan Kratochvil 92d45fc
   args.argv = argv;