blob: 9469ecb5aeb8ddcd69dd2a5ebc26ef0c1e6ddf41 [file] [log] [blame]
Yinghai Ludcd32b62008-06-20 08:18:09 +02001#ifndef ARCH_X86_CPU_H
2
3#define ARCH_X86_CPU_H
Linus Torvalds1da177e2005-04-16 15:20:36 -07004
5struct cpu_model_info {
6 int vendor;
7 int family;
Jan Beulich02dde8b2009-03-12 12:08:49 +00008 const char *model_names[16];
Linus Torvalds1da177e2005-04-16 15:20:36 -07009};
10
11/* attempt to consolidate cpu attributes */
12struct cpu_dev {
Jan Beulich02dde8b2009-03-12 12:08:49 +000013 const char * c_vendor;
Linus Torvalds1da177e2005-04-16 15:20:36 -070014
15 /* some have two possibilities for cpuid string */
Jan Beulich02dde8b2009-03-12 12:08:49 +000016 const char * c_ident[2];
Linus Torvalds1da177e2005-04-16 15:20:36 -070017
18 struct cpu_model_info c_models[4];
19
Thomas Petazzoni03ae5762008-02-15 12:00:23 +010020 void (*c_early_init)(struct cpuinfo_x86 *c);
Linus Torvalds1da177e2005-04-16 15:20:36 -070021 void (*c_init)(struct cpuinfo_x86 * c);
22 void (*c_identify)(struct cpuinfo_x86 * c);
23 unsigned int (*c_size_cache)(struct cpuinfo_x86 * c, unsigned int size);
Yinghai Lu10a434f2008-09-04 21:09:45 +020024 int c_x86_vendor;
Linus Torvalds1da177e2005-04-16 15:20:36 -070025};
26
Yinghai Lu10a434f2008-09-04 21:09:45 +020027#define cpu_dev_register(cpu_devX) \
Jan Beulich02dde8b2009-03-12 12:08:49 +000028 static const struct cpu_dev *const __cpu_dev_##cpu_devX __used \
Yinghai Lu10a434f2008-09-04 21:09:45 +020029 __attribute__((__section__(".x86_cpu_dev.init"))) = \
30 &cpu_devX;
Linus Torvalds1da177e2005-04-16 15:20:36 -070031
Jan Beulich02dde8b2009-03-12 12:08:49 +000032extern const struct cpu_dev *const __x86_cpu_dev_start[],
33 *const __x86_cpu_dev_end[];
Thomas Petazzoni03ae5762008-02-15 12:00:23 +010034
Linus Torvalds1da177e2005-04-16 15:20:36 -070035extern void display_cacheinfo(struct cpuinfo_x86 *c);
Robert Richter9e26d842008-06-06 12:01:13 +020036
Yinghai Ludcd32b62008-06-20 08:18:09 +020037#endif