2008-10-23 13:26:29 +08:00
|
|
|
#ifndef _ASM_X86_TIME_H
|
|
|
|
#define _ASM_X86_TIME_H
|
2008-01-30 20:31:10 +08:00
|
|
|
|
|
|
|
extern void hpet_time_init(void);
|
2006-12-07 09:14:07 +08:00
|
|
|
|
2008-01-30 20:30:26 +08:00
|
|
|
#include <asm/mc146818rtc.h>
|
2008-01-30 20:31:10 +08:00
|
|
|
#ifdef CONFIG_X86_32
|
|
|
|
#include <linux/efi.h>
|
2006-12-07 09:14:07 +08:00
|
|
|
|
|
|
|
static inline unsigned long native_get_wallclock(void)
|
|
|
|
{
|
|
|
|
unsigned long retval;
|
|
|
|
|
|
|
|
if (efi_enabled)
|
|
|
|
retval = efi_get_time();
|
|
|
|
else
|
|
|
|
retval = mach_get_cmos_time();
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int native_set_wallclock(unsigned long nowtime)
|
|
|
|
{
|
|
|
|
int retval;
|
|
|
|
|
|
|
|
if (efi_enabled)
|
|
|
|
retval = efi_set_rtc_mmss(nowtime);
|
|
|
|
else
|
|
|
|
retval = mach_set_rtc_mmss(nowtime);
|
|
|
|
|
|
|
|
return retval;
|
|
|
|
}
|
|
|
|
|
2008-01-30 20:31:10 +08:00
|
|
|
#else
|
|
|
|
extern void native_time_init_hook(void);
|
|
|
|
|
|
|
|
static inline unsigned long native_get_wallclock(void)
|
|
|
|
{
|
|
|
|
return mach_get_cmos_time();
|
|
|
|
}
|
|
|
|
|
|
|
|
static inline int native_set_wallclock(unsigned long nowtime)
|
|
|
|
{
|
|
|
|
return mach_set_rtc_mmss(nowtime);
|
|
|
|
}
|
|
|
|
|
|
|
|
#endif
|
2007-03-05 16:30:39 +08:00
|
|
|
|
2008-07-22 00:22:51 +08:00
|
|
|
extern void time_init(void);
|
|
|
|
|
2006-12-07 09:14:07 +08:00
|
|
|
#ifdef CONFIG_PARAVIRT
|
|
|
|
#include <asm/paravirt.h>
|
|
|
|
#else /* !CONFIG_PARAVIRT */
|
|
|
|
|
|
|
|
#define get_wallclock() native_get_wallclock()
|
|
|
|
#define set_wallclock(x) native_set_wallclock(x)
|
2007-03-05 16:30:39 +08:00
|
|
|
#define choose_time_init() hpet_time_init
|
2006-12-07 09:14:07 +08:00
|
|
|
|
|
|
|
#endif /* CONFIG_PARAVIRT */
|
|
|
|
|
2008-07-02 02:43:34 +08:00
|
|
|
extern unsigned long __init calibrate_cpu(void);
|
|
|
|
|
2008-10-23 13:26:29 +08:00
|
|
|
#endif /* _ASM_X86_TIME_H */
|