2007-03-06 01:42:05 -08:00
/*
2007-10-12 23:04:23 +02:00
* x86 TSC related functions
2007-03-06 01:42:05 -08:00
*/
2007-10-12 23:04:23 +02:00
# ifndef _ASM_X86_TSC_H
# define _ASM_X86_TSC_H
2007-03-06 01:42:05 -08:00
# include <asm/processor.h>
2007-10-12 23:04:23 +02:00
# define NS_SCALE 10 /* 2^10, carefully chosen */
# define US_SCALE 32 /* 2^32, arbitralrily chosen */
2007-03-06 01:42:05 -08:00
/*
* Standard way to access the cycle counter .
*/
typedef unsigned long long cycles_t ;
extern unsigned int cpu_khz ;
extern unsigned int tsc_khz ;
2008-01-30 13:31:26 +01:00
extern void disable_TSC ( void ) ;
2007-03-06 01:42:05 -08:00
static inline cycles_t get_cycles ( void )
{
unsigned long long ret = 0 ;
# ifndef CONFIG_X86_TSC
if ( ! cpu_has_tsc )
return 0 ;
# endif
rdtscll ( ret ) ;
2008-01-30 13:33:24 +01:00
2007-03-06 01:42:05 -08:00
return ret ;
}
2008-04-27 00:39:36 +01:00
static __always_inline cycles_t vget_cycles ( void )
2007-03-06 01:42:05 -08:00
{
2007-05-02 19:27:21 +02:00
/*
2008-01-30 13:32:39 +01:00
* We only do VDSOs on TSC capable CPUs , so this shouldnt
* access boot_cpu_data ( which is not VDSO - safe ) :
2007-05-02 19:27:21 +02:00
*/
2008-01-30 13:32:39 +01:00
# ifndef CONFIG_X86_TSC
if ( ! cpu_has_tsc )
return 0 ;
2008-01-30 13:31:03 +01:00
# endif
2008-03-23 01:03:47 -07:00
return ( cycles_t ) __native_read_tsc ( ) ;
2008-01-30 13:32:39 +01:00
}
2008-01-30 13:31:03 +01:00
2007-03-06 01:42:05 -08:00
extern void tsc_init ( void ) ;
2007-05-02 19:27:08 +02:00
extern void mark_tsc_unstable ( char * reason ) ;
2007-03-06 01:42:05 -08:00
extern int unsynchronized_tsc ( void ) ;
2007-07-19 01:49:23 -07:00
int check_tsc_unstable ( void ) ;
2007-03-06 01:42:05 -08:00
/*
* Boot - time check whether the TSCs are synchronized across
* all CPUs / cores :
*/
extern void check_tsc_sync_source ( int cpu ) ;
extern void check_tsc_sync_target ( void ) ;
2008-01-30 13:30:18 +01:00
extern int notsc_setup ( char * ) ;
2007-10-12 23:04:06 +02:00
2007-03-06 01:42:05 -08:00
# endif