diff options
author | Arnaldo Carvalho de Melo <acme@redhat.com> | 2011-01-29 12:44:29 -0500 |
---|---|---|
committer | Arnaldo Carvalho de Melo <acme@redhat.com> | 2011-01-30 08:37:38 -0500 |
commit | 877108e42b1b9ba64857c4030cf356ecc120fd18 (patch) | |
tree | ca41fa741081faa0f936b7296d721c84d1b89176 /tools/perf/Makefile | |
parent | 8115d60c323dd9931b95221c0a392aeddc1d6ef3 (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/Makefile | 20 |
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 = | |||
315 | COMPAT_OBJS = | 315 | COMPAT_OBJS = |
316 | LIB_H = | 316 | LIB_H = |
317 | LIB_OBJS = | 317 | LIB_OBJS = |
318 | PYRF_OBJS = | ||
318 | SCRIPT_PERL = | 319 | SCRIPT_PERL = |
319 | SCRIPT_SH = | 320 | SCRIPT_SH = |
320 | TEST_PROGRAMS = | 321 | TEST_PROGRAMS = |
@@ -324,6 +325,9 @@ SCRIPT_SH += perf-archive.sh | |||
324 | grep-libs = $(filter -l%,$(1)) | 325 | grep-libs = $(filter -l%,$(1)) |
325 | strip-libs = $(filter-out -l%,$(1)) | 326 | strip-libs = $(filter-out -l%,$(1)) |
326 | 327 | ||
328 | pyrf: $(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 |
352 | ALL_PROGRAMS = $(PROGRAMS) $(SCRIPTS) | 356 | ALL_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 |
355 | OTHER_PROGRAMS = $(OUTPUT)perf$X | 359 | OTHER_PROGRAMS = $(OUTPUT)perf$X |
@@ -520,6 +524,20 @@ BUILTIN_OBJS += $(OUTPUT)builtin-inject.o | |||
520 | 524 | ||
521 | PERFLIBS = $(LIB_FILE) | 525 | PERFLIBS = $(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 | |||
532 | PYRF_OBJS += $(OUTPUT)util/cpumap.o | ||
533 | PYRF_OBJS += $(OUTPUT)util/ctype.o | ||
534 | PYRF_OBJS += $(OUTPUT)util/evlist.o | ||
535 | PYRF_OBJS += $(OUTPUT)util/evsel.o | ||
536 | PYRF_OBJS += $(OUTPUT)util/python.o | ||
537 | PYRF_OBJS += $(OUTPUT)util/thread_map.o | ||
538 | PYRF_OBJS += $(OUTPUT)util/util.o | ||
539 | PYRF_OBJS += $(OUTPUT)util/xyarray.o | ||
540 | |||
523 | # | 541 | # |
524 | # Platform specific tweaks | 542 | # Platform specific tweaks |
525 | # | 543 | # |