/* SPDX-License-Identifier: GPL-2.0 */ #ifndef ARCH_X86_CPU_H #define ARCH_X86_CPU_H /* attempt to consolidate cpu attributes */ struct cpu_dev { const char *c_vendor; /* some have two possibilities for cpuid string */ const char *c_ident[2]; void (*c_early_init)(struct cpuinfo_x86 *); void (*c_bsp_init)(struct cpuinfo_x86 *); void (*c_init)(struct cpuinfo_x86 *); void (*c_identify)(struct cpuinfo_x86 *); void (*c_detect_tlb)(struct cpuinfo_x86 *); void (*c_bsp_resume)(struct cpuinfo_x86 *); int c_x86_vendor; #ifdef CONFIG_X86_32 /* Optional vendor specific routine to obtain the cache size. */ unsigned int (*legacy_cache_size)(struct cpuinfo_x86 *, unsigned int); /* Family/stepping-based lookup table for model names. */ struct legacy_cpu_model_info { int family; const char *model_names[16]; } legacy_models[5]; #endif }; struct _tlb_table { unsigned char descriptor; char tlb_type; unsigned int entries; /* unsigned int ways; */ char info[128]; }; #define cpu_dev_register(cpu_devX) \ static const struct cpu_dev *const __cpu_dev_##cpu_devX __used \ __attribute__((__section__(".x86_cpu_dev.init"))) = \ &cpu_devX; extern const struct cpu_dev *const __x86_cpu_dev_start[], *const __x86_cpu_dev_end[]; extern void get_cpu_cap(struct cpuinfo_x86 *c); extern void cpu_detect_cache_sizes(struct cpuinfo_x86 *c); #endif /* ARCH_X86_CPU_H */Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Dave Jones | 57 | 27.67% | 1 | 6.25% |
Jan Beulich | 35 | 16.99% | 2 | 12.50% |
Alex Shi | 34 | 16.50% | 1 | 6.25% |
Thomas Petazzoni | 22 | 10.68% | 1 | 6.25% |
Yinghai Lu | 13 | 6.31% | 2 | 12.50% |
Borislav Petkov | 13 | 6.31% | 3 | 18.75% |
Laura Abbott | 11 | 5.34% | 1 | 6.25% |
H. Peter Anvin | 10 | 4.85% | 1 | 6.25% |
Andrew Morton | 7 | 3.40% | 1 | 6.25% |
Robert Richter | 2 | 0.97% | 1 | 6.25% |
Greg Kroah-Hartman | 1 | 0.49% | 1 | 6.25% |
Andi Kleen | 1 | 0.49% | 1 | 6.25% |
Total | 206 | 100.00% | 16 | 100.00% |