mirror of
https://mirrors.bfsu.edu.cn/git/linux.git
synced 2025-01-17 19:34:12 +08:00
845b3944bb
The timer init code is convoluted with several quirks and the paravirt timer chooser. Figuring out which code path is actually taken is not for the faint hearted. Move the numaq TSC quirk to tsc_pre_init x86_init_ops function and replace the paravirt time chooser and the remaining x86 quirk with a simple x86_init_ops function. Signed-off-by: Thomas Gleixner <tglx@linutronix.de>
63 lines
1.1 KiB
C
63 lines
1.1 KiB
C
#ifndef _ASM_X86_TIME_H
|
|
#define _ASM_X86_TIME_H
|
|
|
|
extern void hpet_time_init(void);
|
|
|
|
#include <asm/mc146818rtc.h>
|
|
#ifdef CONFIG_X86_32
|
|
#include <linux/efi.h>
|
|
|
|
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;
|
|
}
|
|
|
|
#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
|
|
|
|
extern void time_init(void);
|
|
|
|
#ifdef CONFIG_PARAVIRT
|
|
#include <asm/paravirt.h>
|
|
#else /* !CONFIG_PARAVIRT */
|
|
|
|
#define get_wallclock() native_get_wallclock()
|
|
#define set_wallclock(x) native_set_wallclock(x)
|
|
|
|
#endif /* CONFIG_PARAVIRT */
|
|
|
|
extern unsigned long __init calibrate_cpu(void);
|
|
|
|
#endif /* _ASM_X86_TIME_H */
|