[<prev] [next>] [thread-next>] [day] [month] [year] [list]
Message-Id: <1380113447-17144-1-git-send-email-jolsa@redhat.com>
Date:	Wed, 25 Sep 2013 14:50:26 +0200
From:	Jiri Olsa <jolsa@...hat.com>
To:	linux-kernel@...r.kernel.org
Cc:	Jiri Olsa <jolsa@...hat.com>,
	Arnaldo Carvalho de Melo <acme@...hat.com>,
	Corey Ashford <cjashfor@...ux.vnet.ibm.com>,
	Frederic Weisbecker <fweisbec@...il.com>,
	Ingo Molnar <mingo@...e.hu>, Paul Mackerras <paulus@...ba.org>,
	Peter Zijlstra <a.p.zijlstra@...llo.nl>,
	Don Zickus <dzickus@...hat.com>,
	Andi Kleen <ak@...ux.jf.intel.com>,
	Adrian Hunter <adrian.hunter@...el.com>,
	Stephane Eranian <eranian@...gle.com>
Subject: [RFC 00/21] perf tools: Add toggling events support
hi,
sending *RFC* for toggling events support.
Adding perf interface that allows to create toggle events, which can
enable or disable another event. Whenever the toggle event is triggered
(has overflow), it toggles another event state and either starts or
stops it.
The goal is to be able to create toggling tracepoint events to enable and
disable HW counters, but the interface is generic enough to be used for
any kind of event. 
It's based on the Frederic's patchset:
https://lkml.org/lkml/2011/3/14/346
Most of the changelogs info is on wiki:
https://perf.wiki.kernel.org/index.php/Jolsa_Features_Togle_Event
In a nutshell:
  The interface is added to the sys_perf_event_open syscall
  and new ioctl was added for completeness, check:
    perf: Add event toggle sys_perf_event_open interface
    perf: Add event toggle ioctl interface
  The perf tool interface is pretty rough at the moment. We use
  'on' and 'off' terms to specify the toggling event, like:
    -e 'cycles,irq_entry/on=cycles/,irq_exit/off=cycles/'
  Meaning:
    - irq_entry toggles on (starts) cycles, and irq_exit toggled off (stops) cycles.
    - cycles is started as paused 
   Looking forward to some ideas for better interface in here ;-)
The patchset is available at:
git://git.kernel.org/pub/scm/linux/kernel/git/jolsa/perf.git
perf/core_toggle
thanks for comments,
jirka
Example:
  Define toggle(on/off) events: 
    # perf probe -a fork_entry=do_fork
    # perf probe -a fork_exit=do_fork%return
  Following record session samples only within do_fork function: 
    # perf record -g -e '{cycles,cache-misses}:k,probe:fork_entry/on=cycles/,probe:fork_exit/off=cycles/' \ 
      perf bench sched messaging
  Following stat session measure cycles within do_fork function: 
    # perf stat -e '{cycles,cache-misses}:k,probe:fork_entry/on=cycles/,probe:fork_exit/off=cycles/' \ 
      perf bench sched messaging
      # Running sched/messaging benchmark...
      # 20 sender and receiver processes per group
      # 1 groups == 40 processes run
           Total time: 0.073 [sec]
       Performance counter stats for './perf bench sched messaging -g 1':
              20,935,464 cycles                    #    0.000 GHz
                  18,897 cache-misses
                      40 probe:fork_entry
                      40 probe:fork_exit
             0.086319682 seconds time elapsed
Example:
  Measure interrupts cycles:
  # ./perf stat -e 'cycles,cycles/name=cycles_irq/,irq:irq_handler_entry/on=cycles_irq/,irq:irq_handler_exit/off=cycles_irq/' -a sleep 10
   Performance counter stats for 'sleep 10':
      50,680,084,994 cycles                    #    0.000 GHz                     [100.00%]
             652,690 cycles_irq                #    0.000 GHz                    
                  33 irq:irq_handler_entry                                        [100.00%]
                  33 irq:irq_handler_exit                                        
        10.002084400 seconds time elapsed
