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

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

?? proc.c

?? vivi源碼代碼支持usb下載功能
?? C
字號:
/* * vivi/arch/s3c2410/proc.c * * Copyright (C) 2002 MIZI Research, Inc. * * 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. * * This program is distributed in the hope that it will be useful, * but WITHOUT ANY WARRANTY; without even the implied warranty of * MERCHANTABILITY or FITNESS FOR A PARTICULAR PURPOSE.  See the * GNU General Public License for more details. * * You should have received a copy of the GNU General Public License * along with this program; if not, write to the Free Software * Foundation, Inc., 59 Temple Place, Suite 330, Boston, MA  02111-1307  USA * *  * Author: Janghoon Lyu <nandy@mizi.com> * Date  : $Date: 2004/02/04 06:22:25 $ * * $Revision: 1.1.1.1 $ * $Id: proc.c,v 1.1.1.1 2004/02/04 06:22:25 laputa Exp $ * * * History * * 2002-07-12: Janghoon Lyu <nandy@mizi.com> *    - Initial code * */#include "config.h"#include "machine.h"#include "mmu.h"#include "command.h"#include "vivi_string.h"#include "printk.h"#include "priv_data.h"#include <types.h>#include <string.h>#define GET_PCLK		0#define GET_HCLK		1struct cpu_clk_t {	unsigned long clock;	unsigned long mdiv;	unsigned long pdiv;	unsigned long sdiv;};struct mem_clk_t {	unsigned long clock;	unsigned long bankcon6;	unsigned long bankcon7;	unsigned long refresh;};/* * cpu_clk = FIN  */struct cpu_clk_t s3c2410_clks[] = {	/*	mdiv	sdiv	pdiv */	{  50,	0x5c,	0x4,	0x0 },	{ 200,	0x5c,	0x4,	0x0 },	{ 203,	 0x3,	0x4,	0x1 },	/* not tested */	{ 202,	0xa1,	0x3,	0x1 },  /* not tested */	{ 284,	0x86,	0x1,	0x1 },	{ 290,	0x89,	0x1,	0x1 },	{ 400,	0x5c,	0x1,	0x0 },	{ 474,	0x96,	0x2,	0x0 },	{ 508,	0x77,	0x1,	0x0 },	{ 533,	0xd6,	0x3,	0x0 },	{   0,	   0,	  0,	  0 }};/* * Memory Clock Change  */struct mem_clk_t s3c2410_memclks[] = {	/*FClK  Bcon6       Bcon7        Ref */	{ 284,	0x00018005, 0x00018005, 0x009c0379},	{ 290,	0x00018005, 0x00018005, 0x009c0379},	{ 400,	0x00018005, 0x00018005, 0x009c0379},	{   0,	   0,	  0,	  0 }};static inline unsigned longcal_bus_clk(unsigned long cpu_clk, unsigned long ratio, int who){	unsigned long hclk = 0,pclk = 0;	switch( (ratio&0x6) >> 1 ) {		case 0:  			hclk = cpu_clk;			break;		case 1:			hclk = cpu_clk/2;			break;		case 2:			hclk = cpu_clk/4;			break;		case 3:			hclk = cpu_clk/3;			break;	}	switch ( ratio&0x1) {		case 0:			pclk = hclk;			break;		case 1:			pclk = hclk/2;			break;	}	return ( who ? hclk: pclk );}/*  * Note: this code is not tested. * * set_cpu_clk(): *   clk: cpu clock to set. unit is mega hertz  *   ratio:  */static int set_cpu_clk(unsigned long clk){	struct cpu_clk_t *clks = s3c2410_clks;	while (clks->clock != 0) {		if (clk == clks->clock)		    break;		clks++;	}	if (clks->clock == 0) {		printk("Can not find cpu clock table\n");		return -2;	}		MPLLCON = ((clks->mdiv << 12) | (clks->pdiv << 4) | (clks->sdiv));	return 0;}static intchange_memctl_regs(unsigned long clk) {	struct mem_clk_t * memclks = s3c2410_memclks;	while ( memclks->clock !=0) {		if (clk == memclks->clock)			break;		memclks++;	}	if (memclks->clock == 0) {		printk("Can not find mem  clock table\n");		return -2;	}	BANKCON6 = memclks->bankcon6;	BANKCON7 = memclks->bankcon7;	REFRESH  = memclks->refresh;	return 0;}#define REFRESH_PERIOD 78  /* 7.8us */static intchange_refresh(unsigned long hclk){	hclk = hclk /10000000;	REFRESH = (REFRESH & ~0x7ff) | (2049-(unsigned int)(hclk * REFRESH_PERIOD));	return 0;}/* * cpu clock = (((mdiv + 8) * FIN) / ((pdiv + 2) * (1 << sdiv))) *  FIN = Input Frequency (to CPU) */static inline unsigned longget_cpu_clk(void){	unsigned long val = MPLLCON;		return (((GET_MDIV(val) + 8) * FIN * 2) / \		((GET_PDIV(val) + 2) * (1 << GET_SDIV(val))));			}static unsigned longget_bus_clk(int who){	unsigned long cpu_clk = get_cpu_clk();	unsigned long ratio = CLKDIVN;	return (cal_bus_clk(cpu_clk, ratio, who));}static void print_cpu_info(void){	long armrev = 0;	unsigned long mpll = MPLLCON;		__asm__("mrc	p15, 0, %0, c0, c0, 0" : "=r" (armrev));	printk("\nProcessor Information (Revision: 0x%08lx)\n", armrev);	printk("--------------------------------------------\n");	printk("Processor clock: %d Hz\n", get_cpu_clk());	printk("AHB bus clock  : %d Hz\n", get_bus_clk(GET_HCLK));	printk("APB bus clock  : %d Hz\n", get_bus_clk(GET_PCLK));	printk("\nRegister values\n");	printk("MPLLCON: 0x%08lx", mpll);	printk("  (MDIV: 0x%04x, PDIV: 0x%02x, SDIV: 0x%02x)\n",		GET_MDIV(mpll), GET_PDIV(mpll), GET_SDIV(mpll));	printk("CLKDIVN: 0x%08lx\n\n", CLKDIVN);}/* * A clock is the PCLK clock. */static void change_baudrate(unsigned long clock){	unsigned long baudrate;	int ret;	baudrate = get_param_value("baudrate", &ret);	if (ret) {		printk("There is no 'baudrate' parameter\n");		return;	}	#if defined(CONFIG_SERIAL_UART0)	UBRDIV0 = ((clock / (baudrate * 16)) - 1);#elif defined(CONFIG_SERIAL_UART1)	UBRDIV1 = ((clock / (baudrate * 16)) - 1);#endif}void change_clk_divider(int divider ){	int hdivn =2, pdivn = 0;	switch (divider) {		case 111:hdivn = 1; pdivn = 1; break;		case 122:hdivn = 2; pdivn = 2; break;		case 124:hdivn = 2; pdivn = 4; break;		case 133:hdivn = 3; pdivn = 3; break;		case 136:hdivn = 3; pdivn = 6; break;		case 144:hdivn = 4; pdivn = 4; break;		case 148:hdivn = 8; pdivn = 8; break;		default:			 printk(" Wrong divider %d \n");	}	//if ( hdivn !=0 ) 	//	MMU_SetAsyncBusMode();//	else//		MMU_SetFastBusMode();}/* * change cpu clock and bus clock * Changed By SW.LEE * */int change_sys_clks(unsigned long cpu_clk, unsigned long ratio){	int ret = 0;	printk("CPU Clock Change From %d Mhz  To %d Mhz \n",				get_cpu_clk()/1000000,cpu_clk);	if (ratio > 7) {		printk("Wrong Clock Ration %d \n",ratio);	}	else	{		CLKDIVN = ratio;	}		ret = set_cpu_clk(cpu_clk);	if (ret) return -1;	//	change_memctl_regs(cpu_clk);	change_refresh(get_bus_clk(GET_HCLK)); 	change_baudrate(get_bus_clk(GET_PCLK));	{ 		/* To avoid showing broken characters to console */		int delay;		for (delay =0; delay < 0x10000; delay ++)			;	}	return 0;}/* * change a uart baudrate  */void change_uart_baudrate(void){	change_baudrate(get_bus_clk(GET_PCLK));}static inline int get_clk_divider(void){	int val = GET_DIVIDER_TIMER4(TCFG1);	return (2 << (val));}unsigned long get_clock_tick_rate(void){	unsigned long prescale = GET_PRESCALE_TIMER4(TCFG0);	unsigned long divider = (unsigned long)get_clk_divider();	unsigned freq = get_bus_clk(GET_PCLK);	if (!divider)		return 0;	return (freq / (prescale + 1) / divider);}static void time_wait(unsigned int sec, int unit){	unsigned long ticks, clock_tick_rate;	/* clear interupt bit */	SRCPND |= INT_TIMER4;	INTPND |= INT_TIMER4;	INTMSK &= ~INT_TIMER4;			/* enable timer 4 interrupt */	clock_tick_rate = get_clock_tick_rate();	if (clock_tick_rate == 0) {		printk("Can not get a clock tick rate\n");		return;	}	if (unit == 0) {		ticks = (clock_tick_rate * (sec)) / (1000 * 1000);	} else {		ticks = (clock_tick_rate * (sec)) / (1000);	}	TCNTB4 = ticks;	TCON = (TCON_4_UPDATE | COUNT_4_OFF);	/* load counter value */	TCON = (COUNT_4_ON);			/* start timer */	while (!(INTPND & INT_TIMER4)) ;		TCON = (COUNT_4_OFF);			/* stop timer */	INTMSK |= INT_TIMER4;			/* mask timer 4 interrupt */	/* clear interupt bit */	SRCPND |= INT_TIMER4;	INTPND |= INT_TIMER4;}static voidtime_delay(unsigned int sec, int unit){	unsigned int remain = sec;	while (remain > 0) {		if (remain > 40) {			sec = 40;		} else {			sec = remain;		}		time_wait(sec, unit);		remain -= sec;	}}void arch_udelay(unsigned int usec){	time_delay(usec, 0);}void arch_mdelay(unsigned int msec){	time_delay(msec, 1);}void init_time(void){	TCFG0 = (TCFG0_DZONE(0) | TCFG0_PRE1(15) | TCFG0_PRE0(0));}/* * Perform a soft reset of the system.  Put the CPU into the * same state as it would be if it had been reset, and branch * to what would be the reset vector. * * loc: location to jump to for soft reset */void processor_reset(unsigned long loc){	cache_clean_invalidate();	tlb_invalidate();__asm__(	"mov	ip, #0\n"	"mcr	p15, 0, ip, c7, c7, 0\n"	/* invalidate I,D caches */	"mcr	p15, 0, ip, c7, c10, 4\n"	/* drain WB */	"mcr	p15, 0, ip, c8, c7, 0\n"	/* invalidate I & D TLBs */	"mrc	p15, 0, ip, c1, c0, 0\n"	/* ctrl register */	"bic	ip, ip, #0x000f\n"		/* ............wcam */	"bic	ip, ip, #0x1100\n"		/* ...i...s........ */	"mcr	p15, 0, ip, c1, c0, 0\n"	/* ctrl register */	"mov	pc, %0\n"	: : "r" (loc) );}void command_reset(int argc, const char **argv){	processor_reset(0);}user_command_t reset_cmd = {	"reset",	command_reset,	NULL,	"reset\t\t\t\t-- Reset the system"};static void display_cpu_help(void){	printk("Usage:\n");	printk("cpu info\t\t\t-- Display cpu informatin\n");	printk("cpu set <clock> <ratio>\t\t-- Change cpu clock and bus clock\n");}static void command_cpu(int argc, const char **argv){	switch (argc) {	case 1:		goto print_usage;		break;	case 2:		if (strncmp("help", argv[1], 4) == 0) {			display_cpu_help();			break;		}		if (strncmp("info", argv[1], 4) == 0) {			print_cpu_info();			break;		}		goto print_usage;	case 4:		if (strncmp("set", argv[1], 3) == 0) {			unsigned long clock = strtoul(argv[2], NULL, 0, NULL);			unsigned long ratio = strtoul(argv[3], NULL, 0, NULL);			int ret = 0;			ret = change_sys_clks(clock, ratio);			if (ret)				printk("Failed. Can not change cpu clock\n");			else				printk("OK\n");			break;		}	default:		goto print_usage;		break;	}	return;print_usage:	display_cpu_help();}user_command_t cpu_cmd = {	"cpu",	command_cpu,	NULL,	"cpu [{cmds}] \t\t\t-- Manage cpu clocks"};

