亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關(guān)于我們
? 蟲蟲下載站

?? p4-clockmod.c

?? LINUX 2.6.17.4的源碼
?? C
字號:
/* *	Pentium 4/Xeon CPU on demand clock modulation/speed scaling *	(C) 2002 - 2003 Dominik Brodowski <linux@brodo.de> *	(C) 2002 Zwane Mwaikambo <zwane@commfireservices.com> *	(C) 2002 Arjan van de Ven <arjanv@redhat.com> *	(C) 2002 Tora T. Engstad *	All Rights Reserved * *	This program is free software; you can redistribute it and/or *      modify it under the terms of the GNU General Public License *      as published by the Free Software Foundation; either version *      2 of the License, or (at your option) any later version. * *      The author(s) of this software shall not be held liable for damages *      of any nature resulting due to the use of this software. This *      software is provided AS-IS with no warranties. * *	Date		Errata			Description *	20020525	N44, O17	12.5% or 25% DC causes lockup * */#include <linux/config.h>#include <linux/kernel.h>#include <linux/module.h>#include <linux/init.h>#include <linux/smp.h>#include <linux/cpufreq.h>#include <linux/slab.h>#include <linux/cpumask.h>#include <linux/sched.h>	/* current / set_cpus_allowed() */#include <asm/processor.h>#include <asm/msr.h>#include <asm/timex.h>#include "speedstep-lib.h"#define PFX	"p4-clockmod: "#define dprintk(msg...) cpufreq_debug_printk(CPUFREQ_DEBUG_DRIVER, "p4-clockmod", msg)/* * Duty Cycle (3bits), note DC_DISABLE is not specified in * intel docs i just use it to mean disable */enum {	DC_RESV, DC_DFLT, DC_25PT, DC_38PT, DC_50PT,	DC_64PT, DC_75PT, DC_88PT, DC_DISABLE};#define DC_ENTRIES	8static int has_N44_O17_errata[NR_CPUS];static int has_N60_errata[NR_CPUS];static unsigned int stock_freq;static struct cpufreq_driver p4clockmod_driver;static unsigned int cpufreq_p4_get(unsigned int cpu);static int cpufreq_p4_setdc(unsigned int cpu, unsigned int newstate){	u32 l, h;	if (!cpu_online(cpu) || (newstate > DC_DISABLE) || (newstate == DC_RESV))		return -EINVAL;	rdmsr(MSR_IA32_THERM_STATUS, l, h);	if (l & 0x01)		dprintk("CPU#%d currently thermal throttled\n", cpu);	if (has_N44_O17_errata[cpu] && (newstate == DC_25PT || newstate == DC_DFLT))		newstate = DC_38PT;	rdmsr(MSR_IA32_THERM_CONTROL, l, h);	if (newstate == DC_DISABLE) {		dprintk("CPU#%d disabling modulation\n", cpu);		wrmsr(MSR_IA32_THERM_CONTROL, l & ~(1<<4), h);	} else {		dprintk("CPU#%d setting duty cycle to %d%%\n",			cpu, ((125 * newstate) / 10));		/* bits 63 - 5	: reserved		 * bit  4	: enable/disable		 * bits 3-1	: duty cycle		 * bit  0	: reserved		 */		l = (l & ~14);		l = l | (1<<4) | ((newstate & 0x7)<<1);		wrmsr(MSR_IA32_THERM_CONTROL, l, h);	}	return 0;}static struct cpufreq_frequency_table p4clockmod_table[] = {	{DC_RESV, CPUFREQ_ENTRY_INVALID},	{DC_DFLT, 0},	{DC_25PT, 0},	{DC_38PT, 0},	{DC_50PT, 0},	{DC_64PT, 0},	{DC_75PT, 0},	{DC_88PT, 0},	{DC_DISABLE, 0},	{DC_RESV, CPUFREQ_TABLE_END},};static int cpufreq_p4_target(struct cpufreq_policy *policy,			     unsigned int target_freq,			     unsigned int relation){	unsigned int    newstate = DC_RESV;	struct cpufreq_freqs freqs;	cpumask_t cpus_allowed;	int i;	if (cpufreq_frequency_table_target(policy, &p4clockmod_table[0], target_freq, relation, &newstate))		return -EINVAL;	freqs.old = cpufreq_p4_get(policy->cpu);	freqs.new = stock_freq * p4clockmod_table[newstate].index / 8;	if (freqs.new == freqs.old)		return 0;	/* notifiers */	for_each_cpu_mask(i, policy->cpus) {		freqs.cpu = i;		cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE);	}	/* run on each logical CPU, see section 13.15.3 of IA32 Intel Architecture Software	 * Developer's Manual, Volume 3	 */	cpus_allowed = current->cpus_allowed;	for_each_cpu_mask(i, policy->cpus) {		cpumask_t this_cpu = cpumask_of_cpu(i);		set_cpus_allowed(current, this_cpu);		BUG_ON(smp_processor_id() != i);		cpufreq_p4_setdc(i, p4clockmod_table[newstate].index);	}	set_cpus_allowed(current, cpus_allowed);	/* notifiers */	for_each_cpu_mask(i, policy->cpus) {		freqs.cpu = i;		cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE);	}	return 0;}static int cpufreq_p4_verify(struct cpufreq_policy *policy){	return cpufreq_frequency_table_verify(policy, &p4clockmod_table[0]);}static unsigned int cpufreq_p4_get_frequency(struct cpuinfo_x86 *c){	if ((c->x86 == 0x06) && (c->x86_model == 0x09)) {		/* Pentium M (Banias) */		printk(KERN_WARNING PFX "Warning: Pentium M detected. "		       "The speedstep_centrino module offers voltage scaling"		       " in addition of frequency scaling. You should use "		       "that instead of p4-clockmod, if possible.\n");		return speedstep_get_processor_frequency(SPEEDSTEP_PROCESSOR_PM);	}	if ((c->x86 == 0x06) && (c->x86_model == 0x0D)) {		/* Pentium M (Dothan) */		printk(KERN_WARNING PFX "Warning: Pentium M detected. "		       "The speedstep_centrino module offers voltage scaling"		       " in addition of frequency scaling. You should use "		       "that instead of p4-clockmod, if possible.\n");		/* on P-4s, the TSC runs with constant frequency independent whether		 * throttling is active or not. */		p4clockmod_driver.flags |= CPUFREQ_CONST_LOOPS;		return speedstep_get_processor_frequency(SPEEDSTEP_PROCESSOR_PM);	}	if (c->x86 != 0xF) {		printk(KERN_WARNING PFX "Unknown p4-clockmod-capable CPU. Please send an e-mail to <linux@brodo.de>\n");		return 0;	}	/* on P-4s, the TSC runs with constant frequency independent whether	 * throttling is active or not. */	p4clockmod_driver.flags |= CPUFREQ_CONST_LOOPS;	if (speedstep_detect_processor() == SPEEDSTEP_PROCESSOR_P4M) {		printk(KERN_WARNING PFX "Warning: Pentium 4-M detected. "		       "The speedstep-ich or acpi cpufreq modules offer "		       "voltage scaling in addition of frequency scaling. "		       "You should use either one instead of p4-clockmod, "		       "if possible.\n");		return speedstep_get_processor_frequency(SPEEDSTEP_PROCESSOR_P4M);	}	return speedstep_get_processor_frequency(SPEEDSTEP_PROCESSOR_P4D);}static int cpufreq_p4_cpu_init(struct cpufreq_policy *policy){	struct cpuinfo_x86 *c = &cpu_data[policy->cpu];	int cpuid = 0;	unsigned int i;#ifdef CONFIG_SMP	policy->cpus = cpu_sibling_map[policy->cpu];#endif	/* Errata workaround */	cpuid = (c->x86 << 8) | (c->x86_model << 4) | c->x86_mask;	switch (cpuid) {	case 0x0f07:	case 0x0f0a:	case 0x0f11:	case 0x0f12:		has_N44_O17_errata[policy->cpu] = 1;		dprintk("has errata -- disabling low frequencies\n");		break;	case 0x0f29:		has_N60_errata[policy->cpu] = 1;		dprintk("has errata -- disabling frequencies lower than 2ghz\n");		break;	}	/* get max frequency */	stock_freq = cpufreq_p4_get_frequency(c);	if (!stock_freq)		return -EINVAL;	/* table init */	for (i=1; (p4clockmod_table[i].frequency != CPUFREQ_TABLE_END); i++) {		if ((i<2) && (has_N44_O17_errata[policy->cpu]))			p4clockmod_table[i].frequency = CPUFREQ_ENTRY_INVALID;		else if (has_N60_errata[policy->cpu] && ((stock_freq * i)/8) < 2000000)			p4clockmod_table[i].frequency = CPUFREQ_ENTRY_INVALID;		else			p4clockmod_table[i].frequency = (stock_freq * i)/8;	}	cpufreq_frequency_table_get_attr(p4clockmod_table, policy->cpu);	/* cpuinfo and default policy values */	policy->governor = CPUFREQ_DEFAULT_GOVERNOR;	policy->cpuinfo.transition_latency = 1000000; /* assumed */	policy->cur = stock_freq;	return cpufreq_frequency_table_cpuinfo(policy, &p4clockmod_table[0]);}static int cpufreq_p4_cpu_exit(struct cpufreq_policy *policy){	cpufreq_frequency_table_put_attr(policy->cpu);	return 0;}static unsigned int cpufreq_p4_get(unsigned int cpu){	cpumask_t cpus_allowed;	u32 l, h;	cpus_allowed = current->cpus_allowed;	set_cpus_allowed(current, cpumask_of_cpu(cpu));	BUG_ON(smp_processor_id() != cpu);	rdmsr(MSR_IA32_THERM_CONTROL, l, h);	set_cpus_allowed(current, cpus_allowed);	if (l & 0x10) {		l = l >> 1;		l &= 0x7;	} else		l = DC_DISABLE;	if (l != DC_DISABLE)		return (stock_freq * l / 8);	return stock_freq;}static struct freq_attr* p4clockmod_attr[] = {	&cpufreq_freq_attr_scaling_available_freqs,	NULL,};static struct cpufreq_driver p4clockmod_driver = {	.verify		= cpufreq_p4_verify,	.target		= cpufreq_p4_target,	.init		= cpufreq_p4_cpu_init,	.exit		= cpufreq_p4_cpu_exit,	.get		= cpufreq_p4_get,	.name		= "p4-clockmod",	.owner		= THIS_MODULE,	.attr		= p4clockmod_attr,};static int __init cpufreq_p4_init(void){	struct cpuinfo_x86 *c = cpu_data;	int ret;	/*	 * THERM_CONTROL is architectural for IA32 now, so	 * we can rely on the capability checks	 */	if (c->x86_vendor != X86_VENDOR_INTEL)		return -ENODEV;	if (!test_bit(X86_FEATURE_ACPI, c->x86_capability) ||		!test_bit(X86_FEATURE_ACC, c->x86_capability))		return -ENODEV;	ret = cpufreq_register_driver(&p4clockmod_driver);	if (!ret)		printk(KERN_INFO PFX "P4/Xeon(TM) CPU On-Demand Clock Modulation available\n");	return (ret);}static void __exit cpufreq_p4_exit(void){	cpufreq_unregister_driver(&p4clockmod_driver);}MODULE_AUTHOR ("Zwane Mwaikambo <zwane@commfireservices.com>");MODULE_DESCRIPTION ("cpufreq driver for Pentium(TM) 4/Xeon(TM)");MODULE_LICENSE ("GPL");late_initcall(cpufreq_p4_init);module_exit(cpufreq_p4_exit);

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲精品一线二线三线无人区| 色欧美乱欧美15图片| 精品日韩一区二区| 国产一区二区在线观看视频| 国产亚洲综合性久久久影院| 丁香婷婷综合五月| 亚洲私人黄色宅男| 精品视频在线看| 久久国产成人午夜av影院| 国产日韩欧美激情| 色婷婷综合激情| 男女男精品视频| 亚洲国产成人午夜在线一区| 91免费国产在线观看| 日韩精品视频网| 久久久久国产精品麻豆ai换脸| 成人性色生活片免费看爆迷你毛片| 亚洲日本va午夜在线影院| 91久久精品午夜一区二区| 日本美女一区二区| 国产精品美女www爽爽爽| 色激情天天射综合网| 蜜桃av噜噜一区二区三区小说| 日本一区二区三区dvd视频在线| 一本久久综合亚洲鲁鲁五月天 | 玖玖九九国产精品| 国产精品久久久久精k8| 欧美三级视频在线播放| 国产一区在线观看视频| 一区二区视频免费在线观看| 精品国产网站在线观看| 91碰在线视频| 国产美女精品一区二区三区| 亚洲日本电影在线| 久久综合给合久久狠狠狠97色69| 91日韩一区二区三区| 激情小说欧美图片| 亚洲午夜电影在线观看| 国产精品麻豆久久久| 884aa四虎影成人精品一区| 成人一区二区三区视频在线观看| 五月天一区二区| 日韩毛片视频在线看| 欧美精品一区二区三区在线播放 | 日本道免费精品一区二区三区| 日韩中文字幕1| 亚洲天堂2014| 久久精品人人爽人人爽| 日韩一区二区在线观看视频 | 亚洲午夜羞羞片| 中文成人综合网| 精品国产91久久久久久久妲己 | 亚洲青青青在线视频| 久久精品亚洲精品国产欧美| 欧美一区二区女人| 欧美日本韩国一区二区三区视频| 99久久伊人精品| 国产99久久久国产精品潘金网站| 美女视频网站黄色亚洲| 日韩中文字幕亚洲一区二区va在线 | 激情久久久久久久久久久久久久久久| 亚洲精品久久嫩草网站秘色| 欧美国产日本视频| 久久久久久久久岛国免费| 欧美大片拔萝卜| 欧美一区二区播放| 欧美浪妇xxxx高跟鞋交| 在线日韩一区二区| 91黄色免费观看| 成人午夜在线视频| 成人网在线免费视频| 国产成人免费视频一区| 国产精品影视在线观看| 国产精品一区二区果冻传媒| 国产一区 二区| 国产精品亚洲第一区在线暖暖韩国| 久久国产婷婷国产香蕉| 精品中文字幕一区二区| 精品一区二区免费视频| 九一九一国产精品| 国产原创一区二区| 成人精品视频网站| 99精品国产视频| 67194成人在线观看| 欧美绝品在线观看成人午夜影视| 日本免费新一区视频| 视频一区二区欧美| 白白色亚洲国产精品| 美女高潮久久久| 亚洲在线视频免费观看| 国产精品久久久久久久久免费相片 | 精品日韩一区二区三区| 欧美在线综合视频| 成a人片亚洲日本久久| 国产一区二区三区在线观看免费视频 | 日本一区二区三级电影在线观看| 日韩一区二区在线观看| 欧美最新大片在线看| 9人人澡人人爽人人精品| 国产一区二区在线观看免费| 奇米888四色在线精品| 日欧美一区二区| 亚洲va韩国va欧美va精品| 亚洲六月丁香色婷婷综合久久| 欧美韩国日本一区| 日本一区二区免费在线观看视频 | 中文字幕一区二区三区精华液| 久久精品在这里| 久久精品夜色噜噜亚洲a∨| 精品久久久三级丝袜| 日韩一区二区三区电影在线观看| 欧美日韩高清一区二区| 欧美日本视频在线| 欧美一级高清片| 欧美电影免费观看高清完整版在 | 色94色欧美sute亚洲线路二| av成人免费在线| 99久久久无码国产精品| 91视频精品在这里| 色综合久久天天| 在线观看日韩精品| 欧美体内she精视频| 在线亚洲高清视频| 欧美日韩免费一区二区三区| 欧美日韩精品福利| 欧美一区二区福利在线| 精品国产一区二区三区不卡| 久久久久久久综合狠狠综合| 国产精品丝袜在线| 亚洲日本在线a| 日韩精品久久理论片| 久久狠狠亚洲综合| 成人精品视频.| 欧美综合亚洲图片综合区| 欧美一区二区三区四区五区| 精品日韩在线观看| 中文字幕在线不卡一区| 亚洲影院在线观看| 精品一区二区免费| 成人av午夜影院| 欧美精品乱码久久久久久| 欧美成va人片在线观看| 中文字幕一区二区三区在线观看 | 中文字幕中文字幕一区| 一区二区三区四区激情| 免费欧美日韩国产三级电影| 国产99久久久国产精品潘金| 在线视频国产一区| 久久亚洲精品小早川怜子| 亚洲男人电影天堂| 狠狠色狠狠色合久久伊人| 色综合视频一区二区三区高清| 91精品国产综合久久精品性色| 国产视频在线观看一区二区三区 | 中文字幕av资源一区| 亚洲高清三级视频| 国产成人鲁色资源国产91色综| 欧美日韩视频在线第一区| 久久久久久久久岛国免费| 亚洲va欧美va人人爽| 国产成人精品一区二区三区四区| 91久久精品一区二区二区| 久久综合999| 香蕉av福利精品导航| 丁香网亚洲国际| 日韩欧美色综合| 亚洲一区二区欧美日韩| 国产99久久久久久免费看农村| 56国语精品自产拍在线观看| 最新欧美精品一区二区三区| 老司机一区二区| wwww国产精品欧美| 五月天激情综合| 色综合色狠狠天天综合色| 欧美国产日韩在线观看| 久久精品国产免费| 67194成人在线观看| 亚洲精品成a人| www.欧美亚洲| 国产午夜精品一区二区三区视频| 日本在线观看不卡视频| 欧美图区在线视频| 一区二区三区中文免费| 成人av影视在线观看| 国产日韩一级二级三级| 久久国产精品区| 日韩视频在线永久播放| 日韩精品视频网| 3d成人动漫网站| 日韩在线卡一卡二| 7777女厕盗摄久久久| 午夜精品成人在线| 欧美狂野另类xxxxoooo| 午夜免费欧美电影| 91精品免费在线观看| 免费成人美女在线观看.| 欧美一二三区精品| 久久精品国内一区二区三区| 日韩你懂的在线播放| 精品一区二区免费|