2 # SPDX-License-Identifier: GPL-2.0
3 # description: event trigger - test histogram trigger
4 # requires: set_event events/sched/sched_process_fork/trigger events/sched/sched_process_fork/hist
12 echo "Test histogram basic trigger"
14 echo 'hist:keys=parent_pid:vals=child_pid' > events/sched/sched_process_fork/trigger
15 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
16 grep parent_pid events/sched/sched_process_fork/hist > /dev/null || \
17 fail "hist trigger on sched_process_fork did not work"
18 grep child events/sched/sched_process_fork/hist > /dev/null || \
19 fail "hist trigger on sched_process_fork did not work"
23 echo "Test histogram with compound keys"
25 echo 'hist:keys=parent_pid,child_pid' > events/sched/sched_process_fork/trigger
26 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
27 grep '^{ parent_pid:.*, child_pid:.*}' events/sched/sched_process_fork/hist > /dev/null || \
28 fail "compound keys on sched_process_fork did not work"
32 echo "Test histogram with string key"
34 echo 'hist:keys=parent_comm' > events/sched/sched_process_fork/trigger
35 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
36 COMM=`cat /proc/$$/comm`
37 grep "parent_comm: $COMM" events/sched/sched_process_fork/hist > /dev/null || \
38 fail "string key on sched_process_fork did not work"
42 echo "Test histogram with sym modifier"
44 echo 'hist:keys=call_site.sym' > events/kmem/kmalloc/trigger
45 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
46 grep '{ call_site: \[[0-9a-f][0-9a-f]*\] [_a-zA-Z][_a-zA-Z]* *}' events/kmem/kmalloc/hist > /dev/null || \
47 fail "sym modifier on kmalloc call_site did not work"
51 echo "Test histogram with sym-offset modifier"
53 echo 'hist:keys=call_site.sym-offset' > events/kmem/kmalloc/trigger
54 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
55 grep '{ call_site: \[[0-9a-f][0-9a-f]*\] [_a-zA-Z][_a-zA-Z]*+0x[0-9a-f][0-9a-f]*' events/kmem/kmalloc/hist > /dev/null || \
56 fail "sym-offset modifier on kmalloc call_site did not work"
60 echo "Test histogram with sort key"
62 echo 'hist:keys=parent_pid,child_pid:sort=child_pid.ascending' > events/sched/sched_process_fork/trigger
63 for i in `seq 1 10` ; do ( echo "forked" > /dev/null); done
66 while [ $# -gt 1 ]; do
67 [ $1 -gt $2 ] && return 1
72 check_inc `grep -o "child_pid:[[:space:]]*[[:digit:]]*" \
73 events/sched/sched_process_fork/hist | cut -d: -f2 ` ||
74 fail "sort param on sched_process_fork did not work"