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

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

?? cpufreq.c

?? 優(yōu)龍2410linux2.6.8內(nèi)核源代碼
?? C
字號(hào):
/* * arch/sh/kernel/cpufreq.c * * cpufreq driver for the SuperH processors. * * Copyright (C) 2002, 2003 Paul Mundt * Copyright (C) 2002 M. R. Brown * * 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. */#include <linux/types.h>#include <linux/cpufreq.h>#include <linux/kernel.h>#include <linux/module.h>#include <linux/slab.h>#include <linux/init.h>#include <linux/delay.h>#include <linux/smp.h>#include <asm/processor.h>#include <asm/watchdog.h>#include <asm/freq.h>#include <asm/io.h>/* * For SuperH, each policy change requires that we change the IFC, BFC, and * PFC at the same time.  Here we define sane values that won't trash the * system. * * Note the max set is computed at runtime, we use the divisors that we booted * with to setup our maximum operating frequencies. */struct clock_set {	unsigned int ifc;	unsigned int bfc;	unsigned int pfc;} clock_sets[] = {#if defined(CONFIG_CPU_SH3) || defined(CONFIG_CPU_SH2)	{ 0, 0, 0 },	/* not implemented yet */#elif defined(CONFIG_CPU_SH4)	{ 4, 8, 8 },	/* min - IFC: 1/4, BFC: 1/8, PFC: 1/8 */	{ 1, 2, 2 },	/* max - IFC: 1, BFC: 1/2, PFC: 1/2 */#endif};#define NR_CLOCK_SETS	(sizeof(clock_sets) / sizeof(struct clock_set))#define MIN_CLOCK_SET	0#define MAX_CLOCK_SET	(NR_CLOCK_SETS - 1)/* * For the time being, we only support two frequencies, which in turn are * aimed at the POWERSAVE and PERFORMANCE policies, which in turn are derived * directly from the respective min/max clock sets. Technically we could * support a wider range of frequencies, but these vary far too much for each * CPU subtype (and we'd have to construct a frequency table for each subtype). * * Maybe something to implement in the future.. */#define SH_FREQ_MAX	0#define SH_FREQ_MIN	1static struct cpufreq_frequency_table sh_freqs[] = {	{ SH_FREQ_MAX,	0 },	{ SH_FREQ_MIN,	0 },	{ 0,		CPUFREQ_TABLE_END },};static void sh_cpufreq_update_clocks(unsigned int set){	current_cpu_data.cpu_clock = current_cpu_data.master_clock / clock_sets[set].ifc;	current_cpu_data.bus_clock = current_cpu_data.master_clock / clock_sets[set].bfc;	current_cpu_data.module_clock = current_cpu_data.master_clock / clock_sets[set].pfc;	current_cpu_data.loops_per_jiffy = loops_per_jiffy;}/* XXX: This needs to be split out per CPU and CPU subtype. *//* * Here we notify other drivers of the proposed change and the final change. */static int sh_cpufreq_setstate(unsigned int cpu, unsigned int set){	unsigned short frqcr = ctrl_inw(FRQCR);	unsigned long cpus_allowed;	struct cpufreq_freqs freqs;	int allowable_cpu_map;	if (!cpu_online(cpu))		return -ENODEV;	cpus_allowed = current->cpus_allowed;	allowable_cpu_map = 1 << cpu;	set_cpus_allowed(current, allowable_cpu_map);		BUG_ON(!(allowable_cpu_map & (1 << smp_processor_id())));	freqs.cpu = cpu;	freqs.old = current_cpu_data.cpu_clock / 1000;	freqs.new = (current_cpu_data.master_clock / clock_sets[set].ifc) / 1000;	cpufreq_notify_transition(&freqs, CPUFREQ_PRECHANGE);#if defined(CONFIG_CPU_SH3)	frqcr |= (newstate & 0x4000) << 14;	frqcr |= (newstate & 0x000c) <<  2;#elif defined(CONFIG_CPU_SH4)	/*	 * FRQCR.PLL2EN is 1, we need to allow the PLL to stabilize by	 * initializing the WDT.	 */	if (frqcr & (1 << 9)) {		__u8 csr;		/*		 * Set the overflow period to the highest available,		 * in this case a 1/4096 division ratio yields a 5.25ms		 * overflow period. See asm-sh/watchdog.h for more		 * information and a range of other divisors.		 */		csr = sh_wdt_read_csr();		csr |= WTCSR_CKS_4096;		sh_wdt_write_csr(csr);		sh_wdt_write_cnt(0);	}	frqcr &= 0x0e00;	/* Clear ifc, bfc, pfc */	frqcr |= get_ifc_value(clock_sets[set].ifc) << 6;	frqcr |= get_bfc_value(clock_sets[set].bfc) << 3;	frqcr |= get_pfc_value(clock_sets[set].pfc);#endif	ctrl_outw(frqcr, FRQCR);	sh_cpufreq_update_clocks(set);	set_cpus_allowed(current, cpus_allowed);	cpufreq_notify_transition(&freqs, CPUFREQ_POSTCHANGE);		return 0;}static int sh_cpufreq_cpu_init(struct cpufreq_policy *policy){	unsigned int min_freq, max_freq;	unsigned int ifc, bfc, pfc;	if (!cpu_online(policy->cpu))		return -ENODEV;	/* Update our maximum clock set */	get_current_frequency_divisors(&ifc, &bfc, &pfc);	clock_sets[MAX_CLOCK_SET].ifc = ifc;	clock_sets[MAX_CLOCK_SET].bfc = bfc;	clock_sets[MAX_CLOCK_SET].pfc = pfc;	/* Convert from Hz to kHz */	max_freq = current_cpu_data.cpu_clock / 1000;	min_freq = (current_cpu_data.master_clock / clock_sets[MIN_CLOCK_SET].ifc) / 1000;		sh_freqs[SH_FREQ_MAX].frequency = max_freq;	sh_freqs[SH_FREQ_MIN].frequency = min_freq;	/* cpuinfo and default policy values */	policy->governor                   = CPUFREQ_DEFAULT_GOVERNOR;	policy->cpuinfo.transition_latency = CPUFREQ_ETERNAL;	policy->cur                        = max_freq;	return cpufreq_frequency_table_cpuinfo(policy, &sh_freqs[0]);}static int sh_cpufreq_verify(struct cpufreq_policy *policy){	return cpufreq_frequency_table_verify(policy, &sh_freqs[0]);}static int sh_cpufreq_target(struct cpufreq_policy *policy,			     unsigned int target_freq,			     unsigned int relation){	unsigned int set, idx = 0;	if (cpufreq_frequency_table_target(policy, &sh_freqs[0], target_freq, relation, &idx))		return -EINVAL;	set = (idx == SH_FREQ_MIN) ? MIN_CLOCK_SET : MAX_CLOCK_SET;	sh_cpufreq_setstate(policy->cpu, set);	return 0;}static struct cpufreq_driver sh_cpufreq_driver = {	.owner		= THIS_MODULE,	.name		= "SH cpufreq",	.init		= sh_cpufreq_cpu_init,	.verify		= sh_cpufreq_verify,	.target		= sh_cpufreq_target,};static int __init sh_cpufreq_init(void){	if (!current_cpu_data.cpu_clock)		return -EINVAL;	if (cpufreq_register_driver(&sh_cpufreq_driver))		return -EINVAL;	return 0;}static void __exit sh_cpufreq_exit(void){	cpufreq_unregister_driver(&sh_cpufreq_driver);}module_init(sh_cpufreq_init);module_exit(sh_cpufreq_exit);MODULE_AUTHOR("Paul Mundt <lethal@linux-sh.org>");MODULE_DESCRIPTION("cpufreq driver for SuperH");MODULE_LICENSE("GPL");

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
日韩视频一区二区三区在线播放| 久久久久9999亚洲精品| 国产成人av电影在线| 一区二区三区中文字幕在线观看| 日韩一区二区在线观看视频| 色哟哟在线观看一区二区三区| 久久爱www久久做| 亚洲精品中文在线| 亚洲精品在线三区| 欧美日韩国产大片| 成人蜜臀av电影| 美脚の诱脚舐め脚责91| 亚洲欧美综合另类在线卡通| 欧美tickling挠脚心丨vk| 欧美亚洲自拍偷拍| 不卡av免费在线观看| 精品一区二区三区av| 亚洲一区二区三区四区在线观看| 国产精品美女久久久久久久久| 精品免费视频.| 欧美一区二区三区四区在线观看| 99久久久免费精品国产一区二区 | 亚洲品质自拍视频| 精品不卡在线视频| 91麻豆精品国产91| 欧美在线观看视频一区二区三区| 风间由美中文字幕在线看视频国产欧美| 人人狠狠综合久久亚洲| 亚洲韩国一区二区三区| 亚洲欧美另类图片小说| 国产精品久久久久久久蜜臀| 久久―日本道色综合久久 | 亚洲欧美一区二区三区孕妇| 国产色产综合色产在线视频| 日韩免费电影一区| 日韩视频在线永久播放| 在线成人免费视频| 欧美精品久久天天躁| 欧美日韩免费高清一区色橹橹 | 免费欧美在线视频| 五月婷婷综合网| 天使萌一区二区三区免费观看| 亚洲二区在线视频| 亚洲成人av一区二区| 亚洲午夜电影在线观看| 亚洲成人tv网| 免费成人在线播放| 捆绑变态av一区二区三区| 日本va欧美va欧美va精品| 久久精品国产网站| 精品一区二区三区免费| 国产一区二区三区免费观看| 国产美女在线精品| 国产91精品露脸国语对白| 国产丶欧美丶日本不卡视频| 成人国产精品免费| 91在线高清观看| 欧美中文一区二区三区| 911精品国产一区二区在线| 欧美一卡2卡三卡4卡5免费| 欧美成人aa大片| 国产午夜精品福利| 亚洲日本电影在线| 亚洲午夜视频在线| 青青草精品视频| 国产v综合v亚洲欧| 99在线精品视频| 欧美日韩一区二区三区四区| 555夜色666亚洲国产免| 精品国产一区二区国模嫣然| 中文字幕+乱码+中文字幕一区| 亚洲黄色尤物视频| 日韩国产精品91| 国产成人精品三级麻豆| 97久久久精品综合88久久| 欧美亚洲一区二区三区四区| 日韩免费看的电影| 亚洲欧洲精品天堂一级 | 国产精品国产三级国产aⅴ入口| 一区二区激情视频| 久久草av在线| 色呦呦一区二区三区| 欧美一区二区三区免费视频| 国产精品你懂的在线| 一区二区三区四区亚洲| 久久99精品久久久久久久久久久久| 成人激情黄色小说| 欧美久久久久久蜜桃| 久久精品水蜜桃av综合天堂| 亚洲福利视频导航| 国产suv精品一区二区三区| 欧美日韩精品一区二区三区蜜桃| 久久精品一区二区| 亚洲v日本v欧美v久久精品| 国产91高潮流白浆在线麻豆| 欧美福利电影网| 国产精品国产a| 久久激情五月婷婷| 欧美视频一区二| 中文字幕精品三区| 人妖欧美一区二区| 在线视频国内一区二区| 国产亚洲短视频| 日韩电影免费一区| 91麻豆视频网站| 久久精品网站免费观看| 免费视频最近日韩| 欧美性色综合网| 综合在线观看色| 国内成人精品2018免费看| 欧美色国产精品| 国产精品狼人久久影院观看方式| 伦理电影国产精品| 在线成人av影院| 亚洲第一综合色| 色婷婷亚洲精品| 国产精品久久毛片av大全日韩| 九九九精品视频| 欧美一二三四区在线| 亚洲成人av一区| 在线观看免费成人| **网站欧美大片在线观看| 欧洲国内综合视频| 欧美国产精品v| 国产91高潮流白浆在线麻豆| 精品第一国产综合精品aⅴ| 美女视频黄 久久| 91精品国产免费| 奇米综合一区二区三区精品视频| 欧美视频第二页| 亚洲一二三四在线观看| 色久综合一二码| ●精品国产综合乱码久久久久| 成人免费观看av| 国产欧美日韩三区| 国产成人自拍网| 欧美激情一区二区在线| 国产成人aaa| 国产精品久久精品日日| 波多野结衣中文一区| 中文字幕视频一区| 99精品视频在线观看| 亚洲色图视频网| 色婷婷国产精品综合在线观看| 亚洲天堂精品视频| 欧美在线观看一区二区| 亚洲成年人影院| 日韩欧美成人一区二区| 精品一区二区三区免费| 国产午夜精品一区二区三区嫩草| 国产69精品久久99不卡| 最新热久久免费视频| 色婷婷精品久久二区二区蜜臂av| 亚洲免费电影在线| 欧美性猛片aaaaaaa做受| 爽好多水快深点欧美视频| 欧美tk—视频vk| 成人午夜在线免费| 亚洲黄色小视频| 91精品国产综合久久福利| 激情国产一区二区| 国产欧美日韩卡一| 91在线丨porny丨国产| 亚洲一二三四久久| 欧美一区二区福利在线| 国产成人午夜电影网| 亚洲人午夜精品天堂一二香蕉| 欧美日韩一区二区三区四区| 久久国产日韩欧美精品| 国产精品美女一区二区| 欧美日韩国产系列| 寂寞少妇一区二区三区| 中文字幕中文字幕中文字幕亚洲无线| 日本电影亚洲天堂一区| 麻豆精品国产传媒mv男同| 国产精品亲子乱子伦xxxx裸| 一区二区免费在线播放| 91性感美女视频| 日韩电影在线看| 久久久九九九九| 欧美系列日韩一区| 久国产精品韩国三级视频| 亚洲欧美综合色| 日韩欧美一级二级三级| av电影天堂一区二区在线| 蜜臀久久99精品久久久久宅男 | 久久久三级国产网站| 色婷婷亚洲精品| 国模冰冰炮一区二区| 一级女性全黄久久生活片免费| 精品国产一区二区三区忘忧草 | 精品免费日韩av| 91行情网站电视在线观看高清版| 老司机免费视频一区二区三区| 亚洲天堂精品在线观看| 欧美mv和日韩mv的网站| 在线免费观看视频一区| 国产v日产∨综合v精品视频| 日韩中文欧美在线| 亚洲欧美日韩在线播放|