From 57c48453496c3900ff6265751056f61718cbf80c Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Wed, 25 Oct 2023 14:39:27 +0200 Subject: [PATCH 1/4] fix: switch to wall time measurement in ping tests --- examples/unix/c11/z_ping.c | 16 ++++++++-------- examples/unix/c99/z_ping.c | 16 ++++++++-------- examples/windows/z_ping.c | 16 ++++++++-------- 3 files changed, 24 insertions(+), 24 deletions(-) diff --git a/examples/unix/c11/z_ping.c b/examples/unix/c11/z_ping.c index d3853d475..c9755d6fc 100644 --- a/examples/unix/c11/z_ping.c +++ b/examples/unix/c11/z_ping.c @@ -94,23 +94,23 @@ int main(int argc, char** argv) { _z_mutex_lock(&mutex); if (args.warmup_ms) { printf("Warming up for %dms...\n", args.warmup_ms); - clock_t warmup_end = clock() + CLOCKS_PER_SEC * args.warmup_ms / 1000; - for (clock_t now = clock(); now < warmup_end; now = clock()) { + z_clock_t warmup_start = z_clock_now(); + unsigned long elapsed_us = 0; + while (elapsed_us < args.warmup_ms * 1000) { z_publisher_put(z_loan(pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); + elapsed_us = z_clock_elapsed_us(&warmup_start); } } - clock_t* results = z_malloc(sizeof(clock_t) * args.number_of_pings); + unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t start = clock(); + z_clock_t measure_start = z_clock_now(); z_publisher_put(z_loan(pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); - clock_t end = clock(); - results[i] = end - start; + results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t rtt = results[i] * 1000000 / CLOCKS_PER_SEC; - printf("%d bytes: seq=%d rtt=%ldµs lat=%ldµs\n", args.size, i, rtt, rtt / 2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); } _z_mutex_unlock(&mutex); z_free(results); diff --git a/examples/unix/c99/z_ping.c b/examples/unix/c99/z_ping.c index 451a8fc30..4627bc427 100644 --- a/examples/unix/c99/z_ping.c +++ b/examples/unix/c99/z_ping.c @@ -94,23 +94,23 @@ int main(int argc, char** argv) { _z_mutex_lock(&mutex); if (args.warmup_ms) { printf("Warming up for %dms...\n", args.warmup_ms); - clock_t warmup_end = clock() + CLOCKS_PER_SEC * args.warmup_ms / 1000; - for (clock_t now = clock(); now < warmup_end; now = clock()) { + z_clock_t warmup_start = z_clock_now(); + unsigned long elapsed_us = 0; + while (elapsed_us < args.warmup_ms * 1000) { z_publisher_put(z_publisher_loan(&pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); + elapsed_us = z_clock_elapsed_us(&warmup_start); } } - clock_t* results = z_malloc(sizeof(clock_t) * args.number_of_pings); + unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t start = clock(); + z_clock_t measure_start = z_clock_now(); z_publisher_put(z_publisher_loan(&pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); - clock_t end = clock(); - results[i] = end - start; + results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t rtt = results[i] * 1000000 / CLOCKS_PER_SEC; - printf("%d bytes: seq=%d rtt=%ldµs lat=%ldµs\n", args.size, i, rtt, rtt / 2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); } _z_mutex_unlock(&mutex); z_free(results); diff --git a/examples/windows/z_ping.c b/examples/windows/z_ping.c index da6cb75db..4e4509d4a 100644 --- a/examples/windows/z_ping.c +++ b/examples/windows/z_ping.c @@ -91,23 +91,23 @@ int main(int argc, char** argv) { _z_mutex_lock(&mutex); if (args.warmup_ms) { printf("Warming up for %dms...\n", args.warmup_ms); - clock_t warmup_end = clock() + CLOCKS_PER_SEC * args.warmup_ms / 1000; - for (clock_t now = clock(); now < warmup_end; now = clock()) { + z_clock_t warmup_start = z_clock_now(); + unsigned long elapsed_us = 0; + while (elapsed_us < args.warmup_ms * 1000) { z_publisher_put(z_loan(pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); + elapsed_us = z_clock_elapsed_us(&warmup_start); } } - clock_t* results = z_malloc(sizeof(clock_t) * args.number_of_pings); + unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t start = clock(); + z_clock_t measure_start = z_clock_now(); z_publisher_put(z_loan(pub), data, args.size, NULL); _z_condvar_wait(&cond, &mutex); - clock_t end = clock(); - results[i] = end - start; + results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - clock_t rtt = results[i] * 1000000 / CLOCKS_PER_SEC; - printf("%d bytes: seq=%d rtt=%ldµs lat=%ldµs\n", args.size, i, rtt, rtt / 2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); } _z_mutex_unlock(&mutex); z_free(results); From 2a568830531f5d3a01389bba462ccffebba134be Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Wed, 25 Oct 2023 16:14:22 +0200 Subject: [PATCH 2/4] fix: use same default value as rust example --- examples/unix/c11/z_ping.c | 8 ++++---- examples/unix/c99/z_ping.c | 8 ++++---- examples/windows/z_ping.c | 8 ++++---- 3 files changed, 12 insertions(+), 12 deletions(-) diff --git a/examples/unix/c11/z_ping.c b/examples/unix/c11/z_ping.c index c9755d6fc..bea5837d3 100644 --- a/examples/unix/c11/z_ping.c +++ b/examples/unix/c11/z_ping.c @@ -50,9 +50,9 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=4): the number of pings to be attempted\n\ + -n (optional, int, default=100): the number of pings to be attempted\n\ -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=0): the warmup time in ms during which pings will be emitted but not measured\n\ + -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ "); return 1; @@ -150,12 +150,12 @@ struct args_t parse_args(int argc, char** argv) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 4; + unsigned int number_of_pings = 100; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 0; + unsigned int warmup_ms = 1000; if (arg) { warmup_ms = atoi(arg); } diff --git a/examples/unix/c99/z_ping.c b/examples/unix/c99/z_ping.c index 4627bc427..bc2c22cb0 100644 --- a/examples/unix/c99/z_ping.c +++ b/examples/unix/c99/z_ping.c @@ -49,9 +49,9 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=4): the number of pings to be attempted\n\ + -n (optional, int, default=100): the number of pings to be attempted\n\ -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=0): the warmup time in ms during which pings will be emitted but not measured\n\ + -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ "); return 1; @@ -150,12 +150,12 @@ struct args_t parse_args(int argc, char** argv) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 4; + unsigned int number_of_pings = 100; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 0; + unsigned int warmup_ms = 1000; if (arg) { warmup_ms = atoi(arg); } diff --git a/examples/windows/z_ping.c b/examples/windows/z_ping.c index 4e4509d4a..6e196c697 100644 --- a/examples/windows/z_ping.c +++ b/examples/windows/z_ping.c @@ -48,9 +48,9 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=4): the number of pings to be attempted\n\ + -n (optional, int, default=100): the number of pings to be attempted\n\ -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=0): the warmup time in ms during which pings will be emitted but not measured\n\ + -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ "); return 1; @@ -147,12 +147,12 @@ struct args_t parse_args(int argc, char** argv) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 4; + unsigned int number_of_pings = 100; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 0; + unsigned int warmup_ms = 1000; if (arg) { warmup_ms = atoi(arg); } From 1c264105fd2640fcaabafa014b415788d9bdd5ee Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Wed, 25 Oct 2023 17:10:42 +0200 Subject: [PATCH 3/4] fix: add default values as define --- examples/unix/c11/z_ping.c | 24 +++++++++++++++--------- examples/unix/c99/z_ping.c | 24 +++++++++++++++--------- examples/windows/z_ping.c | 24 +++++++++++++++--------- 3 files changed, 45 insertions(+), 27 deletions(-) diff --git a/examples/unix/c11/z_ping.c b/examples/unix/c11/z_ping.c index bea5837d3..af13efb2a 100644 --- a/examples/unix/c11/z_ping.c +++ b/examples/unix/c11/z_ping.c @@ -22,6 +22,11 @@ #include "zenoh-pico/system/platform.h" #if Z_FEATURE_SUBSCRIPTION == 1 && Z_FEATURE_PUBLICATION == 1 + +#define DEFAULT_PKT_SIZE 8 +#define DEFAULT_PING_NB 100 +#define DEFAULT_WARMUP_MS 1000 + // WARNING: for the sake of this example we are using "internal" structs and functions (starting with "_"). // Synchronisation primitives are planned to be added to the API in the future. _z_condvar_t cond; @@ -50,11 +55,12 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=100): the number of pings to be attempted\n\ - -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ + -n (optional, int, default=%d): the number of pings to be attempted\n\ + -s (optional, int, default=%d): the size of the payload embedded in the ping and repeated by the pong\n\ + -w (optional, int, default=%d): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ - "); + ", + DEFAULT_PKT_SIZE, DEFAULT_PING_NB, DEFAULT_WARMUP_MS); return 1; } _z_mutex_init(&mutex); @@ -102,7 +108,7 @@ int main(int argc, char** argv) { elapsed_us = z_clock_elapsed_us(&warmup_start); } } - unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); + unsigned long* results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { z_clock_t measure_start = z_clock_now(); z_publisher_put(z_loan(pub), data, args.size, NULL); @@ -110,7 +116,7 @@ int main(int argc, char** argv) { results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i] / 2); } _z_mutex_unlock(&mutex); z_free(results); @@ -145,17 +151,17 @@ struct args_t parse_args(int argc, char** argv) { } } char* arg = getopt(argc, argv, 's'); - unsigned int size = 8; + unsigned int size = DEFAULT_PKT_SIZE; if (arg) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 100; + unsigned int number_of_pings = DEFAULT_PING_NB; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 1000; + unsigned int warmup_ms = DEFAULT_WARMUP_MS; if (arg) { warmup_ms = atoi(arg); } diff --git a/examples/unix/c99/z_ping.c b/examples/unix/c99/z_ping.c index bc2c22cb0..94fe42424 100644 --- a/examples/unix/c99/z_ping.c +++ b/examples/unix/c99/z_ping.c @@ -23,6 +23,11 @@ #include "zenoh-pico/system/platform.h" #if Z_FEATURE_SUBSCRIPTION == 1 && Z_FEATURE_PUBLICATION == 1 + +#define DEFAULT_PKT_SIZE 8 +#define DEFAULT_PING_NB 100 +#define DEFAULT_WARMUP_MS 1000 + _z_condvar_t cond; _z_mutex_t mutex; @@ -49,11 +54,12 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=100): the number of pings to be attempted\n\ - -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ + -n (optional, int, default=%d): the number of pings to be attempted\n\ + -s (optional, int, default=%d): the size of the payload embedded in the ping and repeated by the pong\n\ + -w (optional, int, default=%d): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ - "); + ", + DEFAULT_PKT_SIZE, DEFAULT_PING_NB, DEFAULT_WARMUP_MS); return 1; } _z_mutex_init(&mutex); @@ -102,7 +108,7 @@ int main(int argc, char** argv) { elapsed_us = z_clock_elapsed_us(&warmup_start); } } - unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); + unsigned long* results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { z_clock_t measure_start = z_clock_now(); z_publisher_put(z_publisher_loan(&pub), data, args.size, NULL); @@ -110,7 +116,7 @@ int main(int argc, char** argv) { results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i] / 2); } _z_mutex_unlock(&mutex); z_free(results); @@ -145,17 +151,17 @@ struct args_t parse_args(int argc, char** argv) { } } char* arg = getopt(argc, argv, 's'); - unsigned int size = 8; + unsigned int size = DEFAULT_PKT_SIZE; if (arg) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 100; + unsigned int number_of_pings = DEFAULT_PING_NB; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 1000; + unsigned int warmup_ms = DEFAULT_WARMUP_MS; if (arg) { warmup_ms = atoi(arg); } diff --git a/examples/windows/z_ping.c b/examples/windows/z_ping.c index 6e196c697..f1a218386 100644 --- a/examples/windows/z_ping.c +++ b/examples/windows/z_ping.c @@ -22,6 +22,11 @@ #include "zenoh-pico/system/platform.h" #if Z_FEATURE_SUBSCRIPTION == 1 && Z_FEATURE_PUBLICATION == 1 + +#define DEFAULT_PKT_SIZE 8 +#define DEFAULT_PING_NB 100 +#define DEFAULT_WARMUP_MS 1000 + _z_condvar_t cond; _z_mutex_t mutex; @@ -48,11 +53,12 @@ int main(int argc, char** argv) { if (args.help_requested) { printf( "\ - -n (optional, int, default=100): the number of pings to be attempted\n\ - -s (optional, int, default=8): the size of the payload embedded in the ping and repeated by the pong\n\ - -w (optional, int, default=1000): the warmup time in ms during which pings will be emitted but not measured\n\ + -n (optional, int, default=%d): the number of pings to be attempted\n\ + -s (optional, int, default=%d): the size of the payload embedded in the ping and repeated by the pong\n\ + -w (optional, int, default=%d): the warmup time in ms during which pings will be emitted but not measured\n\ -c (optional, string): the path to a configuration file for the session. If this option isn't passed, the default configuration will be used.\n\ - "); + ", + DEFAULT_PKT_SIZE, DEFAULT_PING_NB, DEFAULT_WARMUP_MS); return 1; } _z_mutex_init(&mutex); @@ -99,7 +105,7 @@ int main(int argc, char** argv) { elapsed_us = z_clock_elapsed_us(&warmup_start); } } - unsigned long *results = z_malloc(sizeof(unsigned long) * args.number_of_pings); + unsigned long* results = z_malloc(sizeof(unsigned long) * args.number_of_pings); for (unsigned int i = 0; i < args.number_of_pings; i++) { z_clock_t measure_start = z_clock_now(); z_publisher_put(z_loan(pub), data, args.size, NULL); @@ -107,7 +113,7 @@ int main(int argc, char** argv) { results[i] = z_clock_elapsed_us(&measure_start); } for (unsigned int i = 0; i < args.number_of_pings; i++) { - printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i]/2); + printf("%d bytes: seq=%d rtt=%luµs, lat=%luµs\n", args.size, i, results[i], results[i] / 2); } _z_mutex_unlock(&mutex); z_free(results); @@ -142,17 +148,17 @@ struct args_t parse_args(int argc, char** argv) { } } char* arg = getopt(argc, argv, 's'); - unsigned int size = 8; + unsigned int size = DEFAULT_PKT_SIZE; if (arg) { size = atoi(arg); } arg = getopt(argc, argv, 'n'); - unsigned int number_of_pings = 100; + unsigned int number_of_pings = DEFAULT_PING_NB; if (arg) { number_of_pings = atoi(arg); } arg = getopt(argc, argv, 'w'); - unsigned int warmup_ms = 1000; + unsigned int warmup_ms = DEFAULT_WARMUP_MS; if (arg) { warmup_ms = atoi(arg); } From 8c6b9bba9eb711adecf7faf5107c7f3d96229642 Mon Sep 17 00:00:00 2001 From: Jean-Roland Date: Thu, 26 Oct 2023 09:20:05 +0200 Subject: [PATCH 4/4] fix: use CLOCK_MONOTONIC for time measurements --- src/system/arduino/esp32/system.c | 8 ++++---- src/system/espidf/system.c | 8 ++++---- src/system/unix/system.c | 8 ++++---- src/system/zephyr/system.c | 8 ++++---- 4 files changed, 16 insertions(+), 16 deletions(-) diff --git a/src/system/arduino/esp32/system.c b/src/system/arduino/esp32/system.c index a9eab813c..8f0773751 100644 --- a/src/system/arduino/esp32/system.c +++ b/src/system/arduino/esp32/system.c @@ -135,13 +135,13 @@ int z_sleep_s(size_t time) { return sleep(time); } /*------------------ Instant ------------------*/ z_clock_t z_clock_now(void) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); return now; } unsigned long z_clock_elapsed_us(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000); return elapsed; @@ -149,7 +149,7 @@ unsigned long z_clock_elapsed_us(z_clock_t *instant) { unsigned long z_clock_elapsed_ms(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000000); return elapsed; @@ -157,7 +157,7 @@ unsigned long z_clock_elapsed_ms(z_clock_t *instant) { unsigned long z_clock_elapsed_s(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = now.tv_sec - instant->tv_sec; return elapsed; diff --git a/src/system/espidf/system.c b/src/system/espidf/system.c index 8a655cf0d..a93c5b0e5 100644 --- a/src/system/espidf/system.c +++ b/src/system/espidf/system.c @@ -136,13 +136,13 @@ int z_sleep_s(size_t time) { return sleep(time); } /*------------------ Instant ------------------*/ z_clock_t z_clock_now(void) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); return now; } unsigned long z_clock_elapsed_us(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000); return elapsed; @@ -150,7 +150,7 @@ unsigned long z_clock_elapsed_us(z_clock_t *instant) { unsigned long z_clock_elapsed_ms(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000000); return elapsed; @@ -158,7 +158,7 @@ unsigned long z_clock_elapsed_ms(z_clock_t *instant) { unsigned long z_clock_elapsed_s(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = now.tv_sec - instant->tv_sec; return elapsed; diff --git a/src/system/unix/system.c b/src/system/unix/system.c index 875bc5f2b..990619dac 100644 --- a/src/system/unix/system.c +++ b/src/system/unix/system.c @@ -156,13 +156,13 @@ int z_sleep_s(size_t time) { return sleep(time); } /*------------------ Instant ------------------*/ z_clock_t z_clock_now(void) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); return now; } unsigned long z_clock_elapsed_us(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000); return elapsed; @@ -170,7 +170,7 @@ unsigned long z_clock_elapsed_us(z_clock_t *instant) { unsigned long z_clock_elapsed_ms(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000000); return elapsed; @@ -178,7 +178,7 @@ unsigned long z_clock_elapsed_ms(z_clock_t *instant) { unsigned long z_clock_elapsed_s(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = now.tv_sec - instant->tv_sec; return elapsed; diff --git a/src/system/zephyr/system.c b/src/system/zephyr/system.c index 28ce1d303..20e54d146 100644 --- a/src/system/zephyr/system.c +++ b/src/system/zephyr/system.c @@ -150,13 +150,13 @@ int z_sleep_s(size_t time) { /*------------------ Instant ------------------*/ z_clock_t z_clock_now(void) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); return now; } unsigned long z_clock_elapsed_us(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000); return elapsed; @@ -164,7 +164,7 @@ unsigned long z_clock_elapsed_us(z_clock_t *instant) { unsigned long z_clock_elapsed_ms(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = (1000 * (now.tv_sec - instant->tv_sec) + (now.tv_nsec - instant->tv_nsec) / 1000000); return elapsed; @@ -172,7 +172,7 @@ unsigned long z_clock_elapsed_ms(z_clock_t *instant) { unsigned long z_clock_elapsed_s(z_clock_t *instant) { z_clock_t now; - clock_gettime(CLOCK_REALTIME, &now); + clock_gettime(CLOCK_MONOTONIC, &now); unsigned long elapsed = now.tv_sec - instant->tv_sec; return elapsed;