aboutsummaryrefslogtreecommitdiffstats
path: root/arch
diff options
context:
space:
mode:
Diffstat (limited to 'arch')
-rw-r--r--arch/x86/kernel/cpu/common.c8
-rw-r--r--arch/x86/kernel/cpu/common_64.c111
2 files changed, 119 insertions, 0 deletions
diff --git a/arch/x86/kernel/cpu/common.c b/arch/x86/kernel/cpu/common.c
index e0ca51f4f2d3..9128ba0c8d33 100644
--- a/arch/x86/kernel/cpu/common.c
+++ b/arch/x86/kernel/cpu/common.c
@@ -93,6 +93,7 @@ DEFINE_PER_CPU_PAGE_ALIGNED(struct gdt_page, gdt_page) = { .gdt = {
93#endif 93#endif
94EXPORT_PER_CPU_SYMBOL_GPL(gdt_page); 94EXPORT_PER_CPU_SYMBOL_GPL(gdt_page);
95 95
96#ifdef CONFIG_X86_32
96static int cachesize_override __cpuinitdata = -1; 97static int cachesize_override __cpuinitdata = -1;
97static int disable_x86_serial_nr __cpuinitdata = 1; 98static int disable_x86_serial_nr __cpuinitdata = 1;
98 99
@@ -195,6 +196,13 @@ static int __init x86_serial_nr_setup(char *s)
195 return 1; 196 return 1;
196} 197}
197__setup("serialnumber", x86_serial_nr_setup); 198__setup("serialnumber", x86_serial_nr_setup);
199#else
200/* Probe for the CPUID instruction */
201static inline int have_cpuid_p(void)
202{
203 return 1;
204}
205#endif
198 206
199__u32 cleared_cpu_caps[NCAPINTS] __cpuinitdata; 207__u32 cleared_cpu_caps[NCAPINTS] __cpuinitdata;
200 208
diff --git a/arch/x86/kernel/cpu/common_64.c b/arch/x86/kernel/cpu/common_64.c
index b4890504284d..40c9d89cc14a 100644
--- a/arch/x86/kernel/cpu/common_64.c
+++ b/arch/x86/kernel/cpu/common_64.c
@@ -92,6 +92,117 @@ DEFINE_PER_CPU_PAGE_ALIGNED(struct gdt_page, gdt_page) = { .gdt = {
92#endif 92#endif
93EXPORT_PER_CPU_SYMBOL_GPL(gdt_page); 93EXPORT_PER_CPU_SYMBOL_GPL(gdt_page);
94 94
95#ifdef CONFIG_X86_32
96static int cachesize_override __cpuinitdata = -1;
97static int disable_x86_serial_nr __cpuinitdata = 1;
98
99static int __init cachesize_setup(char *str)
100{
101 get_option(&str, &cachesize_override);
102 return 1;
103}
104__setup("cachesize=", cachesize_setup);
105
106/*
107 * Naming convention should be: <Name> [(<Codename>)]
108 * This table only is used unless init_<vendor>() below doesn't set it;
109 * in particular, if CPUID levels 0x80000002..4 are supported, this isn't used
110 *
111 */
112
113/* Look up CPU names by table lookup. */
114static char __cpuinit *table_lookup_model(struct cpuinfo_x86 *c)
115{
116 struct cpu_model_info *info;
117
118 if (c->x86_model >= 16)
119 return NULL; /* Range check */
120
121 if (!this_cpu)
122 return NULL;
123
124 info = this_cpu->c_models;
125
126 while (info && info->family) {
127 if (info->family == c->x86)
128 return info->model_names[c->x86_model];
129 info++;
130 }
131 return NULL; /* Not found */
132}
133
134static int __init x86_fxsr_setup(char *s)
135{
136 setup_clear_cpu_cap(X86_FEATURE_FXSR);
137 setup_clear_cpu_cap(X86_FEATURE_XMM);
138 return 1;
139}
140__setup("nofxsr", x86_fxsr_setup);
141
142static int __init x86_sep_setup(char *s)
143{
144 setup_clear_cpu_cap(X86_FEATURE_SEP);
145 return 1;
146}
147__setup("nosep", x86_sep_setup);
148
149/* Standard macro to see if a specific flag is changeable */
150static inline int flag_is_changeable_p(u32 flag)
151{
152 u32 f1, f2;
153
154 asm("pushfl\n\t"
155 "pushfl\n\t"
156 "popl %0\n\t"
157 "movl %0,%1\n\t"
158 "xorl %2,%0\n\t"
159 "pushl %0\n\t"
160 "popfl\n\t"
161 "pushfl\n\t"
162 "popl %0\n\t"
163 "popfl\n\t"
164 : "=&r" (f1), "=&r" (f2)
165 : "ir" (flag));
166
167 return ((f1^f2) & flag) != 0;
168}
169
170/* Probe for the CPUID instruction */
171static int __cpuinit have_cpuid_p(void)
172{
173 return flag_is_changeable_p(X86_EFLAGS_ID);
174}
175
176static void __cpuinit squash_the_stupid_serial_number(struct cpuinfo_x86 *c)
177{
178 if (cpu_has(c, X86_FEATURE_PN) && disable_x86_serial_nr) {
179 /* Disable processor serial number */
180 unsigned long lo, hi;
181 rdmsr(MSR_IA32_BBL_CR_CTL, lo, hi);
182 lo |= 0x200000;
183 wrmsr(MSR_IA32_BBL_CR_CTL, lo, hi);
184 printk(KERN_NOTICE "CPU serial number disabled.\n");
185 clear_cpu_cap(c, X86_FEATURE_PN);
186
187 /* Disabling the serial number may affect the cpuid level */
188 c->cpuid_level = cpuid_eax(0);
189 }
190}
191
192static int __init x86_serial_nr_setup(char *s)
193{
194 disable_x86_serial_nr = 0;
195 return 1;
196}
197__setup("serialnumber", x86_serial_nr_setup);
198#else
199/* Probe for the CPUID instruction */
200static inline int have_cpuid_p(void)
201{
202 return 1;
203}
204#endif
205
95__u32 cleared_cpu_caps[NCAPINTS] __cpuinitdata; 206__u32 cleared_cpu_caps[NCAPINTS] __cpuinitdata;
96 207
97/* Current gdt points %fs at the "master" per-cpu area: after this, 208/* Current gdt points %fs at the "master" per-cpu area: after this,