/* 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); unsigned int aperfmperf_get_khz(int cpu); #endif /* ARCH_X86_CPU_H */Overall Contributors
Person | Tokens | Prop | Commits | CommitProp |
Dave Jones | 57 | 26.64% | 1 | 5.88% |
Jan Beulich | 35 | 16.36% | 2 | 11.76% |
Alex Shi | 34 | 15.89% | 1 | 5.88% |
Thomas Petazzoni | 22 | 10.28% | 1 | 5.88% |
Yinghai Lu | 13 | 6.07% | 2 | 11.76% |
Borislav Petkov | 13 | 6.07% | 3 | 17.65% |
Laura Abbott | 11 | 5.14% | 1 | 5.88% |
H. Peter Anvin | 10 | 4.67% | 1 | 5.88% |
Rafael J. Wysocki | 8 | 3.74% | 1 | 5.88% |
Andrew Morton | 7 | 3.27% | 1 | 5.88% |
Robert Richter | 2 | 0.93% | 1 | 5.88% |
Andi Kleen | 1 | 0.47% | 1 | 5.88% |
Greg Kroah-Hartman | 1 | 0.47% | 1 | 5.88% |
Total | 214 | 100.00% | 17 | 100.00% |