blob: 2404772e863cd2ffe2ccccbd472e2bfd9e343d00 [file] [log] [blame]
#!/bin/sh -e
# cyclicdeadline is a test that is similar to cyclictest but instead
# of using SCHED_FIFO and nanosleep() to measure jitter, it uses
# SCHED_DEADLINE and has the deadline be the wakeup interval."
# shellcheck disable=SC1091
. ../../lib/sh-test-lib
OUTPUT="$(pwd)/output"
LOGFILE="${OUTPUT}/cyclicdeadline.txt"
RESULT_FILE="${OUTPUT}/result.txt"
INTERVAL="1000"
STEP="500"
THREADS="1"
DURATION="1m"
MAX_LATENCY="50"
usage() {
echo "Usage: $0 [-i interval] [-s step] [-t threads] [-D duration ] [-m latency]" 1>&2
exit 1
}
while getopts ":i:s:t:D:m:" opt; do
case "${opt}" in
i) INTERVAL="${OPTARG}" ;;
s) STEP="${STEP}" ;;
t) THREADS="${OPTARG}" ;;
D) DURATION="${OPTARG}" ;;
m) MAX_LATENCY="${OPTARG}" ;;
*) usage ;;
esac
done
! check_root && error_msg "Please run this script as root."
create_out_dir "${OUTPUT}"
# Run cyclicdeadline.
if ! binary=$(command -v cyclicdeadline); then
detect_abi
# shellcheck disable=SC2154
binary="./bin/${abi}/cyclicdeadline"
fi
"${binary}" -i "${INTERVAL}" -s "${STEP}" -t "${THREADS}" \
-D "${DURATION}" | tee "${LOGFILE}"
# Parse test log.
../../lib/parse_rt_tests_results.py cyclicdeadline "${LOGFILE}" "${MAX_LATENCY}" \
| tee -a "${RESULT_FILE}"