projects
/
musl
/ blobdiff
commit
grep
author
committer
pickaxe
?
search:
re
summary
|
shortlog
|
log
|
commit
|
commitdiff
|
tree
raw
|
inline
| side by side
workaround for gcc's optimizer breaking dynamic symbol resolution
[musl]
/
src
/
time
/
clock_gettime.c
diff --git
a/src/time/clock_gettime.c
b/src/time/clock_gettime.c
index
bb977e2
..
9fef54a
100644
(file)
--- a/
src/time/clock_gettime.c
+++ b/
src/time/clock_gettime.c
@@
-5,7
+5,7
@@
#include "libc.h"
int __vdso_clock_gettime(clockid_t, struct timespec *) __attribute__((weak));
#include "libc.h"
int __vdso_clock_gettime(clockid_t, struct timespec *) __attribute__((weak));
-static int (*c
onst c
gt)(clockid_t, struct timespec *) = __vdso_clock_gettime;
+static int (*cgt)(clockid_t, struct timespec *) = __vdso_clock_gettime;
int __clock_gettime(clockid_t clk, struct timespec *ts)
{
int __clock_gettime(clockid_t clk, struct timespec *ts)
{
@@
-14,6
+14,7
@@
int __clock_gettime(clockid_t clk, struct timespec *ts)
r = __syscall(SYS_clock_gettime, clk, ts);
if (!r) return r;
if (r == -ENOSYS) {
r = __syscall(SYS_clock_gettime, clk, ts);
if (!r) return r;
if (r == -ENOSYS) {
+ cgt = 0;
if (clk == CLOCK_REALTIME) {
__syscall(SYS_gettimeofday, clk, ts, 0);
ts->tv_nsec = (int)ts->tv_nsec * 1000;
if (clk == CLOCK_REALTIME) {
__syscall(SYS_gettimeofday, clk, ts, 0);
ts->tv_nsec = (int)ts->tv_nsec * 1000;