⭐ 欢迎来到虫虫下载站! | 📦 资源下载 📁 资源专辑 ℹ️ 关于我们
⭐ 虫虫下载站

📄 setup.c

📁 linux-2.6.15.6
💻 C
📖 第 1 页 / 共 3 页
字号:
	if (!cpu_has(c, X86_FEATURE_HT) || cpu_has(c, X86_FEATURE_CMP_LEGACY))		return;	smp_num_siblings = (ebx & 0xff0000) >> 16;	if (smp_num_siblings == 1) {		printk(KERN_INFO  "CPU: Hyper-Threading is disabled\n");	} else if (smp_num_siblings > 1 ) {		if (smp_num_siblings > NR_CPUS) {			printk(KERN_WARNING "CPU: Unsupported number of the siblings %d", smp_num_siblings);			smp_num_siblings = 1;			return;		}		index_msb = get_count_order(smp_num_siblings);		phys_proc_id[cpu] = phys_pkg_id(index_msb);		printk(KERN_INFO  "CPU: Physical Processor ID: %d\n",		       phys_proc_id[cpu]);		smp_num_siblings = smp_num_siblings / c->x86_max_cores;		index_msb = get_count_order(smp_num_siblings) ;		core_bits = get_count_order(c->x86_max_cores);		cpu_core_id[cpu] = phys_pkg_id(index_msb) &					       ((1 << core_bits) - 1);		if (c->x86_max_cores > 1)			printk(KERN_INFO  "CPU: Processor Core ID: %d\n",			       cpu_core_id[cpu]);	}#endif}/* * find out the number of processor cores on the die */static int __cpuinit intel_num_cpu_cores(struct cpuinfo_x86 *c){	unsigned int eax;	if (c->cpuid_level < 4)		return 1;	__asm__("cpuid"		: "=a" (eax)		: "0" (4), "c" (0)		: "bx", "dx");	if (eax & 0x1f)		return ((eax >> 26) + 1);	else		return 1;}static void srat_detect_node(void){#ifdef CONFIG_NUMA	unsigned node;	int cpu = smp_processor_id();	/* Don't do the funky fallback heuristics the AMD version employs	   for now. */	node = apicid_to_node[hard_smp_processor_id()];	if (node == NUMA_NO_NODE)		node = 0;	numa_set_node(cpu, node);	if (acpi_numa > 0)		printk(KERN_INFO "CPU %d -> Node %d\n", cpu, node);#endif}static void __cpuinit init_intel(struct cpuinfo_x86 *c){	/* Cache sizes */	unsigned n;	init_intel_cacheinfo(c);	n = c->extended_cpuid_level;	if (n >= 0x80000008) {		unsigned eax = cpuid_eax(0x80000008);		c->x86_virt_bits = (eax >> 8) & 0xff;		c->x86_phys_bits = eax & 0xff;		/* CPUID workaround for Intel 0F34 CPU */		if (c->x86_vendor == X86_VENDOR_INTEL &&		    c->x86 == 0xF && c->x86_model == 0x3 &&		    c->x86_mask == 0x4)			c->x86_phys_bits = 36;	}	if (c->x86 == 15)		c->x86_cache_alignment = c->x86_clflush_size * 2;	if (c->x86 >= 15)		set_bit(X86_FEATURE_CONSTANT_TSC, &c->x86_capability); 	c->x86_max_cores = intel_num_cpu_cores(c);	srat_detect_node();}static void __cpuinit get_cpu_vendor(struct cpuinfo_x86 *c){	char *v = c->x86_vendor_id;	if (!strcmp(v, "AuthenticAMD"))		c->x86_vendor = X86_VENDOR_AMD;	else if (!strcmp(v, "GenuineIntel"))		c->x86_vendor = X86_VENDOR_INTEL;	else		c->x86_vendor = X86_VENDOR_UNKNOWN;}struct cpu_model_info {	int vendor;	int family;	char *model_names[16];};/* Do some early cpuid on the boot CPU to get some parameter that are   needed before check_bugs. Everything advanced is in identify_cpu   below. */void __cpuinit early_identify_cpu(struct cpuinfo_x86 *c){	u32 tfms;	c->loops_per_jiffy = loops_per_jiffy;	c->x86_cache_size = -1;	c->x86_vendor = X86_VENDOR_UNKNOWN;	c->x86_model = c->x86_mask = 0;	/* So far unknown... */	c->x86_vendor_id[0] = '\0'; /* Unset */	c->x86_model_id[0] = '\0';  /* Unset */	c->x86_clflush_size = 64;	c->x86_cache_alignment = c->x86_clflush_size;	c->x86_max_cores = 1;	c->extended_cpuid_level = 0;	memset(&c->x86_capability, 0, sizeof c->x86_capability);	/* Get vendor name */	cpuid(0x00000000, (unsigned int *)&c->cpuid_level,	      (unsigned int *)&c->x86_vendor_id[0],	      (unsigned int *)&c->x86_vendor_id[8],	      (unsigned int *)&c->x86_vendor_id[4]);			get_cpu_vendor(c);	/* Initialize the standard set of capabilities */	/* Note that the vendor-specific code below might override */	/* Intel-defined flags: level 0x00000001 */	if (c->cpuid_level >= 0x00000001) {		__u32 misc;		cpuid(0x00000001, &tfms, &misc, &c->x86_capability[4],		      &c->x86_capability[0]);		c->x86 = (tfms >> 8) & 0xf;		c->x86_model = (tfms >> 4) & 0xf;		c->x86_mask = tfms & 0xf;		if (c->x86 == 0xf)			c->x86 += (tfms >> 20) & 0xff;		if (c->x86 >= 0x6)			c->x86_model += ((tfms >> 16) & 0xF) << 4;		if (c->x86_capability[0] & (1<<19)) 			c->x86_clflush_size = ((misc >> 8) & 0xff) * 8;	} else {		/* Have CPUID level 0 only - unheard of */		c->x86 = 4;	}#ifdef CONFIG_SMP	phys_proc_id[smp_processor_id()] = (cpuid_ebx(1) >> 24) & 0xff;#endif}/* * This does the hard work of actually picking apart the CPU stuff... */void __cpuinit identify_cpu(struct cpuinfo_x86 *c){	int i;	u32 xlvl;	early_identify_cpu(c);	/* AMD-defined flags: level 0x80000001 */	xlvl = cpuid_eax(0x80000000);	c->extended_cpuid_level = xlvl;	if ((xlvl & 0xffff0000) == 0x80000000) {		if (xlvl >= 0x80000001) {			c->x86_capability[1] = cpuid_edx(0x80000001);			c->x86_capability[6] = cpuid_ecx(0x80000001);		}		if (xlvl >= 0x80000004)			get_model_name(c); /* Default name */	}	/* Transmeta-defined flags: level 0x80860001 */	xlvl = cpuid_eax(0x80860000);	if ((xlvl & 0xffff0000) == 0x80860000) {		/* Don't set x86_cpuid_level here for now to not confuse. */		if (xlvl >= 0x80860001)			c->x86_capability[2] = cpuid_edx(0x80860001);	}	/*	 * Vendor-specific initialization.  In this section we	 * canonicalize the feature flags, meaning if there are	 * features a certain CPU supports which CPUID doesn't	 * tell us, CPUID claiming incorrect flags, or other bugs,	 * we handle them here.	 *	 * At the end of this section, c->x86_capability better	 * indicate the features this CPU genuinely supports!	 */	switch (c->x86_vendor) {	case X86_VENDOR_AMD:		init_amd(c);		break;	case X86_VENDOR_INTEL:		init_intel(c);		break;	case X86_VENDOR_UNKNOWN:	default:		display_cacheinfo(c);		break;	}	select_idle_routine(c);	detect_ht(c); 	/*	 * On SMP, boot_cpu_data holds the common feature set between	 * all CPUs; so make sure that we indicate which features are	 * common between the CPUs.  The first time this routine gets	 * executed, c == &boot_cpu_data.	 */	if (c != &boot_cpu_data) {		/* AND the already accumulated flags with these */		for (i = 0 ; i < NCAPINTS ; i++)			boot_cpu_data.x86_capability[i] &= c->x86_capability[i];	}#ifdef CONFIG_X86_MCE	mcheck_init(c);#endif	if (c == &boot_cpu_data)		mtrr_bp_init();	else		mtrr_ap_init();#ifdef CONFIG_NUMA	numa_add_cpu(smp_processor_id());#endif} void __cpuinit print_cpu_info(struct cpuinfo_x86 *c){	if (c->x86_model_id[0])		printk("%s", c->x86_model_id);	if (c->x86_mask || c->cpuid_level >= 0) 		printk(" stepping %02x\n", c->x86_mask);	else		printk("\n");}/* *	Get CPU information for use by the procfs. */static int show_cpuinfo(struct seq_file *m, void *v){	struct cpuinfo_x86 *c = v;	/* 	 * These flag bits must match the definitions in <asm/cpufeature.h>.	 * NULL means this bit is undefined or reserved; either way it doesn't	 * have meaning as far as Linux is concerned.  Note that it's important	 * to realize there is a difference between this table and CPUID -- if	 * applications want to get the raw CPUID data, they should access	 * /dev/cpu/<cpu_nr>/cpuid instead.	 */	static char *x86_cap_flags[] = {		/* Intel-defined */	        "fpu", "vme", "de", "pse", "tsc", "msr", "pae", "mce",	        "cx8", "apic", NULL, "sep", "mtrr", "pge", "mca", "cmov",	        "pat", "pse36", "pn", "clflush", NULL, "dts", "acpi", "mmx",	        "fxsr", "sse", "sse2", "ss", "ht", "tm", "ia64", NULL,		/* AMD-defined */		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, "syscall", NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, "nx", NULL, "mmxext", NULL,		NULL, "fxsr_opt", NULL, NULL, NULL, "lm", "3dnowext", "3dnow",		/* Transmeta-defined */		"recovery", "longrun", NULL, "lrti", NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* Other (Linux-defined) */		"cxmmx", NULL, "cyrix_arr", "centaur_mcr", NULL,		"constant_tsc", NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* Intel-defined (#2) */		"pni", NULL, NULL, "monitor", "ds_cpl", "vmx", NULL, "est",		"tm2", NULL, "cid", NULL, NULL, "cx16", "xtpr", NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* VIA/Cyrix/Centaur-defined */		NULL, NULL, "rng", "rng_en", NULL, NULL, "ace", "ace_en",		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* AMD-defined (#2) */		"lahf_lm", "cmp_legacy", NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,	};	static char *x86_power_flags[] = { 		"ts",	/* temperature sensor */		"fid",  /* frequency id control */		"vid",  /* voltage id control */		"ttp",  /* thermal trip */		"tm",		"stc"	};#ifdef CONFIG_SMP	if (!cpu_online(c-cpu_data))		return 0;#endif	seq_printf(m,"processor\t: %u\n"		     "vendor_id\t: %s\n"		     "cpu family\t: %d\n"		     "model\t\t: %d\n"		     "model name\t: %s\n",		     (unsigned)(c-cpu_data),		     c->x86_vendor_id[0] ? c->x86_vendor_id : "unknown",		     c->x86,		     (int)c->x86_model,		     c->x86_model_id[0] ? c->x86_model_id : "unknown");		if (c->x86_mask || c->cpuid_level >= 0)		seq_printf(m, "stepping\t: %d\n", c->x86_mask);	else		seq_printf(m, "stepping\t: unknown\n");		if (cpu_has(c,X86_FEATURE_TSC)) {		seq_printf(m, "cpu MHz\t\t: %u.%03u\n",			     cpu_khz / 1000, (cpu_khz % 1000));	}	/* Cache size */	if (c->x86_cache_size >= 0) 		seq_printf(m, "cache size\t: %d KB\n", c->x86_cache_size);	#ifdef CONFIG_SMP	if (smp_num_siblings * c->x86_max_cores > 1) {		int cpu = c - cpu_data;		seq_printf(m, "physical id\t: %d\n", phys_proc_id[cpu]);		seq_printf(m, "siblings\t: %d\n", cpus_weight(cpu_core_map[cpu]));		seq_printf(m, "core id\t\t: %d\n", cpu_core_id[cpu]);		seq_printf(m, "cpu cores\t: %d\n", c->booted_cores);	}#endif		seq_printf(m,	        "fpu\t\t: yes\n"	        "fpu_exception\t: yes\n"	        "cpuid level\t: %d\n"	        "wp\t\t: yes\n"	        "flags\t\t:",		   c->cpuid_level);	{ 		int i; 		for ( i = 0 ; i < 32*NCAPINTS ; i++ )			if ( test_bit(i, &c->x86_capability) &&			     x86_cap_flags[i] != NULL )				seq_printf(m, " %s", x86_cap_flags[i]);	}			seq_printf(m, "\nbogomips\t: %lu.%02lu\n",		   c->loops_per_jiffy/(500000/HZ),		   (c->loops_per_jiffy/(5000/HZ)) % 100);	if (c->x86_tlbsize > 0) 		seq_printf(m, "TLB size\t: %d 4K pages\n", c->x86_tlbsize);	seq_printf(m, "clflush size\t: %d\n", c->x86_clflush_size);	seq_printf(m, "cache_alignment\t: %d\n", c->x86_cache_alignment);	seq_printf(m, "address sizes\t: %u bits physical, %u bits virtual\n", 		   c->x86_phys_bits, c->x86_virt_bits);	seq_printf(m, "power management:");	{		unsigned i;		for (i = 0; i < 32; i++) 			if (c->x86_power & (1 << i)) {				if (i < ARRAY_SIZE(x86_power_flags))					seq_printf(m, " %s", x86_power_flags[i]);				else					seq_printf(m, " [%d]", i);			}	}	seq_printf(m, "\n\n");	return 0;}static void *c_start(struct seq_file *m, loff_t *pos){	return *pos < NR_CPUS ? cpu_data + *pos : NULL;}static void *c_next(struct seq_file *m, void *v, loff_t *pos){	++*pos;	return c_start(m, pos);}static void c_stop(struct seq_file *m, void *v){}struct seq_operations cpuinfo_op = {	.start =c_start,	.next =	c_next,	.stop =	c_stop,	.show =	show_cpuinfo,};

⌨️ 快捷键说明

复制代码 Ctrl + C
搜索代码 Ctrl + F
全屏模式 F11
切换主题 Ctrl + Shift + D
显示快捷键 ?
增大字号 Ctrl + =
减小字号 Ctrl + -