summaryrefslogtreecommitdiff
path: root/src
diff options
context:
space:
mode:
authorHans Dedecker <hans.dedecker@technicolor.com>2016-01-26 09:20:33 +0100
committerHans Dedecker <hans.dedecker@technicolor.com>2016-01-26 10:43:35 +0100
commite23f12f59182bec966c79c65dec034b8084ff8db (patch)
treea73a6dd703e80e0bdfa8cc239e445c60dde92aa3 /src
parentdc186d6d2b0dd4ad23ca5fc69c00e81f796ff6d9 (diff)
downloadodhcp6c-e23f12f59182bec966c79c65dec034b8084ff8db.tar.gz
script: Launch script with correct action if last script call is terminated
Actions launched as resume will be used in a next script_call if the new action is not marked as resume even when the previous script run was already terminated. This behavior is particular visible when a RA is received as the script will run with action bound and not ra-updated resulting into a wan6 interface down/up transition
Diffstat (limited to 'src')
-rw-r--r--src/script.c4
1 files changed, 3 insertions, 1 deletions
diff --git a/src/script.c b/src/script.c
index 3d313cf..f272c19 100644
--- a/src/script.c
+++ b/src/script.c
@@ -353,13 +353,15 @@ static void s46_to_env(enum odhcp6c_state state, const uint8_t *data, size_t len
void script_call(const char *status, int delay, bool resume)
{
time_t now = odhcp6c_get_milli_time() / 1000;
+ bool running_script = false;
if (running) {
kill(running, SIGTERM);
delay -= now - started;
+ running_script = true;
}
- if (resume || !action[0])
+ if (resume || !running_script || !action[0])
strncpy(action, status, sizeof(action) - 1);
pid_t pid = fork();