posix-timers: Make clock_getres and clock_get mandatory
authorThomas Gleixner <tglx@linutronix.de>
Wed, 2 Feb 2011 10:45:23 +0000 (11:45 +0100)
committerThomas Gleixner <tglx@linutronix.de>
Wed, 2 Feb 2011 14:28:15 +0000 (15:28 +0100)
Richard said: "I would think that we can require k_clocks to provide
the read function. This could be checked and enforced in
register_posix_clock()."

Add checks for clock_getres and clock_get in the register function.

Suggested-by: Richard Cochran <richardcochran@gmail.com>
Cc: John Stultz <johnstul@us.ibm.com>
Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
kernel/posix-timers.c

index d9e5edfe8a1bbc346f6c3a21861f9926656a3922..7f66143d1ce5f317a5d940bac34a3313125ab000 100644 (file)
@@ -485,7 +485,18 @@ static struct pid *good_sigevent(sigevent_t * event)
 void register_posix_clock(const clockid_t clock_id, struct k_clock *new_clock)
 {
        if ((unsigned) clock_id >= MAX_CLOCKS) {
-               printk("POSIX clock register failed for clock_id %d\n",
+               printk(KERN_WARNING "POSIX clock register failed for clock_id %d\n",
+                      clock_id);
+               return;
+       }
+
+       if (!new_clock->clock_get) {
+               printk(KERN_WARNING "POSIX clock id %d lacks clock_get()\n",
+                      clock_id);
+               return;
+       }
+       if (!new_clock->clock_getres) {
+               printk(KERN_WARNING "POSIX clock id %d lacks clock_getres()\n",
                       clock_id);
                return;
        }
@@ -961,8 +972,6 @@ SYSCALL_DEFINE2(clock_gettime, const clockid_t, which_clock,
 
        if (!kc)
                return -EINVAL;
-       if (!kc->clock_get)
-               return -EOPNOTSUPP;
 
        error = kc->clock_get(which_clock, &kernel_tp);