mirror of
https://github.com/ARM-software/devlib.git
synced 2025-04-04 17:00:03 +01:00
Support sending any signal to background commands, instead of only supporting properly SIGKILL/SIGTERM/SIGQUIT. The main issue is figuring out what PID to send the signal to, as the devlib API allows running a whole snippet of shell script that typically is wrapped under many layers of sh -c and sudo calls. In order to lift the ambiguity, the user has access to a "devlib-signal-target" command that points devlib at what process should be the target of signals: # Run a "setup" command, then the main command that will receive the # signals cmd = 'echo setup; devlib-signal-target echo hello world' with target.background(cmd) as bg: bg.communicate() The devlib-signal-target script can only be used once per background command, so that it is never ambiguous what process is targeted, and so that the Python code can cache the target PID. Subsequent invocations of devlib-signal-target will fail.
21 lines
783 B
Plaintext
21 lines
783 B
Plaintext
(
|
|
# If there is no data dir, it means we are not running as a background
|
|
# command so we just do nothing
|
|
if [ -e "$_DEVLIB_BG_CMD_DATA_DIR" ]; then
|
|
pid_file="$_DEVLIB_BG_CMD_DATA_DIR/pid"
|
|
# Atomically check if the PID file already exist and make the write
|
|
# fail if it already does. This way we don't have any race condition
|
|
# with the Python API, as there is either no PID or the same PID for
|
|
# the duration of the command
|
|
set -o noclobber
|
|
if ! printf "%u\n" $$ > "$pid_file"; then
|
|
echo "$0 was already called for this command" >&2
|
|
exit 1
|
|
fi
|
|
fi
|
|
) || exit $?
|
|
|
|
# Use exec so that the PID of the command we run is the same as the current $$
|
|
# PID that we just registered
|
|
exec "$@"
|