/*
- * Copyright (c) 2000-2005 Apple Computer, Inc. All rights reserved.
+ * Copyright (c) 2000-2008 Apple Inc. All rights reserved.
*
* @APPLE_OSREFERENCE_LICENSE_HEADER_START@
*
#include <mach/mach_types.h>
-#include <kern/lock.h>
#include <kern/host.h>
#include <kern/spl.h>
#include <kern/sched_prim.h>
sleep_type_t sleep_type,
mach_timespec_t *sleep_time);
-int rtclock_config(void);
-
int rtclock_init(void);
kern_return_t rtclock_gettime(
mach_msg_type_number_t *count);
struct clock_ops sysclk_ops = {
- rtclock_config, rtclock_init,
+ NULL, rtclock_init,
rtclock_gettime,
rtclock_getattr,
};
mach_msg_type_number_t *count);
struct clock_ops calend_ops = {
- 0, 0,
+ NULL, NULL,
calend_gettime,
calend_getattr,
};
clock_oldconfig(void)
{
clock_t clock;
- register int i;
+ int i;
simple_lock_init(&alarm_lock, 0);
thread_call_setup(&alarm_done_call, (thread_call_func_t)alarm_done, NULL);
clock = &clock_list[i];
if (clock->cl_ops && clock->cl_ops->c_config) {
if ((*clock->cl_ops->c_config)() == 0)
- clock->cl_ops = 0;
+ clock->cl_ops = NULL;
}
}
clock_oldinit(void)
{
clock_t clock;
- register int i;
+ int i;
/*
* Initialize basic clock structures.
clock_service_create(void)
{
clock_t clock;
- register int i;
+ int i;
/*
* Initialize ipc clock services.
rtclock_gettime(
mach_timespec_t *time) /* OUT */
{
- clock_get_system_nanotime(&time->tv_sec, (uint32_t *)&time->tv_nsec);
+ clock_sec_t secs;
+ clock_nsec_t nsecs;
+
+ clock_get_system_nanotime(&secs, &nsecs);
+ time->tv_sec = (unsigned int)secs;
+ time->tv_nsec = nsecs;
return (KERN_SUCCESS);
}
calend_gettime(
mach_timespec_t *time) /* OUT */
{
- clock_get_calendar_nanotime(&time->tv_sec, (uint32_t *)&time->tv_nsec);
+ clock_sec_t secs;
+ clock_nsec_t nsecs;
+
+ clock_get_calendar_nanotime(&secs, &nsecs);
+ time->tv_sec = (unsigned int)secs;
+ time->tv_nsec = nsecs;
return (KERN_SUCCESS);
}
alarm_expire(void)
{
clock_t clock;
- register alarm_t alrm1;
- register alarm_t alrm2;
+ alarm_t alrm1;
+ alarm_t alrm2;
mach_timespec_t clock_time;
mach_timespec_t *alarm_time;
spl_t s;
* which issued the clock_sleep() call.
*/
if (alrm2->al_status == ALARM_SLEEP) {
- alrm2->al_next = 0;
+ alrm2->al_next = NULL;
alrm2->al_status = ALARM_DONE;
alrm2->al_time = clock_time;
thread_wakeup((event_t)alrm2);
static void
alarm_done(void)
{
- register alarm_t alrm;
+ alarm_t alrm;
kern_return_t code;
spl_t s;
post_alarm(
alarm_t alarm)
{
- register alarm_t alrm1, alrm2;
+ alarm_t alrm1, alrm2;
mach_timespec_t *alarm_time;
mach_timespec_t *queue_time;
uint64_t abstime;
nanotime_to_absolutetime(alarm_time->tv_sec, alarm_time->tv_nsec, &abstime);
- timer_call_enter(&alarm_expire_timer, abstime);
+ timer_call_enter_with_leeway(&alarm_expire_timer, NULL, abstime, 0, TIMER_CALL_USER_NORMAL, FALSE);
}
/*
return ((result >= 0)? result: 0);
}
+#ifndef __LP64__
+
mach_timespec_t
clock_get_system_value(void)
{
return value;
}
+
+#endif /* __LP64__ */