diff options
author | Thomas Gleixner <tglx@linutronix.de> | 2011-02-02 05:45:23 -0500 |
---|---|---|
committer | Thomas Gleixner <tglx@linutronix.de> | 2011-02-02 09:28:15 -0500 |
commit | 4359ac0ace1a2a267927390ad27f781a2f8e0ab8 (patch) | |
tree | 01a77aa7afece2932d7838dffdc1a0aa0e8b6aac | |
parent | 42285777631aa0654fbb6442057b3e176445c6c5 (diff) |
posix-timers: Make clock_getres and clock_get mandatory
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>
-rw-r--r-- | kernel/posix-timers.c | 15 |
1 files changed, 12 insertions, 3 deletions
diff --git a/kernel/posix-timers.c b/kernel/posix-timers.c index d9e5edfe8a1b..7f66143d1ce5 100644 --- a/kernel/posix-timers.c +++ b/kernel/posix-timers.c | |||
@@ -485,7 +485,18 @@ static struct pid *good_sigevent(sigevent_t * event) | |||
485 | void register_posix_clock(const clockid_t clock_id, struct k_clock *new_clock) | 485 | void register_posix_clock(const clockid_t clock_id, struct k_clock *new_clock) |
486 | { | 486 | { |
487 | if ((unsigned) clock_id >= MAX_CLOCKS) { | 487 | if ((unsigned) clock_id >= MAX_CLOCKS) { |
488 | printk("POSIX clock register failed for clock_id %d\n", | 488 | printk(KERN_WARNING "POSIX clock register failed for clock_id %d\n", |
489 | clock_id); | ||
490 | return; | ||
491 | } | ||
492 | |||
493 | if (!new_clock->clock_get) { | ||
494 | printk(KERN_WARNING "POSIX clock id %d lacks clock_get()\n", | ||
495 | clock_id); | ||
496 | return; | ||
497 | } | ||
498 | if (!new_clock->clock_getres) { | ||
499 | printk(KERN_WARNING "POSIX clock id %d lacks clock_getres()\n", | ||
489 | clock_id); | 500 | clock_id); |
490 | return; | 501 | return; |
491 | } | 502 | } |
@@ -961,8 +972,6 @@ SYSCALL_DEFINE2(clock_gettime, const clockid_t, which_clock, | |||
961 | 972 | ||
962 | if (!kc) | 973 | if (!kc) |
963 | return -EINVAL; | 974 | return -EINVAL; |
964 | if (!kc->clock_get) | ||
965 | return -EOPNOTSUPP; | ||
966 | 975 | ||
967 | error = kc->clock_get(which_clock, &kernel_tp); | 976 | error = kc->clock_get(which_clock, &kernel_tp); |
968 | 977 | ||