[Pm-utils] [PATCH v2] Do not inhibit further power.d hooks if one fails
Chase Douglas
chase.douglas at ubuntu.com
Thu Mar 25 12:09:49 PDT 2010
From: Chase Douglas <chase.douglas at canonical.com>
Sleep hooks are dependency ordered, so we must bail if any hook fails.
However, powersave hooks generally do not have any dependencies. It
makes more sense to allow all powersave hooks to run even if one of them
fails.
Signed-off-by: Chase Douglas <chase.douglas at canonical.com>
---
pm/pm-functions.in | 19 ++++++++++++-------
src/pm-action.in | 6 +++---
src/pm-powersave.in | 6 +++---
3 files changed, 18 insertions(+), 13 deletions(-)
diff --git a/pm/pm-functions.in b/pm/pm-functions.in
index dfbc59f..35c9dfe 100644
--- a/pm/pm-functions.in
+++ b/pm/pm-functions.in
@@ -193,11 +193,15 @@ hook_ok()
}
_run_hook() {
- # $1 = hook to run
+ # $1 = "inhibit" or "advance" further hooks after a hook failure
+ # $2 = hook to run
# rest of args passed to hook unchanged.
+ local do_inhibit=$1
+ shift
log -n "$*:"
hook_ok "$1" && "$@"
- hook_exit_status $? && LAST_HOOK="${1##*/}" || inhibit
+ hook_exit_status $? && LAST_HOOK="${1##*/}"
+ [ $? -ne 0 -a "$do_inhibit" = "inhibit" ] && inhibit
}
if profiling; then
@@ -210,7 +214,8 @@ fi
_run_hooks() {
# $1 = type of hook to find.
# $2 = paramaters to pass to hooks.
- # $3 = if present and equal to "reverse", run hooks backwards.
+ # $3 = "inhibit" or "advance" further hooks after a hook failure
+ # $4 = if present and equal to "reverse", run hooks backwards.
# Currently only power and sleep are meaningful.
local syshooks="${PM_UTILS_ETCDIR}/$1.d"
local phooks="${PM_UTILS_LIBDIR}/$1.d"
@@ -223,25 +228,25 @@ _run_hooks() {
local nifs="
"
IFS="${nifs}" # tolerate spaces in filenames.
- [ "$3" = "reverse" ] && sort="sort -r"
+ [ "$4" = "reverse" ] && sort="sort -r"
for base in $(IFS="${oifs}"; for f in "$syshooks/"*[!~] "$phooks/"*[!~];
do [ -O "$f" ] && echo ${f##*/} ; done | $sort | uniq) ;
do
IFS="${oifs}"
# if we are running backwards, skip hooks that we did not
# run going forwards due to a hook failing.
- [ "$3" -a "$3" = "reverse" -a "$LAST_HOOK" ] && \
+ [ "$4" -a "$4" = "reverse" -a "$LAST_HOOK" ] && \
[ "$base" \> "$LAST_HOOK" ] && continue
# if we have already inhibited suspend/resume,
# don't run any more hooks.
- [ ! "$3" ] && inhibited && break
+ [ ! "$4" ] && inhibited && break
update_parameters
if [ -f "$syshooks/$base" ]; then
hook="$syshooks/$base"
elif [ -f "$phooks/$base" ]; then
hook="$phooks/$base"
fi
- run_hook "$hook" $2
+ run_hook $3 "$hook" $2
IFS="${nifs}"
done
IFS="${oifs}"
diff --git a/src/pm-action.in b/src/pm-action.in
index e148585..3d89ab6 100755
--- a/src/pm-action.in
+++ b/src/pm-action.in
@@ -37,7 +37,7 @@ help()
echo "${0##*/} [options]"
echo
echo "Options can change how suspend or hibernate is done."
- run_hooks sleep help
+ run_hooks sleep help advance
sleep_module_help
exit 0
}
@@ -96,7 +96,7 @@ load_hook_parameters
# run the sleep hooks
log "$(date): Running hooks for $ACTION."
-if run_hooks sleep "$ACTION $METHOD"; then
+if run_hooks sleep "$ACTION $METHOD" inhibit; then
# Sleep only if we know how and if a hook did not inhibit us.
log "$(date): performing $METHOD"
sync
@@ -107,7 +107,7 @@ else
fi
log "$(date): Running hooks for $REVERSE"
# run the sleep hooks in reverse with the wakeup action
-if run_hooks sleep "$REVERSE $METHOD" reverse; then
+if run_hooks sleep "$REVERSE $METHOD" inhibit reverse; then
log "$(date): Finished."
else
exit $((r+1))
diff --git a/src/pm-powersave.in b/src/pm-powersave.in
index 08e4f5b..e0a4b8d 100644
--- a/src/pm-powersave.in
+++ b/src/pm-powersave.in
@@ -42,14 +42,14 @@ load_hook_blacklist
if [ "$1" = "true" -o "$1" = "false" ] ; then
init_logfile "${PM_LOGFILE}"
- run_hooks power "$1"
+ run_hooks power "$1" advance
elif [ ! "$1" ]; then
# no arg? Guess!
init_logfile "${PM_LOGFILE}"
if on_ac_power; then
- run_hooks power false;
+ run_hooks power false advance;
else
- run_hooks power true;
+ run_hooks power true advance;
fi
else
echo "Argument needs to be true or false" >&2
--
1.7.0
More information about the Pm-utils
mailing list