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

? 歡迎來到蟲蟲下載站! | ?? 資源下載 ?? 資源專輯 ?? 關于我們
? 蟲蟲下載站

?? dpm.c

?? 一段基于linux的電源管理的源代碼
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * linux/arch/mips/jzsoc/common/jz_dpm.c * * JzSOC-specific DPM support * * 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. * * Copyright 2005 Ingenic Technology Corporation *      Wei Jianli <jlwei@ingenic.cn> * Copyright (C) 2002 MontaVista Software <source@mvista.com>. * 	Matthew Locke <mlocke@mvista.com> */#include <linux/config.h>#include <linux/dpm.h>#include <linux/errno.h>#include <linux/init.h>#include <linux/kernel.h>#include <linux/kmod.h>#include <linux/module.h>#include <linux/proc_fs.h>#include <linux/stat.h>#include <linux/string.h>#include <linux/delay.h>#include <asm/hardirq.h>#include <asm/page.h>#include <asm/processor.h>#include <asm/uaccess.h>#include <asm/jzsoc.h>#include <linux/device.h>struct dpm_bd dpm_bd;struct dpm_md dpm_md;extern void eth_dpm_freq_pre(void);extern void eth_dpm_freq_post(void);/* Saved the boot-time parameters */static struct {	/* SDRAM parameters */	unsigned int mclk;  /* memory clock, KHz */	unsigned int tras;  /* RAS pulse width, cycles of mclk */	unsigned int rcd;   /* RAS to CAS Delay, cycles of mclk */	unsigned int tpc;   /* RAS Precharge time, cycles of mclk */	unsigned int trwl;  /* Write Precharge Time, cycles of mclk */	unsigned int trc;   /* RAS Cycle Time, cycles of mclk */	unsigned int rtcor; /* Refresh Time Constant */	unsigned int sdram_initialized;	/* LCD parameters */	unsigned int lcd_clk;    /* LCD clock, Hz */	unsigned int lcdpix_clk; /* LCD Pixel clock, Hz */	unsigned int lcd_clks_initialized;} boot_config;extern struct sys_clock jz_clocks;static void jz_update_clocks(void){	/* Next clocks must be updated if we have changed 	 * the PLL or divisors.	 */	jz_clocks.iclk = __cpm_get_iclk();	jz_clocks.sclk = __cpm_get_sclk();	jz_clocks.mclk = __cpm_get_mclk();	jz_clocks.pclk = __cpm_get_pclk();	jz_clocks.lcdclk = __cpm_get_lcdclk();	jz_clocks.pixclk = __cpm_get_pixclk();}static void jz_update_dram_rtcor(unsigned int new_mclk){	unsigned int rtcor;		new_mclk /= 1000;	rtcor = boot_config.rtcor * new_mclk / boot_config.mclk;	rtcor--;	if (rtcor < 1) rtcor = 1;	if (rtcor > 255) rtcor = 255;	REG_EMC_RTCOR = rtcor;	REG_EMC_RTCNT = rtcor;}static void jz_update_dram_dmcr(unsigned int new_mclk){	unsigned int dmcr;	unsigned int tras, rcd, tpc, trwl, trc;	unsigned int valid_time, new_time; /* ns */	new_mclk /= 1000;	tras = boot_config.tras * new_mclk / boot_config.mclk;	rcd = boot_config.rcd * new_mclk / boot_config.mclk;	tpc = boot_config.tpc * new_mclk / boot_config.mclk;	trwl = boot_config.trwl * new_mclk / boot_config.mclk;	trc = boot_config.trc * new_mclk / boot_config.mclk;	/* Validation checking */	valid_time = (boot_config.tras * 1000000) / boot_config.mclk;	new_time = (tras * 1000000) / new_mclk;	if (new_time < valid_time) tras += 1;	valid_time = (boot_config.rcd * 1000000) / boot_config.mclk;	new_time = (rcd * 1000000) / new_mclk;	if (new_time < valid_time) rcd += 1;	valid_time = (boot_config.tpc * 1000000) / boot_config.mclk;	new_time = (tpc * 1000000) / new_mclk;	if (new_time < valid_time) tpc += 1;	valid_time = (boot_config.trwl * 1000000) / boot_config.mclk;	new_time = (trwl * 1000000) / new_mclk;	if (new_time < valid_time) trwl += 1;	valid_time = (boot_config.trc * 1000000) / boot_config.mclk;	new_time = (trc * 1000000) / new_mclk;	if (new_time < valid_time) trc += 2;	tras = (tras < 4) ? 4: tras;	tras = (tras > 11) ? 11: tras;	tras -= 4;	rcd = (rcd < 1) ? 1: rcd;	rcd = (rcd > 4) ? 4: rcd;	rcd -= 1;	tpc = (tpc < 1) ? 1: tpc;	tpc = (tpc > 8) ? 8: tpc;	tpc -= 1;	trwl = (trwl < 1) ? 1: trwl;	trwl = (trwl > 4) ? 4: trwl;	trwl -= 1;	trc = (trc < 1) ? 1: trc;	trc = (trc > 15) ? 15: trc;	trc /= 2;		dmcr = REG_EMC_DMCR;		dmcr &= ~(EMC_DMCR_TRAS_MASK | EMC_DMCR_RCD_MASK | EMC_DMCR_TPC_MASK | EMC_DMCR_TRWL_MASK | EMC_DMCR_TRC_MASK);	dmcr |= ((tras << EMC_DMCR_TRAS_BIT) | (rcd << EMC_DMCR_RCD_BIT) | (tpc << EMC_DMCR_TPC_BIT) | (trwl << EMC_DMCR_TRWL_BIT) | (trc << EMC_DMCR_TRC_BIT));	REG_EMC_DMCR = dmcr;}static void jz_update_dram_prev(unsigned int cur_mclk, unsigned int new_mclk){		/* No risk, no fun: run with interrupts on! */	if (new_mclk > cur_mclk) {		/* We're going FASTER, so first update TRAS, RCD, TPC, TRWL		 * and TRC of DMCR before changing the frequency.		 */		jz_update_dram_dmcr(new_mclk);	} else {		/* We're going SLOWER: first update RTCOR value		 * before changing the frequency.		 */		jz_update_dram_rtcor(new_mclk);	}}static void jz_update_dram_post(unsigned int cur_mclk, unsigned int new_mclk){		/* No risk, no fun: run with interrupts on! */	if (new_mclk > cur_mclk) {		/* We're going FASTER, so update RTCOR		 * after changing the frequency 		 */		jz_update_dram_rtcor(new_mclk);	} else {		/* We're going SLOWER: so update TRAS, RCD, TPC, TRWL		 * and TRC of DMCR after changing the frequency.		 */		jz_update_dram_dmcr(new_mclk);	}}static void jz_scale_divisors(struct dpm_regs *regs){	unsigned int cfcr;	unsigned int cur_mclk, new_mclk;	int div[] = {1, 2, 3, 4, 6, 8, 12, 16, 24, 32};	cfcr = REG_CPM_CFCR;	cfcr &= ~((unsigned long)regs->cfcr_mask);	cfcr |= regs->cfcr;	cfcr |= CPM_CFCR_UPE;       /* update immediately */		cur_mclk = __cpm_get_mclk();	new_mclk = __cpm_get_pllout() / div[(cfcr & CPM_CFCR_MFR_MASK) >> CPM_CFCR_MFR_BIT];	/* Update some DRAM parameters before changing frequency */	jz_update_dram_prev(cur_mclk, new_mclk);	/* Update divisores */	REG_CPM_CFCR = cfcr;	/* Update some other DRAM parameters after changing frequency */	jz_update_dram_post(cur_mclk, new_mclk);}/* Maintain the LCD clock and pixel clock */static void jz_scale_lcd_divisors(struct dpm_regs *regs){		unsigned int new_pll, new_lcd_div, new_lcdpix_div;	unsigned int cfcr;	if (!boot_config.lcd_clks_initialized) return;	new_pll = __cpm_get_pllout();	new_lcd_div = new_pll / boot_config.lcd_clk;	new_lcdpix_div = new_pll / boot_config.lcdpix_clk;	if (new_lcd_div < 1)		new_lcd_div = 1;	if (new_lcd_div > 16)		new_lcd_div = 16;	if (new_lcdpix_div < 1)		new_lcdpix_div = 1;	if (new_lcdpix_div > 512)		new_lcdpix_div = 512;	REG_CPM_CFCR2 = new_lcdpix_div - 1;	cfcr = REG_CPM_CFCR;	cfcr &= ~CPM_CFCR_LFR_MASK;	cfcr |= ((new_lcd_div - 1) << CPM_CFCR_LFR_BIT);	cfcr |= CPM_CFCR_UPE;       /* update immediately */	REG_CPM_CFCR = cfcr;}static void jz_scale_pll(struct dpm_regs *regs){	unsigned int plcr1;	unsigned int cur_mclk, new_mclk, new_pll;	int div[] = {1, 2, 3, 4, 6, 8, 12, 16, 24, 32};	int od[] = {1, 2, 2, 4};	plcr1 = REG_CPM_PLCR1;	plcr1 &= ~(regs->plcr1_mask | CPM_PLCR1_PLL1S | CPM_PLCR1_PLL1EN | CPM_PLCR1_PLL1ST_MASK);	regs->plcr1 &= ~CPM_PLCR1_PLL1EN;	plcr1 |= (regs->plcr1 | 0xff);	/* LCD and LCD pixel clocks should not be changed even if the PLL 	 * output frequency has been changed.	 */	/* Disable LCD before scaling pll */	REG_LCD_CTRL &= ~LCD_CTRL_ENA;	/* Update some DRAM parameters before changing frequency */	new_pll = JZ_EXTAL * ((plcr1>>23)+2) / ((((plcr1>>18)&0x1f)+2) * od[(plcr1>>16)&0x03]);	cur_mclk = __cpm_get_mclk();	new_mclk = new_pll / div[(REG_CPM_CFCR>>16) & 0xf];	jz_update_dram_prev(cur_mclk, new_mclk);	/* Update PLL  *///	__cpm_stop_all();	REG_CPM_PLCR1 = plcr1;	REG_CPM_PLCR1 |= CPM_PLCR1_PLL1EN;//	__cpm_start_all();	/* Update some other DRAM parameters after changing frequency */	jz_update_dram_post(cur_mclk, new_mclk);	/* Scale the LCD divisors after scaling pll */	jz_scale_lcd_divisors(regs);	/* Enable LCD */	REG_LCD_CTRL &= ~LCD_CTRL_DIS;	REG_LCD_CTRL |= LCD_CTRL_ENA;}static voidjz_init_boot_config(void){	if (!boot_config.lcd_clks_initialized) {		/* the first time to scale pll */		boot_config.lcd_clk = __cpm_get_lcdclk();		boot_config.lcdpix_clk = __cpm_get_pixclk();		boot_config.lcd_clks_initialized = 1;	}	if (!boot_config.sdram_initialized) {		/* the first time to scale frequencies */		unsigned int dmcr, rtcor;		unsigned int tras, rcd, tpc, trwl, trc;				dmcr = REG_EMC_DMCR;		rtcor = REG_EMC_RTCOR;		tras = (dmcr >> 13) & 0x7;		rcd = (dmcr >> 11) & 0x3;		tpc = (dmcr >> 8) & 0x7;		trwl = (dmcr >> 5) & 0x3;		trc = (dmcr >> 2) & 0x7;		boot_config.mclk = __cpm_get_mclk() / 1000;		boot_config.tras = tras + 4;		boot_config.rcd = rcd + 1;		boot_config.tpc = tpc + 1;		boot_config.trwl = trwl + 1;		boot_config.trc = trc * 2 + 1;		boot_config.rtcor = rtcor;		boot_config.sdram_initialized = 1;	}}static void jz_fscaler(struct dpm_regs *regs){	jz_init_boot_config();	/* the pll frequency is going up, so change dividers first */	if (regs->pll_up_flag) {		jz_scale_divisors(regs);//		jz_scale_pll(regs);	} else {//		jz_scale_pll(regs);		jz_scale_divisors(regs);	}	jz_update_clocks();}//extern void dpm_device_suspend(void);//extern void dpm_device_resume(void);static void jz_fscaler_suspend(struct dpm_regs *regs){	extern void jz_pm_suspend(void);//	dpm_device_suspend();#ifdef CONFIG_PM	jz_pm_suspend();#endif	dpm_set_os(DPM_TASK_STATE);}static void jz_fscaler_resume(struct dpm_regs *regs){	jz_fscaler(regs);//	dpm_device_resume();}/* This routine computes the "forward" frequency scaler that moves the system * from the current operating point to the new operating point.  The resulting * fscaler is applied to the registers of the new operating point.  */dpm_fscaler compute_fscaler(struct dpm_md_opt *cur, struct dpm_md_opt *new){	new->regs.pll_up_flag = (new->pll > cur->pll) ? 1 : 0;	loops_per_jiffy = new->lpj;	if (cur->cpu == 0) {		return jz_fscaler_resume;	}	if (new->cpu == 0) {		return jz_fscaler_suspend;	}	return jz_fscaler;}static unsigned long compute_lpj(unsigned long ref, u_int div, u_int mult){	unsigned long new_jiffy_l, new_jiffy_h;	/*	 * Recalculate loops_per_jiffy.  We do it this way to	 * avoid math overflow on 32-bit machines.  Maybe we	 * should make this architecture dependent?  If you have	 * a better way of doing this, please replace!	 *	 *    new = old * mult / div	 */	new_jiffy_h = ref / div;	new_jiffy_l = (ref % div) / 100;	new_jiffy_h *= mult;	new_jiffy_l = new_jiffy_l * mult / div;	return new_jiffy_h + new_jiffy_l * 100;}/* Initialize the machine-dependent operating point from a list of parameters,   which has already been installed in the pp field of the operating point.   Some of the parameters may be specified with a value of -1 to indicate a   default value. */static int check_divider(int div){	if ((div != 1) && (div != 2) && (div != 3) && (div != 4) &&	    (div != 6) && (div != 8) && (div != 12) && (div != 16) &&	    (div != 24) && (div != 32) && (div != 0)) {		return -EINVAL;	}	return 0;}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久人人爽人人爽| 国产一区二区三区香蕉 | 欧美三级电影精品| 亚洲精品一区二区在线观看| 亚洲一区中文在线| 国产激情视频一区二区在线观看| 欧美日韩国产精品自在自线| 国产欧美日韩久久| 极品少妇一区二区三区精品视频| 色综合久久精品| 国产拍欧美日韩视频二区| 奇米精品一区二区三区在线观看一 | 欧美一区二区三区公司| 1000部国产精品成人观看| 久久99热这里只有精品| 欧美日本韩国一区| 亚洲精品中文字幕在线观看| 国产a视频精品免费观看| 日韩精品一区二区三区老鸭窝| 午夜视频一区二区| 欧美亚洲一区二区在线观看| 亚洲欧美一区二区三区极速播放| 国产精品自拍毛片| 亚洲黄网站在线观看| 97久久精品人人做人人爽| 国产丝袜欧美中文另类| 国产精品综合在线视频| 欧美精品一区视频| 国产精品一区二区三区99| 精品人在线二区三区| 久久99国产精品久久99| 精品国产123| 国产激情91久久精品导航| 久久久噜噜噜久久人人看| 国产精品一区二区在线观看网站| 2014亚洲片线观看视频免费| 精品一区二区在线播放| 欧美tickle裸体挠脚心vk| 极品少妇一区二区三区精品视频 | 午夜精品福利在线| 欧美巨大另类极品videosbest | 成人app网站| 久久久久久久网| 国产麻豆精品在线观看| 欧美国产欧美综合| 色婷婷激情久久| 亚洲午夜精品在线| 日韩欧美三级在线| 国产 日韩 欧美大片| 亚洲欧美日韩中文字幕一区二区三区| 91亚洲精品久久久蜜桃| 亚洲成在线观看| 精品三级在线看| 不卡的电视剧免费网站有什么| 亚洲特黄一级片| 欧美男人的天堂一二区| 激情小说亚洲一区| 亚洲色图19p| 4438成人网| 成人深夜福利app| 亚洲国产欧美在线| 久久综合九色欧美综合狠狠| 99久久久久免费精品国产| 亚洲图片一区二区| 国产午夜精品在线观看| 欧美午夜精品免费| 国产在线精品一区二区夜色 | 91亚洲精品乱码久久久久久蜜桃 | 国产成人综合自拍| 亚洲综合在线观看视频| 精品久久国产老人久久综合| 97久久超碰国产精品| 男人的天堂久久精品| 欧美激情一区二区三区全黄| 欧美色视频在线| 成人做爰69片免费看网站| 亚洲一区在线播放| 欧美国产日韩精品免费观看| 欧美精品视频www在线观看| 国产成人夜色高潮福利影视| 亚洲伊人色欲综合网| 国产午夜一区二区三区| 91精品国产麻豆国产自产在线| 波多野结衣在线一区| 精品一区二区三区久久| 亚洲黄色尤物视频| 欧美韩日一区二区三区四区| 欧美女孩性生活视频| 91在线porny国产在线看| 国产一区二区日韩精品| 三级不卡在线观看| 亚洲精品视频观看| 国产精品久久久一本精品| 日韩女优视频免费观看| 欧美日韩色综合| 99re视频这里只有精品| 福利一区二区在线观看| 国产一区二区影院| 精品在线免费观看| 日韩成人精品视频| 天堂久久一区二区三区| 亚洲成人免费看| 亚洲一区二区三区视频在线播放| 亚洲欧洲日产国码二区| 欧美激情一区二区三区在线| 久久青草欧美一区二区三区| 欧美成va人片在线观看| 欧美麻豆精品久久久久久| 欧美三级视频在线| 欧美午夜在线一二页| 欧美亚洲禁片免费| 欧美日韩在线精品一区二区三区激情| 一本一道久久a久久精品 | 亚洲日本护士毛茸茸| 国产精品大尺度| 亚洲欧美中日韩| 一区二区三区视频在线看| 一级女性全黄久久生活片免费| 亚洲男人都懂的| 亚洲成人在线免费| 日韩一区精品字幕| 久久99精品国产麻豆婷婷洗澡| 激情综合一区二区三区| 国产成人免费视频一区| 成人性生交大片免费看在线播放| 成人美女视频在线看| 91一区二区三区在线观看| 欧洲中文字幕精品| 欧美军同video69gay| 欧美xxxx老人做受| 久久久久97国产精华液好用吗| 中文字幕欧美三区| 亚洲人成精品久久久久久| 一区二区三区中文免费| 日韩在线观看一区二区| 国产一区二区三区av电影 | 欧美三级视频在线| 欧美成人女星排名| 国产精品毛片高清在线完整版| 中文字幕日本乱码精品影院| 亚洲国产一区二区三区青草影视| 日本三级亚洲精品| 成人午夜免费av| 欧美日韩国产精品成人| 久久精品欧美日韩| 一区二区不卡在线视频 午夜欧美不卡在 | 欧美午夜免费电影| 91精品国产综合久久久蜜臀图片| 国产激情视频一区二区三区欧美| 99久久国产综合精品色伊| 欧美日韩精品系列| 国产欧美日韩综合| 亚洲高清在线精品| 国产激情视频一区二区在线观看 | 欧美麻豆精品久久久久久| 久久久久久免费网| 夜夜精品视频一区二区| 狠狠色狠狠色综合系列| 一道本成人在线| 麻豆久久一区二区| 色综合网色综合| 国产亚洲精品bt天堂精选| 一区二区三区四区av| 国产激情精品久久久第一区二区| 欧美在线三级电影| 国产精品萝li| 日韩欧美黄色影院| 欧美日本在线播放| 国产精品日产欧美久久久久| 日韩av不卡一区二区| 色婷婷狠狠综合| 欧美韩日一区二区三区| 精品综合久久久久久8888| 欧美视频一区二区三区在线观看| 国产欧美日韩不卡| 麻豆91在线播放免费| 在线观看日产精品| 亚洲人成网站精品片在线观看| 国产一区二区精品久久91| 91精品国产综合久久福利| 亚洲影院理伦片| 91亚洲国产成人精品一区二区三 | 久久久.com| 久久精品国产在热久久| 欧美日韩极品在线观看一区| 亚洲欧美一区二区在线观看| 国产黄人亚洲片| 精品福利视频一区二区三区| 日本不卡一二三| 欧美一区二区三区视频在线| 一区二区三区av电影| 成人av在线资源网| 国产欧美久久久精品影院| 久久精品国产77777蜜臀| 欧美一区二区视频在线观看| 日韩高清中文字幕一区| 91麻豆精品国产91久久久 | 亚洲免费在线看| 99久久伊人精品| 亚洲欧美偷拍三级|