mirror of
https://github.com/cesanta/mongoose.git
synced 2025-01-15 18:34:41 +08:00
util: Actually return uptime on OSX/Linux for mg_millis
The documentation for mg_millis indicates it will: Return current uptime in milliseconds. So we should use API's that actually return uptime. Signed-off-by: James Hilliard <james.hilliard1@gmail.com>
This commit is contained in:
parent
b5147a149e
commit
001dc3f33d
19
mongoose.c
19
mongoose.c
@ -4153,6 +4153,10 @@ struct mg_str mg_url_pass(const char *url) {
|
|||||||
|
|
||||||
|
|
||||||
|
|
||||||
|
#if MG_ARCH == MG_ARCH_UNIX && defined(__APPLE__)
|
||||||
|
#include <mach/mach_time.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
char *mg_file_read(const char *path, size_t *sizep) {
|
char *mg_file_read(const char *path, size_t *sizep) {
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *data = NULL;
|
char *data = NULL;
|
||||||
@ -4498,9 +4502,24 @@ unsigned long mg_millis(void) {
|
|||||||
return xTaskGetTickCount() * portTICK_PERIOD_MS;
|
return xTaskGetTickCount() * portTICK_PERIOD_MS;
|
||||||
#elif MG_ARCH == MG_ARCH_AZURERTOS
|
#elif MG_ARCH == MG_ARCH_AZURERTOS
|
||||||
return tx_time_get() * (1000 /* MS per SEC */ / TX_TIMER_TICKS_PER_SECOND);
|
return tx_time_get() * (1000 /* MS per SEC */ / TX_TIMER_TICKS_PER_SECOND);
|
||||||
|
#elif MG_ARCH == MG_ARCH_UNIX && defined(__APPLE__)
|
||||||
|
uint64_t ticks = mach_absolute_time();
|
||||||
|
static mach_timebase_info_data_t timebase;
|
||||||
|
mach_timebase_info(&timebase);
|
||||||
|
double ticks_to_nanos = (double)timebase.numer / timebase.denom;
|
||||||
|
uint64_t uptime_nanos = (uint64_t)(ticks_to_nanos * ticks);
|
||||||
|
return (unsigned long) (uptime_nanos / 1000000);
|
||||||
#else
|
#else
|
||||||
struct timespec ts;
|
struct timespec ts;
|
||||||
|
#ifdef _POSIX_MONOTONIC_CLOCK
|
||||||
|
#ifdef CLOCK_MONOTONIC_RAW
|
||||||
|
clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
|
||||||
|
#else
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &ts);
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
clock_gettime(CLOCK_REALTIME, &ts);
|
clock_gettime(CLOCK_REALTIME, &ts);
|
||||||
|
#endif
|
||||||
return (unsigned long) ((uint64_t) ts.tv_sec * 1000 +
|
return (unsigned long) ((uint64_t) ts.tv_sec * 1000 +
|
||||||
(uint64_t) ts.tv_nsec / 1000000);
|
(uint64_t) ts.tv_nsec / 1000000);
|
||||||
#endif
|
#endif
|
||||||
|
19
src/util.c
19
src/util.c
@ -2,6 +2,10 @@
|
|||||||
|
|
||||||
#include "util.h"
|
#include "util.h"
|
||||||
|
|
||||||
|
#if MG_ARCH == MG_ARCH_UNIX && defined(__APPLE__)
|
||||||
|
#include <mach/mach_time.h>
|
||||||
|
#endif
|
||||||
|
|
||||||
char *mg_file_read(const char *path, size_t *sizep) {
|
char *mg_file_read(const char *path, size_t *sizep) {
|
||||||
FILE *fp;
|
FILE *fp;
|
||||||
char *data = NULL;
|
char *data = NULL;
|
||||||
@ -347,9 +351,24 @@ unsigned long mg_millis(void) {
|
|||||||
return xTaskGetTickCount() * portTICK_PERIOD_MS;
|
return xTaskGetTickCount() * portTICK_PERIOD_MS;
|
||||||
#elif MG_ARCH == MG_ARCH_AZURERTOS
|
#elif MG_ARCH == MG_ARCH_AZURERTOS
|
||||||
return tx_time_get() * (1000 /* MS per SEC */ / TX_TIMER_TICKS_PER_SECOND);
|
return tx_time_get() * (1000 /* MS per SEC */ / TX_TIMER_TICKS_PER_SECOND);
|
||||||
|
#elif MG_ARCH == MG_ARCH_UNIX && defined(__APPLE__)
|
||||||
|
uint64_t ticks = mach_absolute_time();
|
||||||
|
static mach_timebase_info_data_t timebase;
|
||||||
|
mach_timebase_info(&timebase);
|
||||||
|
double ticks_to_nanos = (double)timebase.numer / timebase.denom;
|
||||||
|
uint64_t uptime_nanos = (uint64_t)(ticks_to_nanos * ticks);
|
||||||
|
return (unsigned long) (uptime_nanos / 1000000);
|
||||||
#else
|
#else
|
||||||
struct timespec ts;
|
struct timespec ts;
|
||||||
|
#ifdef _POSIX_MONOTONIC_CLOCK
|
||||||
|
#ifdef CLOCK_MONOTONIC_RAW
|
||||||
|
clock_gettime(CLOCK_MONOTONIC_RAW, &ts);
|
||||||
|
#else
|
||||||
|
clock_gettime(CLOCK_MONOTONIC, &ts);
|
||||||
|
#endif
|
||||||
|
#else
|
||||||
clock_gettime(CLOCK_REALTIME, &ts);
|
clock_gettime(CLOCK_REALTIME, &ts);
|
||||||
|
#endif
|
||||||
return (unsigned long) ((uint64_t) ts.tv_sec * 1000 +
|
return (unsigned long) ((uint64_t) ts.tv_sec * 1000 +
|
||||||
(uint64_t) ts.tv_nsec / 1000000);
|
(uint64_t) ts.tv_nsec / 1000000);
|
||||||
#endif
|
#endif
|
||||||
|
Loading…
x
Reference in New Issue
Block a user