* Copyright 2002-2009, Axel DΓΆrfler, axeld@pinc-software.de.
* Distributed under the terms of the MIT License.
*/
#include <errno.h>
#include <stdio.h>
#include <string.h>
#include <syslog.h>
#include <FindDirectory.h>
#include <OS.h>
#include <commpage_defs.h>
#include <errno_private.h>
#include <libroot_private.h>
#include <real_time_data.h>
#include <user_timer_defs.h>
#include <syscalls.h>
static struct real_time_data* sRealTimeData;
void
__init_time(addr_t commPageTable)
{
sRealTimeData = (struct real_time_data*)
(((addr_t*)commPageTable)[COMMPAGE_ENTRY_REAL_TIME_DATA]
+ commPageTable);
__arch_init_time(sRealTimeData, false);
}
bigtime_t
__get_system_time_offset()
{
return __arch_get_system_time_offset(sRealTimeData);
}
unsigned long
real_time_clock(void)
{
return (__arch_get_system_time_offset(sRealTimeData) + system_time())
/ 1000000;
}
bigtime_t
real_time_clock_usecs(void)
{
return __arch_get_system_time_offset(sRealTimeData) + system_time();
}
void
set_real_time_clock(unsigned long secs)
{
_kern_set_real_time_clock((bigtime_t)secs * 1000000);
}
bigtime_t
set_alarm(bigtime_t when, uint32 mode)
{
bigtime_t interval = 0;
uint32 flags = B_RELATIVE_TIMEOUT;
if (when == B_INFINITE_TIMEOUT) {
when = B_INFINITE_TIMEOUT;
} else {
switch (mode) {
case B_PERIODIC_ALARM:
interval = when;
break;
case B_ONE_SHOT_ABSOLUTE_ALARM:
flags = B_ABSOLUTE_TIMEOUT;
break;
case B_ONE_SHOT_RELATIVE_ALARM:
default:
break;
}
}
user_timer_info oldInfo;
status_t error = _kern_set_timer(USER_TIMER_REAL_TIME_ID, find_thread(NULL),
when, interval, flags, &oldInfo);
if (error != B_OK)
return 0;
return oldInfo.remaining_time != B_INFINITE_TIMEOUT
? oldInfo.remaining_time : 0;
}
#ifdef __HAIKU_BEOS_COMPATIBLE
extern "C" status_t
set_timezone(const char* )
{
return ENOSYS;
}
#endif