?? 快捷鍵說明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
婷婷开心激情综合| 久久99久久99| 精品国产乱码久久久久久浪潮| 成人精品免费网站| 欧美aⅴ一区二区三区视频| 国产欧美日本一区视频| 欧美一区二区在线播放| 99re这里都是精品| 狠狠色丁香久久婷婷综| 亚洲chinese男男1069| 中文字幕一区二区三区视频| 日韩欧美中文字幕公布| 欧美日韩黄色一区二区| 99久久er热在这里只有精品15| 久久91精品国产91久久小草 | 色婷婷久久久综合中文字幕 | 蜜臂av日日欢夜夜爽一区| 亚洲色图一区二区三区| 久久蜜桃av一区二区天堂 | 韩国v欧美v日本v亚洲v| 午夜av电影一区| 亚洲激情av在线| 国产精品三级在线观看| 久久久青草青青国产亚洲免观| 在线综合视频播放| 精品1区2区3区| 在线视频你懂得一区| 99re这里只有精品视频首页| 成人精品视频一区二区三区尤物| 国产精品一二三区| 久久精品国产网站| 欧美aaaaa成人免费观看视频| 午夜a成v人精品| 日韩中文字幕麻豆| 日日夜夜免费精品| 午夜成人免费电影| 热久久久久久久| 丝袜美腿亚洲色图| 婷婷久久综合九色综合伊人色| 亚洲午夜电影在线观看| 亚洲高清不卡在线观看| 亚欧色一区w666天堂| 日韩精品一级中文字幕精品视频免费观看| 亚洲综合另类小说| 一区二区三区丝袜| 性做久久久久久久免费看| 午夜免费欧美电影| 久久精品免费观看| 国产高清成人在线| www.欧美日韩| 色94色欧美sute亚洲13| 欧美天堂一区二区三区| 欧美日韩精品久久久| 777xxx欧美| 久久精品免视看| 国产日韩欧美高清在线| 亚洲欧洲av一区二区三区久久| 亚洲欧美另类小说视频| 午夜亚洲国产au精品一区二区 | 国产91在线观看| 99久久精品情趣| 欧美亚洲一区二区在线观看| 宅男噜噜噜66一区二区66| 久久亚洲免费视频| 亚洲天堂免费看| 午夜精品影院在线观看| 久久99国产精品免费网站| 成人av免费在线| 欧美日韩黄色影视| 久久色在线观看| 最新中文字幕一区二区三区| 亚洲成av人片在线观看无码| 国内精品久久久久影院薰衣草| 成人免费三级在线| 精品视频色一区| 久久久久久亚洲综合| 亚洲美女在线国产| 麻豆成人综合网| 色综合色狠狠综合色| 制服丝袜激情欧洲亚洲| 国产欧美一区二区精品婷婷| 亚洲人午夜精品天堂一二香蕉| 天堂av在线一区| 99国产精品久久久久久久久久| 91精品在线一区二区| 亚洲天堂免费看| 精品中文字幕一区二区| 91一区一区三区| 欧美成人r级一区二区三区| 中文字幕亚洲区| 免费看日韩a级影片| av一区二区三区在线| 日韩三级电影网址| 一区二区激情小说| 国产成人免费xxxxxxxx| 56国语精品自产拍在线观看| 亚洲欧美一区二区在线观看| 免费观看一级特黄欧美大片| 99精品久久只有精品| 精品少妇一区二区三区在线播放 | 国产一区日韩二区欧美三区| 在线视频中文字幕一区二区| 国产日韩亚洲欧美综合| 日韩电影在线观看一区| 色综合天天综合狠狠| 久久蜜臀精品av| 蜜臀久久99精品久久久画质超高清 | 不卡一区二区在线| 51久久夜色精品国产麻豆| 综合激情网...| 丁香婷婷综合网| 日韩精品最新网址| 香蕉影视欧美成人| 色综合天天在线| 中文字幕日韩一区| 国产乱码精品一品二品| 欧美成人官网二区| 美女精品一区二区| 欧美日韩成人在线一区| 亚洲国产三级在线| 一本久久综合亚洲鲁鲁五月天| 欧美韩国一区二区| 国产精品 欧美精品| 久久久精品tv| 国产精品一区在线| 久久综合久色欧美综合狠狠| 激情综合网av| 精品免费国产一区二区三区四区| 日韩国产精品久久久久久亚洲| 欧美日韩在线三级| 亚洲一区成人在线| 欧美视频日韩视频| 亚洲成人免费视频| 91精品国产综合久久久久| 日韩成人av影视| 这里只有精品免费| 久久国产乱子精品免费女| 日韩免费高清av| 国产一区二区三区免费看| 久久天天做天天爱综合色| 国产精品一区二区久久不卡| 久久奇米777| 国产传媒久久文化传媒| 国产视频一区不卡| 成人高清视频免费观看| 最新高清无码专区| 欧美优质美女网站| 日韩在线一区二区三区| 26uuu色噜噜精品一区二区| 国产成人自拍网| 亚洲天天做日日做天天谢日日欢| 91久久精品网| 日韩成人精品在线观看| 337p粉嫩大胆色噜噜噜噜亚洲| 国产成人免费视频| 亚洲色图视频网站| 欧美亚洲国产一区二区三区| 日韩精品色哟哟| 精品美女一区二区| 成人深夜福利app| 一区二区久久久久| 日韩一区二区免费视频| 国产黄色91视频| 亚洲综合另类小说| 日韩欧美国产一区二区在线播放 | 91社区在线播放| 亚洲综合精品久久| 日韩精品中午字幕| 91网站黄www| 日韩精品亚洲专区| 日本一区二区在线不卡| 在线观看国产91| 久久91精品国产91久久小草| 亚洲欧美在线观看| 欧美一区二区播放| 白白色亚洲国产精品| 日本不卡高清视频| 亚洲色图欧美偷拍| 日韩免费视频一区二区| 懂色av一区二区三区免费看| 亚洲一级二级三级| 久久精品欧美日韩精品| 欧美日韩一卡二卡三卡 | 亚洲黄网站在线观看| 日韩一卡二卡三卡| 色呦呦国产精品| 美女视频黄久久| 亚洲精品一卡二卡| 久久久激情视频| 欧美一卡在线观看| 91九色02白丝porn| 国产精品亚洲第一区在线暖暖韩国 | 成人综合日日夜夜| 亚洲成精国产精品女| 欧美国产欧美综合| 日韩午夜电影av| 欧美手机在线视频| av不卡在线播放| 韩国精品久久久| 日韩高清一区在线|