44 lines
1.2 KiB
Bash
44 lines
1.2 KiB
Bash
#!/bin/sh
|
|
# SPDX-License-Identifier: GPL-2.0
|
|
# description: ftrace - function graph print function return value
|
|
# requires: options/funcgraph-retval options/funcgraph-retval-hex function_graph:tracer
|
|
|
|
# Make sure that funcgraph-retval works
|
|
|
|
fail() { # msg
|
|
echo $1
|
|
exit_fail
|
|
}
|
|
|
|
disable_tracing
|
|
clear_trace
|
|
|
|
# get self PID, can not use $$, because it is PPID
|
|
read PID _ < /proc/self/stat
|
|
|
|
[ -f set_ftrace_filter ] && echo proc_reg_write > set_ftrace_filter
|
|
[ -f set_ftrace_pid ] && echo ${PID} > set_ftrace_pid
|
|
echo function_graph > current_tracer
|
|
echo 1 > options/funcgraph-retval
|
|
|
|
set +e
|
|
enable_tracing
|
|
echo > /proc/interrupts
|
|
disable_tracing
|
|
set -e
|
|
|
|
: "Test printing the error code in signed decimal format"
|
|
echo 0 > options/funcgraph-retval-hex
|
|
count=`cat trace | grep 'proc_reg_write' | grep '= -5' | wc -l`
|
|
if [ $count -eq 0 ]; then
|
|
fail "Return value can not be printed in signed decimal format"
|
|
fi
|
|
|
|
: "Test printing the error code in hexadecimal format"
|
|
echo 1 > options/funcgraph-retval-hex
|
|
count=`cat trace | grep 'proc_reg_write' | grep 'fffffffb' | wc -l`
|
|
if [ $count -eq 0 ]; then
|
|
fail "Return value can not be printed in hexadecimal format"
|
|
fi
|
|
|
|
exit 0
|