| Yinghai Lu | dcd32b6 | 2008-06-20 08:18:09 +0200 | [diff] [blame] | 1 | #ifndef ARCH_X86_CPU_H | 
| Yinghai Lu | dcd32b6 | 2008-06-20 08:18:09 +0200 | [diff] [blame] | 2 | #define ARCH_X86_CPU_H | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 3 |  | 
|  | 4 | struct cpu_model_info { | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 5 | int		vendor; | 
|  | 6 | int		family; | 
|  | 7 | const char	*model_names[16]; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 8 | }; | 
|  | 9 |  | 
|  | 10 | /* attempt to consolidate cpu attributes */ | 
|  | 11 | struct cpu_dev { | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 12 | const char	*c_vendor; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 13 |  | 
|  | 14 | /* some have two possibilities for cpuid string */ | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 15 | const char	*c_ident[2]; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 16 |  | 
|  | 17 | struct		cpu_model_info c_models[4]; | 
|  | 18 |  | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 19 | void            (*c_early_init)(struct cpuinfo_x86 *); | 
| Borislav Petkov | a110b5e | 2011-08-05 20:01:16 +0200 | [diff] [blame] | 20 | void		(*c_bsp_init)(struct cpuinfo_x86 *); | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 21 | void		(*c_init)(struct cpuinfo_x86 *); | 
|  | 22 | void		(*c_identify)(struct cpuinfo_x86 *); | 
| Alex Shi | e0ba94f | 2012-06-28 09:02:16 +0800 | [diff] [blame] | 23 | void		(*c_detect_tlb)(struct cpuinfo_x86 *); | 
| Jaswinder Singh Rajput | f2362e6 | 2009-03-23 02:06:51 +0530 | [diff] [blame] | 24 | unsigned int	(*c_size_cache)(struct cpuinfo_x86 *, unsigned int); | 
|  | 25 | int		c_x86_vendor; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 26 | }; | 
|  | 27 |  | 
| Alex Shi | e0ba94f | 2012-06-28 09:02:16 +0800 | [diff] [blame] | 28 | struct _tlb_table { | 
|  | 29 | unsigned char descriptor; | 
|  | 30 | char tlb_type; | 
|  | 31 | unsigned int entries; | 
|  | 32 | /* unsigned int ways; */ | 
|  | 33 | char info[128]; | 
|  | 34 | }; | 
|  | 35 |  | 
| Yinghai Lu | 10a434f | 2008-09-04 21:09:45 +0200 | [diff] [blame] | 36 | #define cpu_dev_register(cpu_devX) \ | 
| Jan Beulich | 02dde8b | 2009-03-12 12:08:49 +0000 | [diff] [blame] | 37 | static const struct cpu_dev *const __cpu_dev_##cpu_devX __used \ | 
| Yinghai Lu | 10a434f | 2008-09-04 21:09:45 +0200 | [diff] [blame] | 38 | __attribute__((__section__(".x86_cpu_dev.init"))) = \ | 
|  | 39 | &cpu_devX; | 
| Linus Torvalds | 1da177e | 2005-04-16 15:20:36 -0700 | [diff] [blame] | 40 |  | 
| Jan Beulich | 02dde8b | 2009-03-12 12:08:49 +0000 | [diff] [blame] | 41 | extern const struct cpu_dev *const __x86_cpu_dev_start[], | 
|  | 42 | *const __x86_cpu_dev_end[]; | 
| Thomas Petazzoni | 03ae576 | 2008-02-15 12:00:23 +0100 | [diff] [blame] | 43 |  | 
| H. Peter Anvin | c2b9ff2 | 2010-09-20 18:01:46 -0700 | [diff] [blame] | 44 | extern void get_cpu_cap(struct cpuinfo_x86 *c); | 
| Borislav Petkov | 27c13ec | 2009-11-21 14:01:45 +0100 | [diff] [blame] | 45 | extern void cpu_detect_cache_sizes(struct cpuinfo_x86 *c); | 
| Borislav Petkov | d059f24 | 2011-11-29 20:14:43 +0100 | [diff] [blame] | 46 | #endif /* ARCH_X86_CPU_H */ |