/*
- * 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>
#include <mach/mach_host_server.h>
#include <mach/host_priv_server.h>
+#include <libkern/section_keywords.h>
/*
* Actual clock alarm structure. Used for user clock_sleep() and
sleep_type_t sleep_type,
mach_timespec_t *sleep_time);
-int rtclock_config(void);
-
int rtclock_init(void);
kern_return_t rtclock_gettime(
clock_attr_t attr,
mach_msg_type_number_t *count);
-struct clock_ops sysclk_ops = {
- rtclock_config, rtclock_init,
+SECURITY_READ_ONLY_EARLY(struct clock_ops) sysclk_ops = {
+ NULL, rtclock_init,
rtclock_gettime,
rtclock_getattr,
};
clock_attr_t attr,
mach_msg_type_number_t *count);
-struct clock_ops calend_ops = {
- 0, 0,
+SECURITY_READ_ONLY_EARLY(struct clock_ops) calend_ops = {
+ NULL, NULL,
calend_gettime,
calend_getattr,
};
+/*
+ * List of clock devices.
+ */
+SECURITY_READ_ONLY_LATE(struct clock) clock_list[] = {
+
+ /* SYSTEM_CLOCK */
+ { &sysclk_ops, 0, 0 },
+
+ /* CALENDAR_CLOCK */
+ { &calend_ops, 0, 0 }
+};
+int clock_count = sizeof(clock_list) / sizeof(clock_list[0]);
+
/*
* Macros to lock/unlock clock system.
*/
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);
}
int sleep_nsec = args->sleep_nsec;
mach_vm_address_t wakeup_time_addr = args->wakeup_time;
clock_t clock;
- mach_timespec_t swtime;
+ mach_timespec_t swtime = {};
kern_return_t rvalue;
/*
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__ */