162306a36Sopenharmony_ci#!/bin/sh 262306a36Sopenharmony_ci# SPDX-License-Identifier: GPL-2.0 362306a36Sopenharmony_ci# description: event trigger - test histogram trigger 462306a36Sopenharmony_ci# requires: set_event events/sched/sched_process_fork/trigger events/sched/sched_process_fork/hist 562306a36Sopenharmony_ci# flags: instance 662306a36Sopenharmony_ci 762306a36Sopenharmony_cifail() { #msg 862306a36Sopenharmony_ci echo $1 962306a36Sopenharmony_ci exit_fail 1062306a36Sopenharmony_ci} 1162306a36Sopenharmony_ci 1262306a36Sopenharmony_ciecho "Test histogram basic trigger" 1362306a36Sopenharmony_ci 1462306a36Sopenharmony_ciecho 'hist:keys=parent_pid:vals=child_pid' > events/sched/sched_process_fork/trigger 1562306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 1662306a36Sopenharmony_cigrep parent_pid events/sched/sched_process_fork/hist > /dev/null || \ 1762306a36Sopenharmony_ci fail "hist trigger on sched_process_fork did not work" 1862306a36Sopenharmony_cigrep child events/sched/sched_process_fork/hist > /dev/null || \ 1962306a36Sopenharmony_ci fail "hist trigger on sched_process_fork did not work" 2062306a36Sopenharmony_ci 2162306a36Sopenharmony_cireset_trigger 2262306a36Sopenharmony_ci 2362306a36Sopenharmony_ciecho "Test histogram with compound keys" 2462306a36Sopenharmony_ci 2562306a36Sopenharmony_ciecho 'hist:keys=parent_pid,child_pid' > events/sched/sched_process_fork/trigger 2662306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 2762306a36Sopenharmony_cigrep '^{ parent_pid:.*, child_pid:.*}' events/sched/sched_process_fork/hist > /dev/null || \ 2862306a36Sopenharmony_ci fail "compound keys on sched_process_fork did not work" 2962306a36Sopenharmony_ci 3062306a36Sopenharmony_cireset_trigger 3162306a36Sopenharmony_ci 3262306a36Sopenharmony_ciecho "Test histogram with string key" 3362306a36Sopenharmony_ci 3462306a36Sopenharmony_ciecho 'hist:keys=parent_comm' > events/sched/sched_process_fork/trigger 3562306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 3662306a36Sopenharmony_ciCOMM=`cat /proc/$$/comm` 3762306a36Sopenharmony_cigrep "parent_comm: $COMM" events/sched/sched_process_fork/hist > /dev/null || \ 3862306a36Sopenharmony_ci fail "string key on sched_process_fork did not work" 3962306a36Sopenharmony_ci 4062306a36Sopenharmony_cireset_trigger 4162306a36Sopenharmony_ci 4262306a36Sopenharmony_ciecho "Test histogram with sym modifier" 4362306a36Sopenharmony_ci 4462306a36Sopenharmony_ciecho 'hist:keys=call_site.sym' > events/kmem/kmalloc/trigger 4562306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 4662306a36Sopenharmony_cigrep '{ call_site: \[[0-9a-f][0-9a-f]*\] [_a-zA-Z][_a-zA-Z]* *}' events/kmem/kmalloc/hist > /dev/null || \ 4762306a36Sopenharmony_ci fail "sym modifier on kmalloc call_site did not work" 4862306a36Sopenharmony_ci 4962306a36Sopenharmony_cireset_trigger 5062306a36Sopenharmony_ci 5162306a36Sopenharmony_ciecho "Test histogram with sym-offset modifier" 5262306a36Sopenharmony_ci 5362306a36Sopenharmony_ciecho 'hist:keys=call_site.sym-offset' > events/kmem/kmalloc/trigger 5462306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 5562306a36Sopenharmony_cigrep '{ 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 || \ 5662306a36Sopenharmony_ci fail "sym-offset modifier on kmalloc call_site did not work" 5762306a36Sopenharmony_ci 5862306a36Sopenharmony_cireset_trigger 5962306a36Sopenharmony_ci 6062306a36Sopenharmony_ciecho "Test histogram with sort key" 6162306a36Sopenharmony_ci 6262306a36Sopenharmony_ciecho 'hist:keys=parent_pid,child_pid:sort=child_pid.ascending' > events/sched/sched_process_fork/trigger 6362306a36Sopenharmony_cifor i in `seq 1 10` ; do ( echo "forked" > /dev/null); done 6462306a36Sopenharmony_ci 6562306a36Sopenharmony_cicheck_inc() { 6662306a36Sopenharmony_ci while [ $# -gt 1 ]; do 6762306a36Sopenharmony_ci [ $1 -gt $2 ] && return 1 6862306a36Sopenharmony_ci shift 1 6962306a36Sopenharmony_ci done 7062306a36Sopenharmony_ci return 0 7162306a36Sopenharmony_ci} 7262306a36Sopenharmony_cicheck_inc `grep -o "child_pid:[[:space:]]*[[:digit:]]*" \ 7362306a36Sopenharmony_ci events/sched/sched_process_fork/hist | cut -d: -f2 ` || 7462306a36Sopenharmony_ci fail "sort param on sched_process_fork did not work" 7562306a36Sopenharmony_ci 7662306a36Sopenharmony_ciexit 0 77