From 4b1244a0bfec55bc4cad91ff157997929f106215 Mon Sep 17 00:00:00 2001 From: Rich Felker Date: Sat, 19 Feb 2011 12:43:56 -0500 Subject: implement the remaining clock_* interfaces --- src/time/clock_getcpuclockid.c | 11 +++++++++++ src/time/clock_getres.c | 8 ++++++++ src/time/clock_gettime.c | 1 + src/time/clock_nanosleep.c | 8 ++++++++ src/time/clock_settime.c | 8 ++++++++ 5 files changed, 36 insertions(+) create mode 100644 src/time/clock_getcpuclockid.c create mode 100644 src/time/clock_getres.c create mode 100644 src/time/clock_nanosleep.c create mode 100644 src/time/clock_settime.c (limited to 'src/time') diff --git a/src/time/clock_getcpuclockid.c b/src/time/clock_getcpuclockid.c new file mode 100644 index 00000000..723840b0 --- /dev/null +++ b/src/time/clock_getcpuclockid.c @@ -0,0 +1,11 @@ +#include +#include +#include +#include "syscall.h" + +int clock_getcpuclockid(pid_t pid, clockid_t *clk) +{ + if (pid && pid != getpid()) return EPERM; + *clk = CLOCK_PROCESS_CPUTIME_ID; + return 0; +} diff --git a/src/time/clock_getres.c b/src/time/clock_getres.c new file mode 100644 index 00000000..e86a1ee4 --- /dev/null +++ b/src/time/clock_getres.c @@ -0,0 +1,8 @@ +#define SYSCALL_RETURN_ERRNO +#include +#include "syscall.h" + +int clock_getres(clockid_t clk, struct timespec *ts) +{ + return syscall2(__NR_clock_getres, clk, (long)ts); +} diff --git a/src/time/clock_gettime.c b/src/time/clock_gettime.c index dab09d50..6b880a06 100644 --- a/src/time/clock_gettime.c +++ b/src/time/clock_gettime.c @@ -1,3 +1,4 @@ +#define SYSCALL_RETURN_ERRNO #include #include "syscall.h" diff --git a/src/time/clock_nanosleep.c b/src/time/clock_nanosleep.c new file mode 100644 index 00000000..c5646de3 --- /dev/null +++ b/src/time/clock_nanosleep.c @@ -0,0 +1,8 @@ +#define SYSCALL_RETURN_ERRNO +#include +#include "syscall.h" + +int clock_nanosleep(clockid_t clk, int flags, const struct timespec *req, struct timespec *rem) +{ + return syscall4(__NR_clock_nanosleep, clk, flags, (long)req, (long)rem); +} diff --git a/src/time/clock_settime.c b/src/time/clock_settime.c new file mode 100644 index 00000000..e880fb33 --- /dev/null +++ b/src/time/clock_settime.c @@ -0,0 +1,8 @@ +#define SYSCALL_RETURN_ERRNO +#include +#include "syscall.h" + +int clock_settime(clockid_t clk, const struct timespec *ts) +{ + return syscall2(__NR_clock_settime, clk, (long)ts); +} -- cgit v1.2.1