aboutsummaryrefslogtreecommitdiffstats
path: root/tools/perf/Makefile
diff options
context:
space:
mode:
authorArnaldo Carvalho de Melo <acme@redhat.com>2011-01-29 12:44:29 -0500
committerArnaldo Carvalho de Melo <acme@redhat.com>2011-01-30 08:37:38 -0500
commit877108e42b1b9ba64857c4030cf356ecc120fd18 (patch)
treeca41fa741081faa0f936b7296d721c84d1b89176 /tools/perf/Makefile
parent8115d60c323dd9931b95221c0a392aeddc1d6ef3 (diff)
perf tools: Initial python binding
First clarifying that this kind of binding is not a replacement or an equivalent to the 'perf script' way of using python with perf. The 'perf script' way is to process events and look at a given script for some python function that matches the events to pass each event for processing. This is a python module, i.e. everything is driven from the python script, that merely uses "import perf" or "from perf import". perf script is focused on tracepoints, this binding is focused on profiling as an initial target. More work is needed to make available tracepoint specific variables as event variables accessible via this binding. There is one example of such usage model, in tools/perf/python/twatch.py, a tool to watch "cycles" events together with task (fork, exit) and comm perf events. For now, due to me not being able to grok how python distutils cope with building C extensions outside the sources dir the install target just builds it, I'm using it as: [root@emilia linux]# export PYTHONPATH=~acme/git/build/perf/lib.linux-x86_64-2.6/ [root@emilia linux]# tools/perf/python/twatch.py cpu: 4, pid: 30126, tid: 30126 { type: mmap, pid: 30126, tid: 30126, start: 0x4, length: 0x82e9ca03, offset: 0, filename: } cpu: 6, pid: 47, tid: 47 { type: mmap, pid: 47, tid: 47, start: 0x6, length: 0xbef87c36, offset: 0, filename: } cpu: 1, pid: 0, tid: 0 { type: mmap, pid: 0, tid: 0, start: 0x1, length: 0x775d1904, offset: 0, filename: } cpu: 7, pid: 0, tid: 0 { type: mmap, pid: 0, tid: 0, start: 0x7, length: 0xc750aeb6, offset: 0, filename: } cpu: 5, pid: 2255, tid: 2255 { type: mmap, pid: 2255, tid: 2255, start: 0x5, length: 0x76669635, offset: 0, filename: } cpu: 0, pid: 0, tid: 0 { type: mmap, pid: 0, tid: 0, start: 0, length: 0x6422ef6b, offset: 0, filename: } cpu: 2, pid: 2255, tid: 2255 { type: mmap, pid: 2255, tid: 2255, start: 0x2, length: 0xe078757a, offset: 0, filename: } cpu: 1, pid: 5769, tid: 5769 { type: fork, pid: 30127, ppid: 5769, tid: 30127, ptid: 5769, time: 103893991270534} cpu: 6, pid: 30127, tid: 30127 { type: comm, pid: 30127, tid: 30127, comm: ls } cpu: 6, pid: 30127, tid: 30127 { type: exit, pid: 30127, ppid: 30127, tid: 30127, ptid: 30127, time: 103893993273024} The first 8 mmap events in this 8 way machine are a mistery that is still being investigated. More of the tools/perf/util/ APIs will be exposed via this python binding as the need arises. For now the focus is on creating events and processing them, symbol resolution is an obvious next step, with tracepoint variables as a close second step. Cc: Clark Williams <williams@redhat.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Mike Galbraith <efault@gmx.de> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <peterz@infradead.org> Cc: Stephane Eranian <eranian@google.com> Cc: Tom Zanussi <tzanussi@gmail.com> LKML-Reference: <new-submission> Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
Diffstat (limited to 'tools/perf/Makefile')
-rw-r--r--tools/perf/Makefile20
1 files changed, 19 insertions, 1 deletions
diff --git a/tools/perf/Makefile b/tools/perf/Makefile
index eedcf9541572..36ff73c0af94 100644
--- a/tools/perf/Makefile
+++ b/tools/perf/Makefile
@@ -315,6 +315,7 @@ COMPAT_CFLAGS =
315COMPAT_OBJS = 315COMPAT_OBJS =
316LIB_H = 316LIB_H =
317LIB_OBJS = 317LIB_OBJS =
318PYRF_OBJS =
318SCRIPT_PERL = 319SCRIPT_PERL =
319SCRIPT_SH = 320SCRIPT_SH =
320TEST_PROGRAMS = 321TEST_PROGRAMS =
@@ -324,6 +325,9 @@ SCRIPT_SH += perf-archive.sh
324grep-libs = $(filter -l%,$(1)) 325grep-libs = $(filter -l%,$(1))
325strip-libs = $(filter-out -l%,$(1)) 326strip-libs = $(filter-out -l%,$(1))
326 327
328pyrf: $(PYRF_OBJS)
329 python util/setup.py build --build-base='$(OUTPUT)'
330
327# 331#
328# No Perl scripts right now: 332# No Perl scripts right now:
329# 333#
@@ -349,7 +353,7 @@ PROGRAMS += $(OUTPUT)perf
349# 353#
350 354
351# what 'all' will build and 'install' will install, in perfexecdir 355# what 'all' will build and 'install' will install, in perfexecdir
352ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) 356ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) pyrf
353 357
354# what 'all' will build but not install in perfexecdir 358# what 'all' will build but not install in perfexecdir
355OTHER_PROGRAMS = $(OUTPUT)perf$X 359OTHER_PROGRAMS = $(OUTPUT)perf$X
@@ -520,6 +524,20 @@ BUILTIN_OBJS += $(OUTPUT)builtin-inject.o
520 524
521PERFLIBS = $(LIB_FILE) 525PERFLIBS = $(LIB_FILE)
522 526
527# Files needed for the python binding, perf.so
528# pyrf is just an internal name needed for all those wrappers.
529# This has to be in sync with what is in the 'sources' variable in
530# tools/perf/util/setup.py
531
532PYRF_OBJS += $(OUTPUT)util/cpumap.o
533PYRF_OBJS += $(OUTPUT)util/ctype.o
534PYRF_OBJS += $(OUTPUT)util/evlist.o
535PYRF_OBJS += $(OUTPUT)util/evsel.o
536PYRF_OBJS += $(OUTPUT)util/python.o
537PYRF_OBJS += $(OUTPUT)util/thread_map.o
538PYRF_OBJS += $(OUTPUT)util/util.o
539PYRF_OBJS += $(OUTPUT)util/xyarray.o
540
523# 541#
524# Platform specific tweaks 542# Platform specific tweaks
525# 543#