aboutsummaryrefslogtreecommitdiffstats
diff options
context:
space:
mode:
authorShaohua Li <shaohua.li@intel.com>2006-03-27 04:15:24 -0500
committerLinus Torvalds <torvalds@g5.osdl.org>2006-03-27 11:44:44 -0500
commitb06be912a3ad68c69dba0ed6e92723140020e392 (patch)
tree4de1f2c2804ae3230e14e94d3f33a14467889233
parent0806903316d516a3b3851c51cea5c71724d9051d (diff)
[PATCH] x86: don't use cpuid.2 to determine cache info if cpuid.4 is supported
Don't use cpuid.2 to determine cache info if cpuid.4 is supported. The exception is P4 trace cache. We always use cpuid.2 to get trace cache under P4. Signed-off-by: Shaohua Li <shaohua.li@intel.com> Cc: Andi Kleen <ak@muc.de> Signed-off-by: Andrew Morton <akpm@osdl.org> Signed-off-by: Linus Torvalds <torvalds@osdl.org>
-rw-r--r--arch/i386/kernel/cpu/intel_cacheinfo.c69
1 files changed, 41 insertions, 28 deletions
diff --git a/arch/i386/kernel/cpu/intel_cacheinfo.c b/arch/i386/kernel/cpu/intel_cacheinfo.c
index 7e7fd4e67dd0..9df87b03612c 100644
--- a/arch/i386/kernel/cpu/intel_cacheinfo.c
+++ b/arch/i386/kernel/cpu/intel_cacheinfo.c
@@ -225,11 +225,19 @@ unsigned int __cpuinit init_intel_cacheinfo(struct cpuinfo_x86 *c)
225 } 225 }
226 } 226 }
227 } 227 }
228 if (c->cpuid_level > 1) { 228 /*
229 * Don't use cpuid2 if cpuid4 is supported. For P4, we use cpuid2 for
230 * trace cache
231 */
232 if ((num_cache_leaves == 0 || c->x86 == 15) && c->cpuid_level > 1) {
229 /* supports eax=2 call */ 233 /* supports eax=2 call */
230 int i, j, n; 234 int i, j, n;
231 int regs[4]; 235 int regs[4];
232 unsigned char *dp = (unsigned char *)regs; 236 unsigned char *dp = (unsigned char *)regs;
237 int only_trace = 0;
238
239 if (num_cache_leaves != 0 && c->x86 == 15)
240 only_trace = 1;
233 241
234 /* Number of times to iterate */ 242 /* Number of times to iterate */
235 n = cpuid_eax(2) & 0xFF; 243 n = cpuid_eax(2) & 0xFF;
@@ -251,6 +259,8 @@ unsigned int __cpuinit init_intel_cacheinfo(struct cpuinfo_x86 *c)
251 while (cache_table[k].descriptor != 0) 259 while (cache_table[k].descriptor != 0)
252 { 260 {
253 if (cache_table[k].descriptor == des) { 261 if (cache_table[k].descriptor == des) {
262 if (only_trace && cache_table[k].cache_type != LVL_TRACE)
263 break;
254 switch (cache_table[k].cache_type) { 264 switch (cache_table[k].cache_type) {
255 case LVL_1_INST: 265 case LVL_1_INST:
256 l1i += cache_table[k].size; 266 l1i += cache_table[k].size;
@@ -276,43 +286,46 @@ unsigned int __cpuinit init_intel_cacheinfo(struct cpuinfo_x86 *c)
276 } 286 }
277 } 287 }
278 } 288 }
289 }
279 290
280 if (new_l1d) 291 if (new_l1d)
281 l1d = new_l1d; 292 l1d = new_l1d;
282 293
283 if (new_l1i) 294 if (new_l1i)
284 l1i = new_l1i; 295 l1i = new_l1i;
285 296
286 if (new_l2) { 297 if (new_l2) {
287 l2 = new_l2; 298 l2 = new_l2;
288#ifdef CONFIG_SMP 299#ifdef CONFIG_SMP
289 cpu_llc_id[cpu] = l2_id; 300 cpu_llc_id[cpu] = l2_id;
290#endif 301#endif
291 } 302 }
292 303
293 if (new_l3) { 304 if (new_l3) {
294 l3 = new_l3; 305 l3 = new_l3;
295#ifdef CONFIG_SMP 306#ifdef CONFIG_SMP
296 cpu_llc_id[cpu] = l3_id; 307 cpu_llc_id[cpu] = l3_id;
297#endif 308#endif
298 }
299
300 if ( trace )
301 printk (KERN_INFO "CPU: Trace cache: %dK uops", trace);
302 else if ( l1i )
303 printk (KERN_INFO "CPU: L1 I cache: %dK", l1i);
304 if ( l1d )
305 printk(", L1 D cache: %dK\n", l1d);
306 else
307 printk("\n");
308 if ( l2 )
309 printk(KERN_INFO "CPU: L2 cache: %dK\n", l2);
310 if ( l3 )
311 printk(KERN_INFO "CPU: L3 cache: %dK\n", l3);
312
313 c->x86_cache_size = l3 ? l3 : (l2 ? l2 : (l1i+l1d));
314 } 309 }
315 310
311 if (trace)
312 printk (KERN_INFO "CPU: Trace cache: %dK uops", trace);
313 else if ( l1i )
314 printk (KERN_INFO "CPU: L1 I cache: %dK", l1i);
315
316 if (l1d)
317 printk(", L1 D cache: %dK\n", l1d);
318 else
319 printk("\n");
320
321 if (l2)
322 printk(KERN_INFO "CPU: L2 cache: %dK\n", l2);
323
324 if (l3)
325 printk(KERN_INFO "CPU: L3 cache: %dK\n", l3);
326
327 c->x86_cache_size = l3 ? l3 : (l2 ? l2 : (l1i+l1d));
328
316 return l2; 329 return l2;
317} 330}
318 331