Commit | Line | Data |
---|---|---|
1353ebb4 | 1 | /* |
1353ebb4 JF |
2 | * Copyright (C) 1994 Linus Torvalds |
3 | * | |
4 | * Cyrix stuff, June 1998 by: | |
5 | * - Rafael R. Reilova (moved everything from head.S), | |
6 | * <rreilova@ececs.uc.edu> | |
7 | * - Channing Corn (tests & fixes), | |
8 | * - Andrew D. Balsa (code cleanup). | |
9 | */ | |
10 | #include <linux/init.h> | |
11 | #include <linux/utsname.h> | |
91eb1b79 | 12 | #include <asm/bugs.h> |
1353ebb4 | 13 | #include <asm/processor.h> |
7ebad705 | 14 | #include <asm/processor-flags.h> |
952f07ec | 15 | #include <asm/fpu/internal.h> |
1353ebb4 JF |
16 | #include <asm/msr.h> |
17 | #include <asm/paravirt.h> | |
18 | #include <asm/alternative.h> | |
62a67e12 | 19 | #include <asm/pgtable.h> |
d1163651 | 20 | #include <asm/set_memory.h> |
1353ebb4 | 21 | |
1353ebb4 JF |
22 | void __init check_bugs(void) |
23 | { | |
24 | identify_boot_cpu(); | |
55a36b65 | 25 | |
62a67e12 BP |
26 | if (!IS_ENABLED(CONFIG_SMP)) { |
27 | pr_info("CPU: "); | |
28 | print_cpu_info(&boot_cpu_data); | |
29 | } | |
30 | ||
31 | #ifdef CONFIG_X86_32 | |
55a36b65 BP |
32 | /* |
33 | * Check whether we are able to run this kernel safely on SMP. | |
34 | * | |
35 | * - i386 is no longer supported. | |
36 | * - In order to run on anything without a TSC, we need to be | |
37 | * compiled for a i486. | |
38 | */ | |
39 | if (boot_cpu_data.x86 < 4) | |
40 | panic("Kernel requires i486+ for 'invlpg' and other features"); | |
41 | ||
bfe4bb15 MV |
42 | init_utsname()->machine[1] = |
43 | '0' + (boot_cpu_data.x86 > 6 ? 6 : boot_cpu_data.x86); | |
1353ebb4 | 44 | alternative_instructions(); |
304bceda | 45 | |
4d164092 | 46 | fpu__init_check_bugs(); |
62a67e12 BP |
47 | #else /* CONFIG_X86_64 */ |
48 | alternative_instructions(); | |
49 | ||
50 | /* | |
51 | * Make sure the first 2MB area is not mapped by huge pages | |
52 | * There are typically fixed size MTRRs in there and overlapping | |
53 | * MTRRs into large pages causes slow downs. | |
54 | * | |
55 | * Right now we don't do that with gbpages because there seems | |
56 | * very little benefit for that case. | |
57 | */ | |
58 | if (!direct_gbpages) | |
59 | set_memory_4k((unsigned long)__va(0), 1); | |
60 | #endif | |
1353ebb4 | 61 | } |