Commit 47d200c6 authored by vkonyashkin's avatar vkonyashkin Committed by Pavel Emelyanov

zdtm: It's need to sleep between clock_gettime() in uptime_grow

Kernel can't suspend container by design if calls clock_gettime()
in a loop, so we need to sleep between clock_gettime().
Signed-off-by: 's avatarVictor Konyashkin  <vkonyashkin@parallels.com>
Acked-by: 's avatarAndrey Vagin <avagin@openvz.org>
Signed-off-by: 's avatarPavel Emelyanov <xemul@parallels.com>
parent 4ee52f34
...@@ -13,8 +13,11 @@ const char *test_author = "Evgeny Antysev <eantyshev@parallels.com>"; ...@@ -13,8 +13,11 @@ const char *test_author = "Evgeny Antysev <eantyshev@parallels.com>";
int main(int argc, char **argv) int main(int argc, char **argv)
{ {
struct timespec tm_old, tm; struct timespec tm_old, tm, ts;
double diff_nsec; double diff_nsec;
ts.tv_sec = 0;
ts.tv_nsec = 1000000;
test_init(argc, argv); test_init(argc, argv);
if (clock_gettime(CLOCK_MONOTONIC, &tm_old)) { if (clock_gettime(CLOCK_MONOTONIC, &tm_old)) {
...@@ -36,6 +39,12 @@ int main(int argc, char **argv) ...@@ -36,6 +39,12 @@ int main(int argc, char **argv)
exit(1); exit(1);
} }
tm_old = tm; tm_old = tm;
/*
Kernel can't suspend container by design if calls
clock_gettime() in a loop, so we need to sleep
between clock_gettime().
*/
nanosleep(&ts, NULL);
} }
pass(); pass();
return 0; return 0;
......
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