summaryrefslogtreecommitdiff
diff options
context:
space:
mode:
authorStéphane Veyret <s.veyret@overkiz.com>2022-06-13 11:42:35 +0200
committerStéphane Veyret <s.veyret@overkiz.com>2022-06-17 16:38:41 +0200
commit431f09eb196cacb72e4884a04b1c9b10ffff9ac8 (patch)
treea00739b998a53ae3d7a04fb0edeb16181d40b692
parentb61fade280d6124597a35c9f27a5c9ca1276d24c (diff)
downloadlibfaketime-431f09eb196cacb72e4884a04b1c9b10ffff9ac8.tar.gz
Reset shared memory when start time is reset
-rw-r--r--src/libfaketime.c23
1 files changed, 21 insertions, 2 deletions
diff --git a/src/libfaketime.c b/src/libfaketime.c
index d62a9f1..9d3bc06 100644
--- a/src/libfaketime.c
+++ b/src/libfaketime.c
@@ -710,6 +710,25 @@ static void next_time(struct timespec *tp, struct timespec *ticklen)
}
}
+static void reset_time()
+{
+ system_time_from_system(&ftpl_starttime);
+ if (shared_sem != NULL)
+ {
+ if (sem_wait(shared_sem) == -1)
+ {
+ perror("libfaketime: In reset_time(), sem_wait failed");
+ exit(1);
+ }
+ ft_shared->start_time = ftpl_starttime;
+ if (sem_post(shared_sem) == -1)
+ {
+ perror("libfaketime: In reset_time(), sem_post failed");
+ exit(1);
+ }
+ }
+}
+
/*
* =======================================================================
@@ -2533,7 +2552,7 @@ static void parse_ft_string(const char *user_faked_time)
/* Reset starttime */
if (NULL == getenv("FAKETIME_DONT_RESET"))
- system_time_from_system(&ftpl_starttime);
+ reset_time();
goto parse_modifiers;
break;
@@ -2561,7 +2580,7 @@ static void parse_ft_string(const char *user_faked_time)
}
}
if (NULL == getenv("FAKETIME_DONT_RESET"))
- system_time_from_system(&ftpl_starttime);
+ reset_time();
goto parse_modifiers;
break;