Commit 81088819 authored by Frank Munzert's avatar Frank Munzert Committed by Martin Schwidefsky

[S390] shutdown actions: save/return rc from init function

We always returned -EINVAL when setting of a shutdown action failed. This was
misleading, if for example the hardware did not support the shutdown action.
Now we save each shutdown action's init return code and return it when the
action is being set.
Signed-off-by: default avatarFrank Munzert <munzert@de.ibm.com>
Signed-off-by: default avatarMartin Schwidefsky <schwidefsky@de.ibm.com>
parent aeec92ca
...@@ -70,6 +70,7 @@ struct shutdown_action { ...@@ -70,6 +70,7 @@ struct shutdown_action {
char *name; char *name;
void (*fn) (struct shutdown_trigger *trigger); void (*fn) (struct shutdown_trigger *trigger);
int (*init) (void); int (*init) (void);
int init_rc;
}; };
static char *ipl_type_str(enum ipl_type type) static char *ipl_type_str(enum ipl_type type)
...@@ -1486,11 +1487,13 @@ static int set_trigger(const char *buf, struct shutdown_trigger *trigger, ...@@ -1486,11 +1487,13 @@ static int set_trigger(const char *buf, struct shutdown_trigger *trigger,
int i; int i;
for (i = 0; i < SHUTDOWN_ACTIONS_COUNT; i++) { for (i = 0; i < SHUTDOWN_ACTIONS_COUNT; i++) {
if (!shutdown_actions_list[i])
continue;
if (sysfs_streq(buf, shutdown_actions_list[i]->name)) { if (sysfs_streq(buf, shutdown_actions_list[i]->name)) {
trigger->action = shutdown_actions_list[i]; if (shutdown_actions_list[i]->init_rc) {
return len; return shutdown_actions_list[i]->init_rc;
} else {
trigger->action = shutdown_actions_list[i];
return len;
}
} }
} }
return -EINVAL; return -EINVAL;
...@@ -1640,8 +1643,8 @@ static void __init shutdown_actions_init(void) ...@@ -1640,8 +1643,8 @@ static void __init shutdown_actions_init(void)
for (i = 0; i < SHUTDOWN_ACTIONS_COUNT; i++) { for (i = 0; i < SHUTDOWN_ACTIONS_COUNT; i++) {
if (!shutdown_actions_list[i]->init) if (!shutdown_actions_list[i]->init)
continue; continue;
if (shutdown_actions_list[i]->init()) shutdown_actions_list[i]->init_rc =
shutdown_actions_list[i] = NULL; shutdown_actions_list[i]->init();
} }
} }
......
Markdown is supported
0%
or
You are about to add 0 people to the discussion. Proceed with caution.
Finish editing this message first!
Please register or to comment