linux/tools/perf/tests/attr
Jiri Olsa fb50c09e92 perf tools: Fix crash on synthesizing the unit
Adam reported a record command crash for simple session like:

  $ perf record -e cpu-clock ls

with following backtrace:

  Program received signal SIGSEGV, Segmentation fault.
  3543            ev = event_update_event__new(size + 1, PERF_EVENT_UPDATE__UNIT, evsel->id[0]);
  (gdb) bt
  #0  perf_event__synthesize_event_update_unit
  #1  0x000000000051e469 in perf_event__synthesize_extra_attr
  #2  0x00000000004445cb in record__synthesize
  #3  0x0000000000444bc5 in __cmd_record
  ...

We synthesize an update event that needs to touch the evsel id array,
which is not defined at that time. Fix this by forcing the id allocation
for events with their unit defined.

Reflecting possible read_format ID bit in the attr tests.

Reported-by: Yongxin Liu <yongxin.liu@outlook.com>
Signed-off-by: Jiri Olsa <jolsa@kernel.org>
Cc: Adam Lee <leeadamrobert@gmail.com>
Cc: Alexander Shishkin <alexander.shishkin@linux.intel.com>
Cc: Namhyung Kim <namhyung@kernel.org>
Cc: Peter Zijlstra <peterz@infradead.org>
Bugzilla: https://bugzilla.kernel.org/show_bug.cgi?id=201477
Fixes: bfd8f72c27 ("perf record: Synthesize unit/scale/... in event update")
Link: http://lkml.kernel.org/r/20181112130012.5424-1-jolsa@kernel.org
Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com>
2018-11-12 08:37:49 -08:00
..
README perf test: Update command line callchain attribute tests 2013-11-01 10:42:57 -03:00
base-record perf tools: Fix crash on synthesizing the unit 2018-11-12 08:37:49 -08:00
base-stat perf tests attr: Fix stat sample_type setup 2017-07-18 23:14:21 -03:00
test-record-C0 perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-basic perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-branch-any perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-any perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-any_call perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-any_ret perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-hv perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-ind_call perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-k perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-branch-filter-u perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-count perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-data perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-freq perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-graph-default perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-graph-dwarf perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-graph-fp perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-group perf tests attr: Fix task term values 2017-10-02 13:59:18 -03:00
test-record-group-sampling perf tools: Do not zero sample_id_all for group members 2018-11-06 08:29:56 -03:00
test-record-group1 perf tests attr: Fix task term values 2017-10-02 13:59:18 -03:00
test-record-no-buffering perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-record-no-inherit perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-no-samples perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-period perf tests attr: Add proper return values 2017-07-18 23:14:19 -03:00
test-record-raw perf tests attr: Fix sample_period setup 2017-07-18 23:14:20 -03:00
test-stat-C0 perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-basic perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-default perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-detailed-1 perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-detailed-2 perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-detailed-3 perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00
test-stat-group perf tests attr: Fix group stat tests 2017-10-03 09:41:45 -03:00
test-stat-group1 perf tests attr: Fix group stat tests 2017-10-03 09:41:45 -03:00
test-stat-no-inherit perf tests attr: Make hw events optional 2017-10-23 11:20:54 -03:00

README

The struct perf_event_attr test (attr tests) support
====================================================
This testing support is embedded into perf directly and is governed
by the PERF_TEST_ATTR environment variable and hook inside the
sys_perf_event_open function.

The general idea is to store 'struct perf_event_attr' details for
each event created within single perf command. Each event details
are stored into separate text file. Once perf command is finished
these files are checked for values we expect for command.

The attr tests consist of following parts:

tests/attr.c
------------
This is the sys_perf_event_open hook implementation. The hook
is triggered when the PERF_TEST_ATTR environment variable is
defined. It must contain name of existing directory with access
and write permissions.

For each sys_perf_event_open call event details are stored in
separate file. Besides 'struct perf_event_attr' values we also
store 'fd' and 'group_fd' values to allow checking for groups.

tests/attr.py
-------------
This is the python script that does all the hard work. It reads
the test definition, executes it and checks results.

tests/attr/
-----------
Directory containing all attr test definitions.
Following tests are defined (with perf commands):

  perf record kill                              (test-record-basic)
  perf record -b kill                           (test-record-branch-any)
  perf record -j any kill                       (test-record-branch-filter-any)
  perf record -j any_call kill                  (test-record-branch-filter-any_call)
  perf record -j any_ret kill                   (test-record-branch-filter-any_ret)
  perf record -j hv kill                        (test-record-branch-filter-hv)
  perf record -j ind_call kill                  (test-record-branch-filter-ind_call)
  perf record -j k kill                         (test-record-branch-filter-k)
  perf record -j u kill                         (test-record-branch-filter-u)
  perf record -c 123 kill                       (test-record-count)
  perf record -d kill                           (test-record-data)
  perf record -F 100 kill                       (test-record-freq)
  perf record -g kill                           (test-record-graph-default)
  perf record --call-graph dwarf kill		(test-record-graph-dwarf)
  perf record --call-graph fp kill              (test-record-graph-fp)
  perf record --group -e cycles,instructions kill (test-record-group)
  perf record -e '{cycles,instructions}' kill   (test-record-group1)
  perf record -D kill                           (test-record-no-delay)
  perf record -i kill                           (test-record-no-inherit)
  perf record -n kill                           (test-record-no-samples)
  perf record -c 100 -P kill                    (test-record-period)
  perf record -R kill                           (test-record-raw)
  perf stat -e cycles kill                      (test-stat-basic)
  perf stat kill                                (test-stat-default)
  perf stat -d kill                             (test-stat-detailed-1)
  perf stat -dd kill                            (test-stat-detailed-2)
  perf stat -ddd kill                           (test-stat-detailed-3)
  perf stat --group -e cycles,instructions kill (test-stat-group)
  perf stat -e '{cycles,instructions}' kill     (test-stat-group1)
  perf stat -i -e cycles kill                   (test-stat-no-inherit)