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

📄 setup_64.c

📁 linux 内核源代码
💻 C
📖 第 1 页 / 共 3 页
字号:
	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 == 0xf && c->x86_model >= 0x03) ||	    (c->x86 == 0x6 && c->x86_model >= 0x0e))		set_bit(X86_FEATURE_CONSTANT_TSC, &c->x86_capability);	if (c->x86 == 6)		set_bit(X86_FEATURE_REP_GOOD, &c->x86_capability);	if (c->x86 == 15)		set_bit(X86_FEATURE_SYNC_RDTSC, &c->x86_capability);	else		clear_bit(X86_FEATURE_SYNC_RDTSC, &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	c->phys_proc_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);	}	init_scattered_cpuid_features(c);	c->apicid = phys_pkg_id(0);	/*	 * 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_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;	int cpu = 0;	/* 	 * 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 const char *const 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", "pbe",		/* 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", "pdpe1gb", "rdtscp", 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", "k6_mtrr", "cyrix_arr", "centaur_mcr",		NULL, NULL, NULL, NULL,		"constant_tsc", "up", NULL, "arch_perfmon",		"pebs", "bts", NULL, "sync_rdtsc",		"rep_good", 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", "smx", "est",		"tm2", "ssse3", "cid", NULL, NULL, "cx16", "xtpr", NULL,		NULL, NULL, "dca", "sse4_1", "sse4_2", NULL, NULL, "popcnt",		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* VIA/Cyrix/Centaur-defined */		NULL, NULL, "rng", "rng_en", NULL, NULL, "ace", "ace_en",		"ace2", "ace2_en", "phe", "phe_en", "pmm", "pmm_en", 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", "svm", "extapic",		"cr8_legacy", "abm", "sse4a", "misalignsse",		"3dnowprefetch", "osvw", "ibs", "sse5",		"skinit", "wdt", NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		NULL, NULL, NULL, NULL, NULL, NULL, NULL, NULL,		/* Auxiliary (Linux-defined) */		"ida", 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, NULL,	};	static const char *const x86_power_flags[] = {		"ts",	/* temperature sensor */		"fid",  /* frequency id control */		"vid",  /* voltage id control */		"ttp",  /* thermal trip */		"tm",		"stc",		"100mhzsteps",		"hwpstate",		"",	/* tsc invariant mapped to constant_tsc */		/* nothing */	};#ifdef CONFIG_SMP	cpu = c->cpu_index;#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)cpu,		     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)) {		unsigned int freq = cpufreq_quick_get((unsigned)cpu);		if (!freq)			freq = cpu_khz;		seq_printf(m, "cpu MHz\t\t: %u.%03u\n",			     freq / 1000, (freq % 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) {		seq_printf(m, "physical id\t: %d\n", c->phys_proc_id);		seq_printf(m, "siblings\t: %d\n",			       cpus_weight(per_cpu(cpu_core_map, cpu)));		seq_printf(m, "core id\t\t: %d\n", c->cpu_core_id);		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 (cpu_has(c, i) && 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) &&					x86_power_flags[i])					seq_printf(m, "%s%s",						x86_power_flags[i][0]?" ":"",						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){	if (*pos == 0)	/* just in case, cpu 0 is not the first */		*pos = first_cpu(cpu_online_map);	if ((*pos) < NR_CPUS && cpu_online(*pos))		return &cpu_data(*pos);	return NULL;}static void *c_next(struct seq_file *m, void *v, loff_t *pos){	*pos = next_cpu(*pos, cpu_online_map);	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 + -