Check uprobes example at:
https://perf.wiki.kernel.org/index.php/Jolsa_Features_Togle_Event#Example_-_using_u.28ret.29probes
Signed-off-by: Frederic Weisbecker <fweisbec@...il.com>
Signed-off-by: Jiri Olsa <jolsa@...hat.com>
Cc: Arnaldo Carvalho de Melo <acme@...hat.com>
Cc: Corey Ashford <cjashfor@...ux.vnet.ibm.com>
Cc: Frederic Weisbecker <fweisbec@...il.com>
Cc: Ingo Molnar <mingo@...e.hu>
Cc: Paul Mackerras <paulus@...ba.org>
Cc: Peter Zijlstra <a.p.zijlstra@...llo.nl>
Cc: Arnaldo Carvalho de Melo <acme@...hat.com>
Cc: Don Zickus <dzickus@...hat.com>
Cc: Andi Kleen <ak@...ux.jf.intel.com>
Cc: Adrian Hunter <adrian.hunter@...el.com>
Cc: Stephane Eranian <eranian@...gle.com>
---
Frederic Weisbecker (2):
      perf: Be more specific on pmu related event init naming
      perf: Split allocation and initialization code
Jiri Olsa (19):
      perf tools: Introduce perf_evlist__wait_workload function
      perf tools: Separate sys_perf_event_open call into evsel_open
      perf x86: Update event count properly for read syscall
      perf: Move event state initialization before/behind the pmu add/del calls
      perf: Add event toggle sys_perf_event_open interface
      perf: Add event toggle ioctl interface
      perf: Toggle whole group in toggle event overflow
      perf: Add new 'paused' attribute
      perf: Account toggle masters for toggled event
      perf: Support event inheritance for toggle feature
      perf tests: Adding event simple toggling test
      perf tests: Adding event group toggling test
      perf tests: Adding event inherit toggling test
      perf tools: Allow numeric event to change name via name term
      perf tools: Add event_config_optional parsing rule
      perf tools: Rename term related parsing function/variable properly
      perf tools: Carry term string value for symbols events
      perf tools: Add support to parse event on/off toggle terms
      perf tools: Add record/stat support for toggling events
 arch/x86/kernel/cpu/perf_event.c                |   6 +-
 include/linux/perf_event.h                      |  12 +++
 include/uapi/linux/perf_event.h                 |   7 +-
 kernel/events/core.c                            | 396 ++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++++---------
 tools/perf/Makefile                             |   6 ++
 tools/perf/arch/x86/tests/toggle-event-raw-64.S |  28 ++++++
 tools/perf/builtin-record.c                     |   7 ++
 tools/perf/builtin-stat.c                       |  12 +++
 tools/perf/tests/builtin-test.c                 |  12 +++
 tools/perf/tests/perf-record.c                  |   1 +
 tools/perf/tests/task-exit.c                    |   5 ++
 tools/perf/tests/tests.h                        |   3 +
 tools/perf/tests/toggle-event-group.c           | 195 +++++++++++++++++++++++++++++++++++++++++
 tools/perf/tests/toggle-event-inherit.c         | 132 ++++++++++++++++++++++++++++
 tools/perf/tests/toggle-event-raw.c             | 106 ++++++++++++++++++++++
 tools/perf/util/evlist.c                        |  97 +++++++++++++++++++++
 tools/perf/util/evlist.h                        |   3 +
 tools/perf/util/evsel.c                         |  53 ++++++-----
 tools/perf/util/evsel.h                         |   4 +
 tools/perf/util/parse-events.c                  | 131 +++++++++++++++++++---------
 tools/perf/util/parse-events.h                  |   9 +-
 tools/perf/util/parse-events.l                  |   6 +-
 tools/perf/util/parse-events.y                  |  68 +++++++++------
 tools/perf/util/record.c                        |   2 +
 24 files changed, 1167 insertions(+), 134 deletions(-)
 create mode 100644 tools/perf/arch/x86/tests/toggle-event-raw-64.S
 create mode 100644 tools/perf/tests/toggle-event-group.c
 create mode 100644 tools/perf/tests/toggle-event-inherit.c
 create mode 100644 tools/perf/tests/toggle-event-raw.c
--
To unsubscribe from this list: send the line "unsubscribe linux-kernel" in
the body of a message to majordomo@...r.kernel.org
More majordomo info at  http://vger.kernel.org/majordomo-info.html
Please read the FAQ at  http://www.tux.org/lkml/
Powered by blists - more mailing lists
 
