DOKK / manpages / debian 12 / rt-tests / pi_stress.8.en
pi_stress(8) Linux System Administrator's Manual pi_stress(8)

pi_stress - a stress test for POSIX Priority Inheritance mutexes

pi_stress [-d|--debug] [-D|--duration [-g|--groups N] [-i|--inversions INV] [--json FILENAME] [-m|--mlockall] [-p|--prompt] [-q|--quiet] [-r|--rr] [-s|--sched OPTS] [-u|--uniprocessor] [-v|--verbose] [-V|--version]

pi_stress is a program used to stress the priority-inheritance code paths for POSIX mutexes, in both the Linux kernel and the C library. It runs as a realtime-priority task and launches inversion machine thread groups. Each inversion group causes a priority inversion condition that will deadlock if priority inheritance doesn't work.

Run in debug mode; lots of extra prints
Specify a length for the test run.
Append 'm', 'h', or 'd' to specify minutes, hours or days.
The number of inversion groups to run. Defaults to 10.
Display a short help message and options.
N number of inversion conditions. This is the total number of inversions for all inversion groups. Default is -1 for infinite.
Write final results into FILENAME , JSON formatted.
Call mlockall to lock current and future memory allocations and prevent being paged out
Prompt before actually starting the stress test
Suppress running output
Run inversion group threads as SCHED_RR (round-robin). The default is to run the inversion threads as SCHED_FIFO.
scheduling options per thread type:
id=[high|med|low],
policy=[fifo,rr],priority=N,
policy=deadline,runtime=N,deadline=N,period=N
Run all threads on one processor. The default is to run all inversion group threads on one processor and the admin threads (reporting thread, keyboard reader, etc.) on a different processor.
Run with verbose messages
Print version number

The pi_stress test threads run as SCHED_FIFO or SCHED_RR threads, which means that they can starve critical system threads. It is advisable to change the scheduling policy of critical system threads to be SCHED_FIFO prior to running pi_stress and use a priority of 10 or higher, to prevent those threads from being starved by the stress test.

No documented bugs.

Clark Williams <williams@redhat.com>

November 27, 2006