diff options
| author | Tvrtko Ursulin <tvrtko.ursulin@intel.com> | 2017-09-13 17:38:16 +0100 | 
|---|---|---|
| committer | Tvrtko Ursulin <tvrtko.ursulin@intel.com> | 2017-11-22 11:17:48 +0000 | 
| commit | a688deceae195aec863d8de45bdaefb251927c89 (patch) | |
| tree | 80f916af851ea53ad295a525efa58e8661e176d1 /overlay | |
| parent | 42ee3f94f2c5c3258930c22da7c1b497dd635346 (diff) | |
intel-gpu-overlay: Move local perf implementation to a library
Idea is to avoid duplication across multiple users in
upcoming patches.
v2: Commit message and use a separate library instead of piggy-
    backing to libintel_tools. (Chris Wilson)
v3: Add Petri's meson build recipe.
Signed-off-by: Tvrtko Ursulin <tvrtko.ursulin@intel.com>
Cc: Petri Latvala <petri.latvala@intel.com>
Reviewed-by: Chris Wilson <chris@chris-wilson.co.uk>
Diffstat (limited to 'overlay')
| -rw-r--r-- | overlay/Makefile.am | 6 | ||||
| -rw-r--r-- | overlay/gem-interrupts.c | 3 | ||||
| -rw-r--r-- | overlay/gpu-freq.c | 3 | ||||
| -rw-r--r-- | overlay/gpu-perf.c | 3 | ||||
| -rw-r--r-- | overlay/gpu-top.c | 3 | ||||
| -rw-r--r-- | overlay/meson.build | 2 | ||||
| -rw-r--r-- | overlay/perf.c | 26 | ||||
| -rw-r--r-- | overlay/perf.h | 64 | ||||
| -rw-r--r-- | overlay/power.c | 3 | ||||
| -rw-r--r-- | overlay/rc6.c | 3 | 
10 files changed, 15 insertions, 101 deletions
| diff --git a/overlay/Makefile.am b/overlay/Makefile.am index 39fbcc4e..cefde2d0 100644 --- a/overlay/Makefile.am +++ b/overlay/Makefile.am @@ -4,8 +4,8 @@ endif  AM_CPPFLAGS = -I.  AM_CFLAGS = $(DRM_CFLAGS) $(PCIACCESS_CFLAGS) $(CWARNFLAGS) \ -	$(CAIRO_CFLAGS) $(OVERLAY_CFLAGS) $(WERROR_CFLAGS) -LDADD = $(DRM_LIBS) $(PCIACCESS_LIBS) $(CAIRO_LIBS) $(OVERLAY_LIBS) +	$(CAIRO_CFLAGS) $(OVERLAY_CFLAGS) $(WERROR_CFLAGS) -I$(srcdir)/../lib +LDADD = $(DRM_LIBS) $(PCIACCESS_LIBS) $(CAIRO_LIBS) $(OVERLAY_LIBS) $(top_builddir)/lib/libigt_perf.la  intel_gpu_overlay_SOURCES = \  	chart.h \ @@ -29,8 +29,6 @@ intel_gpu_overlay_SOURCES = \  	igfx.c \  	overlay.h \  	overlay.c \ -	perf.h \ -	perf.c \  	power.h \  	power.c \  	rc6.h \ diff --git a/overlay/gem-interrupts.c b/overlay/gem-interrupts.c index 0150a1d0..7ba54fcd 100644 --- a/overlay/gem-interrupts.c +++ b/overlay/gem-interrupts.c @@ -31,9 +31,10 @@  #include <string.h>  #include <ctype.h> +#include "igt_perf.h" +  #include "gem-interrupts.h"  #include "debugfs.h" -#include "perf.h"  static int perf_open(void)  { diff --git a/overlay/gpu-freq.c b/overlay/gpu-freq.c index 321c9388..7f29b1aa 100644 --- a/overlay/gpu-freq.c +++ b/overlay/gpu-freq.c @@ -28,9 +28,10 @@  #include <string.h>  #include <stdio.h> +#include "igt_perf.h" +  #include "gpu-freq.h"  #include "debugfs.h" -#include "perf.h"  static int perf_i915_open(int config, int group)  { diff --git a/overlay/gpu-perf.c b/overlay/gpu-perf.c index f557b9f0..3d4a9be9 100644 --- a/overlay/gpu-perf.c +++ b/overlay/gpu-perf.c @@ -34,7 +34,8 @@  #include <fcntl.h>  #include <errno.h> -#include "perf.h" +#include "igt_perf.h" +  #include "gpu-perf.h"  #include "debugfs.h" diff --git a/overlay/gpu-top.c b/overlay/gpu-top.c index 891a7ea7..06f489df 100644 --- a/overlay/gpu-top.c +++ b/overlay/gpu-top.c @@ -31,7 +31,8 @@  #include <errno.h>  #include <assert.h> -#include "perf.h" +#include "igt_perf.h" +  #include "igfx.h"  #include "gpu-top.h" diff --git a/overlay/meson.build b/overlay/meson.build index a92ef895..ffc011cc 100644 --- a/overlay/meson.build +++ b/overlay/meson.build @@ -10,7 +10,6 @@ gpu_overlay_src = [  	'gpu-freq.c',  	'igfx.c',  	'overlay.c', -	'perf.c',  	'power.c',  	'rc6.c',  ] @@ -56,5 +55,6 @@ if xrandr.found() and cairo.found()  			include_directories : inc,  			c_args : gpu_overlay_cflags,  			dependencies : gpu_overlay_deps, +			link_with : lib_igt_perf,  			install : true)  endif diff --git a/overlay/perf.c b/overlay/perf.c deleted file mode 100644 index b8fdc675..00000000 --- a/overlay/perf.c +++ /dev/null @@ -1,26 +0,0 @@ -#include <stdint.h> -#include <fcntl.h> -#include <unistd.h> -#include <stdlib.h> - -#include "perf.h" - -uint64_t i915_type_id(void) -{ -	char buf[1024]; -	int fd, n; - -	fd = open("/sys/bus/event_source/devices/i915/type", 0); -	if (fd < 0) { -		n = -1; -	} else { -		n = read(fd, buf, sizeof(buf)-1); -		close(fd); -	} -	if (n < 0) -		return 0; - -	buf[n] = '\0'; -	return strtoull(buf, 0, 0); -} - diff --git a/overlay/perf.h b/overlay/perf.h deleted file mode 100644 index c44e65f9..00000000 --- a/overlay/perf.h +++ /dev/null @@ -1,64 +0,0 @@ -#ifndef I915_PERF_H -#define I915_PERF_H - -#include <linux/perf_event.h> - -#define I915_SAMPLE_BUSY	0 -#define I915_SAMPLE_WAIT	1 -#define I915_SAMPLE_SEMA	2 - -#define I915_SAMPLE_RCS		0 -#define I915_SAMPLE_VCS		1 -#define I915_SAMPLE_BCS		2 -#define I915_SAMPLE_VECS	3 - -#define __I915_PERF_COUNT(ring, id) ((ring) << 4 | (id)) - -#define I915_PERF_COUNT_RCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_BUSY) -#define I915_PERF_COUNT_RCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_WAIT) -#define I915_PERF_COUNT_RCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_RCS, I915_SAMPLE_SEMA) - -#define I915_PERF_COUNT_VCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_BUSY) -#define I915_PERF_COUNT_VCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_WAIT) -#define I915_PERF_COUNT_VCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_VCS, I915_SAMPLE_SEMA) - -#define I915_PERF_COUNT_BCS_BUSY __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_BUSY) -#define I915_PERF_COUNT_BCS_WAIT __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_WAIT) -#define I915_PERF_COUNT_BCS_SEMA __I915_PERF_COUNT(I915_SAMPLE_BCS, I915_SAMPLE_SEMA) - -#define I915_PERF_COUNT_VECS_BUSY __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_BUSY) -#define I915_PERF_COUNT_VECS_WAIT __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_WAIT) -#define I915_PERF_COUNT_VECS_SEMA __I915_PERF_COUNT(I915_SAMPLE_VECS, I915_SAMPLE_SEMA) - -#define I915_PERF_ACTUAL_FREQUENCY 32 -#define I915_PERF_REQUESTED_FREQUENCY 33 -#define I915_PERF_ENERGY 34 -#define I915_PERF_INTERRUPTS 35 - -#define I915_PERF_RC6_RESIDENCY		40 -#define I915_PERF_RC6p_RESIDENCY	41 -#define I915_PERF_RC6pp_RESIDENCY	42 - -static inline int -perf_event_open(struct perf_event_attr *attr, -		pid_t pid, -		int cpu, -		int group_fd, -		unsigned long flags) -{ -#ifndef __NR_perf_event_open -#if defined(__i386__) -#define __NR_perf_event_open 336 -#elif defined(__x86_64__) -#define __NR_perf_event_open 298 -#else -#define __NR_perf_event_open 0 -#endif -#endif -    attr->size = sizeof(*attr); -    return syscall(__NR_perf_event_open, attr, pid, cpu, group_fd, flags); -} - -uint64_t i915_type_id(void); - -#endif /* I915_PERF_H */ diff --git a/overlay/power.c b/overlay/power.c index 2f1521b8..84d860ca 100644 --- a/overlay/power.c +++ b/overlay/power.c @@ -31,7 +31,8 @@  #include <time.h>  #include <errno.h> -#include "perf.h" +#include "igt_perf.h" +  #include "power.h"  #include "debugfs.h" diff --git a/overlay/rc6.c b/overlay/rc6.c index d7047c2f..3175bb22 100644 --- a/overlay/rc6.c +++ b/overlay/rc6.c @@ -31,8 +31,9 @@  #include <time.h>  #include <errno.h> +#include "igt_perf.h" +  #include "rc6.h" -#include "perf.h"  static int perf_i915_open(int config, int group)  { | 
