xref: /openbmc/linux/arch/x86/include/asm/timer.h (revision 698eff63)
11965aae3SH. Peter Anvin #ifndef _ASM_X86_TIMER_H
21965aae3SH. Peter Anvin #define _ASM_X86_TIMER_H
3bb898558SAl Viro #include <linux/pm.h>
4bb898558SAl Viro #include <linux/percpu.h>
58e6dafd6SIngo Molnar #include <linux/interrupt.h>
65dd12c21SPeter Zijlstra #include <linux/math64.h>
7bb898558SAl Viro 
8bb898558SAl Viro #define TICK_SIZE (tick_nsec / 1000)
9bb898558SAl Viro 
10bb898558SAl Viro unsigned long long native_sched_clock(void);
1125c1a411SStephen Rothwell extern int recalibrate_cpu_khz(void);
12bb898558SAl Viro 
13bb898558SAl Viro extern int no_timer_check;
14bb898558SAl Viro 
15698eff63SPeter Zijlstra extern bool using_native_sched_clock(void);
16698eff63SPeter Zijlstra 
1720d1c86aSPeter Zijlstra /*
1820d1c86aSPeter Zijlstra  * We use the full linear equation: f(x) = a + b*x, in order to allow
1920d1c86aSPeter Zijlstra  * a continuous function in the face of dynamic freq changes.
2020d1c86aSPeter Zijlstra  *
2120d1c86aSPeter Zijlstra  * Continuity means that when our frequency changes our slope (b); we want to
2220d1c86aSPeter Zijlstra  * ensure that: f(t) == f'(t), which gives: a + b*t == a' + b'*t.
2320d1c86aSPeter Zijlstra  *
2420d1c86aSPeter Zijlstra  * Without an offset (a) the above would not be possible.
2520d1c86aSPeter Zijlstra  *
2620d1c86aSPeter Zijlstra  * See the comment near cycles_2_ns() for details on how we compute (b).
2720d1c86aSPeter Zijlstra  */
2820d1c86aSPeter Zijlstra struct cyc2ns_data {
2920d1c86aSPeter Zijlstra 	u32 cyc2ns_mul;
3020d1c86aSPeter Zijlstra 	u32 cyc2ns_shift;
3120d1c86aSPeter Zijlstra 	u64 cyc2ns_offset;
3220d1c86aSPeter Zijlstra 	u32 __count;
3320d1c86aSPeter Zijlstra 	/* u32 hole */
3420d1c86aSPeter Zijlstra }; /* 24 bytes -- do not grow */
3520d1c86aSPeter Zijlstra 
3620d1c86aSPeter Zijlstra extern struct cyc2ns_data *cyc2ns_read_begin(void);
3720d1c86aSPeter Zijlstra extern void cyc2ns_read_end(struct cyc2ns_data *);
38bb898558SAl Viro 
391965aae3SH. Peter Anvin #endif /* _ASM_X86_TIMER_H */
40