forked from Minki/linux
774cb499ca
Currently the record command sets all events initially as disabled. There's non conditional perf_evlist__enable call, that enables all events before we exec tracee program. That actually screws whole enable_on_exec logic, because the event is enabled before the traced program got executed. What we actually want is: 1) For any type of traced program: - all independent events and group leaders are disabled - all group members are enabled Group members are ruled by group leaders. They need to be enabled, because the group scheduling relies on that. 2) For traced programs executed by perf: - all independent events and group leaders have enable_on_exec set - we don't specifically enable or disable any event during the record command Independent events and group leaders are initially disabled and get enabled by exec. Group members are ruled by group leaders as stated in 1). 3) For traced programs attached by perf (pid/tid): - we specifically enable or disable all events during the record command When attaching events to already running traced we enable/disable events specifically, as there's no initial traced exec call. Fixing appropriate perf_event_attr test case to cover this change. Signed-off-by: Jiri Olsa <jolsa@redhat.com> Acked-by: Namhyung Kim <namhyung@kernel.org> Cc: Corey Ashford <cjashfor@linux.vnet.ibm.com> Cc: Frederic Weisbecker <fweisbec@gmail.com> Cc: Ingo Molnar <mingo@elte.hu> Cc: Paul Mackerras <paulus@samba.org> Cc: Peter Zijlstra <a.p.zijlstra@chello.nl> Link: http://lkml.kernel.org/r/1352741644-16809-3-git-send-email-jolsa@redhat.com Signed-off-by: Arnaldo Carvalho de Melo <acme@redhat.com> |
||
---|---|---|
.. | ||
base-record | ||
base-stat | ||
README | ||
test-record-basic | ||
test-record-branch-any | ||
test-record-branch-filter-any | ||
test-record-branch-filter-any_call | ||
test-record-branch-filter-any_ret | ||
test-record-branch-filter-hv | ||
test-record-branch-filter-ind_call | ||
test-record-branch-filter-k | ||
test-record-branch-filter-u | ||
test-record-count | ||
test-record-data | ||
test-record-freq | ||
test-record-graph-default | ||
test-record-graph-dwarf | ||
test-record-graph-fp | ||
test-record-group | ||
test-record-group1 | ||
test-record-no-delay | ||
test-record-no-inherit | ||
test-record-no-samples | ||
test-record-period | ||
test-record-raw | ||
test-stat-basic | ||
test-stat-default | ||
test-stat-detailed-1 | ||
test-stat-detailed-2 | ||
test-stat-detailed-3 | ||
test-stat-group | ||
test-stat-group1 | ||
test-stat-no-inherit |
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 -g dwarf -- kill (test-record-graph-dwarf) perf record -g 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)