[uClibc-cvs] svn commit: trunk/uClibc: include libc/misc/time libc/sysdeps/linu etc...
pkj at uclibc.org
pkj at uclibc.org
Thu Apr 28 13:11:30 UTC 2005
Author: pkj
Date: 2005-04-28 07:11:29 -0600 (Thu, 28 Apr 2005)
New Revision: 10196
Log:
Added support for clock_getres() and clock_settime() in addition to
the already existing clock_gettime(). In addition they will now use
the corresponding system calls if they exists, which resulted in a
move to libc/sysdeps/linux/common for clock_gettime.c (it was
previously located in libc/misc/time).
Added:
trunk/uClibc/libc/sysdeps/linux/common/clock_getres.c
trunk/uClibc/libc/sysdeps/linux/common/clock_gettime.c
trunk/uClibc/libc/sysdeps/linux/common/clock_settime.c
Removed:
trunk/uClibc/libc/misc/time/clock_gettime.c
Modified:
trunk/uClibc/include/time.h
trunk/uClibc/libc/misc/time/Makefile
Changeset:
Modified: trunk/uClibc/include/time.h
===================================================================
--- trunk/uClibc/include/time.h 2005-04-28 12:48:26 UTC (rev 10195)
+++ trunk/uClibc/include/time.h 2005-04-28 13:11:29 UTC (rev 10196)
@@ -345,17 +345,17 @@
struct timespec *__remaining);
+/* Get resolution of clock CLOCK_ID. */
+extern int clock_getres (clockid_t __clock_id, struct timespec *__res) __THROW;
+
/* Get current value of clock CLOCK_ID and store it in TP. */
extern int clock_gettime (clockid_t __clock_id, struct timespec *__tp) __THROW;
-#ifdef __UCLIBC_MJN3_ONLY__
-#warning "mjn3 FIXME: a bunch of unimplemented function prototypes."
-/* Get resolution of clock CLOCK_ID. */
-extern int clock_getres (clockid_t __clock_id, struct timespec *__res) __THROW;
-
/* Set clock CLOCK_ID to value TP. */
extern int clock_settime (clockid_t __clock_id, __const struct timespec *__tp) __THROW;
+#ifdef __UCLIBC_MJN3_ONLY__
+#warning "mjn3 FIXME: a bunch of unimplemented function prototypes."
# ifdef __USE_XOPEN2K
/* High-resolution sleep with the specified clock.
Modified: trunk/uClibc/libc/misc/time/Makefile
===================================================================
--- trunk/uClibc/libc/misc/time/Makefile 2005-04-28 12:48:26 UTC (rev 10195)
+++ trunk/uClibc/libc/misc/time/Makefile 2005-04-28 13:11:29 UTC (rev 10196)
@@ -45,7 +45,7 @@
endif
endif
-CSRC= adjtime.c ftime.c clock_gettime.c
+CSRC= adjtime.c ftime.c
COBJS=$(patsubst %.c,%.o, $(CSRC))
OBJS=$(COBJS) $(MOBJ) $(MOBJx)
Deleted: trunk/uClibc/libc/misc/time/clock_gettime.c
===================================================================
--- trunk/uClibc/libc/misc/time/clock_gettime.c 2005-04-28 12:48:26 UTC (rev 10195)
+++ trunk/uClibc/libc/misc/time/clock_gettime.c 2005-04-28 13:11:29 UTC (rev 10196)
@@ -1,40 +0,0 @@
-/* Copyright (C) 2003 Justus Pendleton <uc at ryoohki.net>
- *
- * This library is free software; you can redistribute it and/or
- * modify it under the terms of the GNU Library General Public
- * License as published by the Free Software Foundation; either
- * version 2 of the License, or (at your option) any later version.
- *
- * This library is distributed in the hope that it will be useful,
- * but WITHOUT ANY WARRANTY; without even the implied warranty of
- * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE. See the GNU
- * Library General Public License for more details.
- *
- * You should have received a copy of the GNU Library General Public
- * License along with this library; if not, write to the Free
- * Software Foundation, Inc., 675 Mass Ave, Cambridge, MA 02139, USA.
- */
-
-#define _GNU_SOURCE
-#include <time.h>
-#include <errno.h>
-#include <sys/time.h>
-
-int clock_gettime (clockid_t clock, struct timespec* ts)
-{
- struct timeval tv;
- int retval = -1;
- switch (clock) {
- case CLOCK_REALTIME:
- retval = gettimeofday (&tv, NULL);
- if (retval == 0) {
- TIMEVAL_TO_TIMESPEC (&tv, ts);
- }
- break;
- default:
- errno = EINVAL;
- break;
- }
- return retval;
-}
-
Added: trunk/uClibc/libc/sysdeps/linux/common/clock_getres.c
===================================================================
--- trunk/uClibc/libc/sysdeps/linux/common/clock_getres.c 2005-04-28 12:48:26 UTC (rev 10195)
+++ trunk/uClibc/libc/sysdeps/linux/common/clock_getres.c 2005-04-28 13:11:29 UTC (rev 10196)
@@ -0,0 +1,51 @@
+/*
+ * clock_getres() for uClibc
+ *
+ * Copyright (C) 2005 by Peter Kjellerstedt <pkj at axis.com>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Library General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+#define _GNU_SOURCE
+#include "syscalls.h"
+#include <time.h>
+#include <unistd.h>
+
+#ifdef __NR_clock_getres
+_syscall2(int, clock_getres, clockid_t, clock_id, struct timespec*, res);
+#else
+int clock_getres(clockid_t clock_id, struct timespec* res)
+{
+ long clk_tck;
+ int retval = -1;
+
+ switch (clock_id) {
+ case CLOCK_REALTIME:
+ if ((clk_tck = sysconf(_SC_CLK_TCK)) < 0)
+ clk_tck = 100;
+ res->tv_sec = 0;
+ res->tv_nsec = 1000000000 / clk_tck;
+ retval = 0;
+ break;
+
+ default:
+ errno = EINVAL;
+ break;
+ }
+
+ return retval;
+}
+#endif
Copied: trunk/uClibc/libc/sysdeps/linux/common/clock_gettime.c (from rev 10193, trunk/uClibc/libc/misc/time/clock_gettime.c)
===================================================================
--- trunk/uClibc/libc/misc/time/clock_gettime.c 2005-04-28 03:53:52 UTC (rev 10193)
+++ trunk/uClibc/libc/sysdeps/linux/common/clock_gettime.c 2005-04-28 13:11:29 UTC (rev 10196)
@@ -0,0 +1,51 @@
+/*
+ * clock_gettime() for uClibc
+ *
+ * Copyright (C) 2003 by Justus Pendleton <uc at ryoohki.net>
+ * Copyright (C) 2005 by Peter Kjellerstedt <pkj at axis.com>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Library General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+#define _GNU_SOURCE
+#include "syscalls.h"
+#include <time.h>
+#include <sys/time.h>
+
+#ifdef __NR_clock_gettime
+_syscall2(int, clock_gettime, clockid_t, clock_id, struct timespec*, tp);
+#else
+int clock_gettime(clockid_t clock_id, struct timespec* tp)
+{
+ struct timeval tv;
+ int retval = -1;
+
+ switch (clock_id) {
+ case CLOCK_REALTIME:
+ retval = gettimeofday(&tv, NULL);
+ if (retval == 0) {
+ TIMEVAL_TO_TIMESPEC(&tv, tp);
+ }
+ break;
+
+ default:
+ errno = EINVAL;
+ break;
+ }
+
+ return retval;
+}
+#endif
Added: trunk/uClibc/libc/sysdeps/linux/common/clock_settime.c
===================================================================
--- trunk/uClibc/libc/sysdeps/linux/common/clock_settime.c 2005-04-28 12:48:26 UTC (rev 10195)
+++ trunk/uClibc/libc/sysdeps/linux/common/clock_settime.c 2005-04-28 13:11:29 UTC (rev 10196)
@@ -0,0 +1,53 @@
+/*
+ * clock_settime() for uClibc
+ *
+ * Copyright (C) 2005 by Peter Kjellerstedt <pkj at axis.com>
+ *
+ * This program is free software; you can redistribute it and/or modify it
+ * under the terms of the GNU Library General Public License as published by
+ * the Free Software Foundation; either version 2 of the License, or (at your
+ * option) any later version.
+ *
+ * This program is distributed in the hope that it will be useful, but WITHOUT
+ * ANY WARRANTY; without even the implied warranty of MERCHANTABILITY or
+ * FITNESS FOR A PARTICULAR PURPOSE. See the GNU Library General Public License
+ * for more details.
+ *
+ * You should have received a copy of the GNU Library General Public License
+ * along with this program; if not, write to the Free Software Foundation,
+ * Inc., 59 Temple Place, Suite 330, Boston, MA 02111-1307 USA
+ *
+ */
+
+#define _GNU_SOURCE
+#include "syscalls.h"
+#include <time.h>
+#include <sys/time.h>
+
+#ifdef __NR_clock_settime
+_syscall2(int, clock_settime, clockid_t, clock_id, const struct timespec*, tp);
+#else
+int clock_settime(clockid_t clock_id, const struct timespec* tp)
+{
+ struct timeval tv;
+ int retval = -1;
+
+ if (tp->tv_nsec < 0 || tp->tv_nsec >= 1000000000) {
+ errno = EINVAL;
+ return -1;
+ }
+
+ switch (clock_id) {
+ case CLOCK_REALTIME:
+ TIMESPEC_TO_TIMEVAL(&tv, tp);
+ retval = settimeofday(&tv, NULL);
+ break;
+
+ default:
+ errno = EINVAL;
+ break;
+ }
+
+ return retval;
+}
+#endif
More information about the uClibc-cvs
mailing list