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

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

?? articias.c

?? u-boot1.3.0的原碼,從配了網絡驅動和FLASH的驅動,并該用ESC竟如
?? C
?? 第 1 頁 / 共 2 頁
字號:
/* * (C) Copyright 2002 * Hyperion Entertainment, ThomasF@hyperion-entertainment.com * * See file CREDITS for list of people who contributed to this * project. * * 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 */#include <common.h>#include <pci.h>#include <asm/processor.h>#include "memio.h"#include "articiaS.h"#include "smbus.h"#include "via686.h"DECLARE_GLOBAL_DATA_PTR;#undef DEBUGstruct dimm_bank {	uint8 used;			/* Bank is populated */	uint32 rows;			/* Number of row addresses */	uint32 columns;			/* Number of column addresses */	uint8 registered;		/* SIMM is registered */	uint8 ecc;			/* SIMM has ecc */	uint8 burst_len;		/* Supported burst lengths */	uint32 cas_lat;			/* Supported CAS latencies */	uint32 cas_used;		/* CAS to use (not set by user) */	uint32 trcd;			/* RAS to CAS latency */	uint32 trp;			/* Precharge latency */	uint32 tclk_hi;			/* SDRAM cycle time (highest CAS latency) */	uint32 tclk_2hi;		/* SDRAM second highest CAS latency */	uint32 size;			/* Size of bank in bytes */	uint8 auto_refresh;		/* Module supports auto refresh */	uint32 refresh_time;		/* Refresh time (in ns) */};/*** Based in part on the evb64260 code*//* * translate ns.ns/10 coding of SPD timing values * into 10 ps unit values */static inline unsigned short NS10to10PS (unsigned char spd_byte){	unsigned short ns, ns10;	/* isolate upper nibble */	ns = (spd_byte >> 4) & 0x0F;	/* isolate lower nibble */	ns10 = (spd_byte & 0x0F);	return (ns * 100 + ns10 * 10);}/* * translate ns coding of SPD timing values * into 10 ps unit values */static inline unsigned short NSto10PS (unsigned char spd_byte){	return (spd_byte * 100);}long detect_sdram (uint8 * rom, int dimmNum, struct dimm_bank *banks){	int dimm_address = (dimmNum == 0) ? SM_DIMM0_ADDR : SM_DIMM1_ADDR;	uint32 busclock = gd->bus_clk;	uint32 memclock = busclock;	uint32 tmemclock = 1000000000 / (memclock / 100);	uint32 datawidth;	if (sm_get_data (rom, dimm_address) == 0) {		/* Nothing in slot, make both banks empty */		debug ("Slot %d: vacant\n", dimmNum);		banks[0].used = 0;		banks[1].used = 0;		return 0;	}	if (rom[2] != 0x04) {		debug ("Slot %d: No SDRAM\n", dimmNum);		banks[0].used = 0;		banks[1].used = 0;		return 0;	}	/* Determine number of banks/rows */	if (rom[5] == 1) {		banks[0].used = 1;		banks[1].used = 0;	} else {		banks[0].used = 1;		banks[1].used = 1;	}	/* Determine number of row addresses */	if (rom[3] & 0xf0) {		/* Different banks sizes */		banks[0].rows = rom[3] & 0x0f;		banks[1].rows = (rom[3] & 0xf0) >> 4;	} else {		/* Equal sized banks */		banks[0].rows = rom[3] & 0x0f;		banks[1].rows = banks[0].rows;	}	/* Determine number of column addresses */	if (rom[4] & 0xf0) {		/* Different bank sizes */		banks[0].columns = rom[4] & 0x0f;		banks[1].columns = (rom[4] & 0xf0) >> 4;	} else {		banks[0].columns = rom[4] & 0x0f;		banks[1].columns = banks[0].columns;	}	/* Check Jedec revision, and modify row/column accordingly */	if (rom[62] > 0x10) {		if (banks[0].rows <= 3)			banks[0].rows += 15;		if (banks[1].rows <= 3)			banks[1].rows += 15;		if (banks[0].columns <= 3)			banks[0].columns += 15;		if (banks[0].columns <= 3)			banks[0].columns += 15;	}	/* Check registered/unregisterd */	if (rom[21] & 0x12) {		banks[0].registered = 1;		banks[1].registered = 1;	} else {		banks[0].registered = 0;		banks[1].registered = 0;	}#ifdef CONFIG_ECC	/* Check parity/ECC */	banks[0].ecc = (rom[11] == 0x02);	banks[1].ecc = (rom[11] == 0x02);#endif	/* Find burst lengths supported */	banks[0].burst_len = rom[16] & 0x8f;	banks[1].burst_len = rom[16] & 0x8f;	/* Find possible cas latencies */	banks[0].cas_lat = rom[18] & 0x7F;	banks[1].cas_lat = rom[18] & 0x7F;	/* RAS/CAS latency */	banks[0].trcd = (NSto10PS (rom[29]) + (tmemclock - 1)) / tmemclock;	banks[1].trcd = (NSto10PS (rom[29]) + (tmemclock - 1)) / tmemclock;	/* Precharge latency */	banks[0].trp = (NSto10PS (rom[27]) + (tmemclock - 1)) / tmemclock;	banks[1].trp = (NSto10PS (rom[27]) + (tmemclock - 1)) / tmemclock;	/* highest CAS latency */	banks[0].tclk_hi = NS10to10PS (rom[9]);	banks[1].tclk_hi = NS10to10PS (rom[9]);	/* second highest CAS latency */	banks[0].tclk_2hi = NS10to10PS (rom[23]);	banks[1].tclk_2hi = NS10to10PS (rom[23]);	/* bank sizes */	datawidth = rom[13] & 0x7f;	banks[0].size =			(1L << (banks[0].rows + banks[0].columns)) *			/* FIXME datawidth */ 8 * rom[17];	if (rom[13] & 0x80)		banks[1].size = 2 * banks[0].size;	else		banks[1].size = (1L << (banks[1].rows + banks[1].columns)) *				/* FIXME datawidth */ 8 * rom[17];	/* Refresh */	if (rom[12] & 0x80) {		banks[0].auto_refresh = 1;		banks[1].auto_refresh = 1;	} else {		banks[0].auto_refresh = 0;		banks[1].auto_refresh = 0;	}	switch (rom[12] & 0x7f) {	case 0:		banks[0].refresh_time = (1562500 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (1562500 + (tmemclock - 1)) / tmemclock;		break;	case 1:		banks[0].refresh_time = (390600 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (390600 + (tmemclock - 1)) / tmemclock;		break;	case 2:		banks[0].refresh_time = (781200 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (781200 + (tmemclock - 1)) / tmemclock;		break;	case 3:		banks[0].refresh_time = (3125000 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (3125000 + (tmemclock - 1)) / tmemclock;		break;	case 4:		banks[0].refresh_time = (6250000 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (6250000 + (tmemclock - 1)) / tmemclock;		break;	case 5:		banks[0].refresh_time = (12500000 + (tmemclock - 1)) / tmemclock;		banks[1].refresh_time = (12500000 + (tmemclock - 1)) / tmemclock;		break;	default:		banks[0].refresh_time = 0x100;	/* Default of Articia S */		banks[1].refresh_time = 0x100;		break;	}#ifdef DEBUG	printf ("\nInformation for SIMM bank %ld:\n", dimmNum);	printf ("Number of banks: %ld\n", banks[0].used + banks[1].used);	printf ("Number of row addresses: %ld\n", banks[0].rows);	printf ("Number of coumns addresses: %ld\n", banks[0].columns);	printf ("SIMM is %sregistered\n",			banks[0].registered == 0 ? "not " : "");#ifdef CONFIG_ECC	printf ("SIMM %s ECC\n",			banks[0].ecc == 1 ? "supports" : "doesn't support");#endif	printf ("Supported burst lenghts: %s %s %s %s %s\n",			banks[0].burst_len & 0x08 ? "8" : " ",			banks[0].burst_len & 0x04 ? "4" : " ",			banks[0].burst_len & 0x02 ? "2" : " ",			banks[0].burst_len & 0x01 ? "1" : " ",			banks[0].burst_len & 0x80 ? "PAGE" : "    ");	printf ("Supported CAS latencies: %s %s %s\n",			banks[0].cas_lat & 0x04 ? "CAS 3" : "     ",			banks[0].cas_lat & 0x02 ? "CAS 2" : "     ",			banks[0].cas_lat & 0x01 ? "CAS 1" : "     ");	printf ("RAS to CAS latency: %ld\n", banks[0].trcd);	printf ("Precharge latency: %ld\n", banks[0].trp);	printf ("SDRAM highest CAS latency: %ld\n", banks[0].tclk_hi);	printf ("SDRAM 2nd highest CAS latency: %ld\n", banks[0].tclk_2hi);	printf ("SDRAM data width: %ld\n", datawidth);	printf ("Auto Refresh %ssupported\n",			banks[0].auto_refresh ? "" : "not ");	printf ("Refresh time: %ld clocks\n", banks[0].refresh_time);	if (banks[0].used)		printf ("Bank 0 size: %ld MB\n", banks[0].size / 1024 / 1024);	if (banks[1].used)		printf ("Bank 1 size: %ld MB\n", banks[1].size / 1024 / 1024);	printf ("\n");#endif	sm_term ();	return 1;}void select_cas (struct dimm_bank *banks, uint8 fast){	if (!banks[0].used) {		banks[0].cas_used = 0;		banks[0].cas_used = 0;		return;	}	if (fast) {		/* Search for fast CAS */		uint32 i;		uint32 c = 0x01;		for (i = 1; i < 5; i++) {			if (banks[0].cas_lat & c) {				banks[0].cas_used = i;				banks[1].cas_used = i;				debug ("Using CAS %d (fast)\n", i);				return;			}			c <<= 1;		}		/* Default to CAS 3 */		banks[0].cas_used = 3;		banks[1].cas_used = 3;		debug ("Using CAS 3 (fast)\n");		return;	} else {		/* Search for slow cas */		uint32 i;		uint32 c = 0x08;		for (i = 4; i > 1; i--) {			if (banks[0].cas_lat & c) {				banks[0].cas_used = i;				banks[1].cas_used = i;				debug ("Using CAS %d (slow)\n", i);				return;			}			c >>= 1;		}		/* Default to CAS 3 */		banks[0].cas_used = 3;		banks[1].cas_used = 3;		debug ("Using CAS 3 (slow)\n");		return;	}	banks[0].cas_used = 3;	banks[1].cas_used = 3;	debug ("Using CAS 3\n");	return;}uint32 get_reg_setting (uint32 banks, uint32 rows, uint32 columns, uint32 size){	uint32 i;	struct RowColumnSize {		uint32 banks;		uint32 rows;		uint32 columns;		uint32 size;		uint32 register_value;	};	struct RowColumnSize rcs_map[] = {		/*  Sbk Radr Cadr   MB     Value */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
一区精品在线播放| 国产精品一区在线| 看国产成人h片视频| 国产一区二区不卡在线| 懂色av一区二区在线播放| 91麻豆国产在线观看| 欧美理论片在线| 日本一区二区三区国色天香 | 日韩av不卡一区二区| 精品一区二区三区欧美| av成人老司机| 日韩欧美精品在线视频| 亚洲欧美偷拍三级| 美国av一区二区| 91麻豆.com| 精品嫩草影院久久| 一区二区在线观看视频 | 国产精品毛片久久久久久| 亚洲国产视频直播| 国产精品一区二区不卡| 欧美在线观看禁18| 久久精品夜色噜噜亚洲aⅴ| 亚洲国产视频在线| 岛国一区二区在线观看| 91精品国产综合久久婷婷香蕉| 国产精品女主播在线观看| 日韩电影在线一区| 日本精品免费观看高清观看| 久久久影视传媒| 婷婷中文字幕一区三区| av在线播放成人| 国产在线视频一区二区| 久久69国产一区二区蜜臀| 色呦呦一区二区三区| 久久久99久久精品欧美| 日韩黄色片在线观看| 色哟哟欧美精品| 久久久精品免费网站| 日韩国产高清影视| 欧美制服丝袜第一页| 国产精品传媒视频| 国产伦精品一区二区三区免费迷 | 天堂在线一区二区| 91在线视频观看| 亚洲精品在线观看视频| 日本亚洲视频在线| 在线观看av不卡| 国产精品伦理一区二区| 国产呦精品一区二区三区网站| 91麻豆精品国产91久久久久久久久| 亚洲欧美日本在线| 成人精品视频一区二区三区尤物| 欧美v日韩v国产v| 天天综合天天做天天综合| 91成人网在线| 亚洲色图一区二区| 91在线一区二区| 国产精品蜜臀在线观看| 成人亚洲一区二区一| 久久久久久久电影| 激情国产一区二区| 日韩美女视频一区二区在线观看| 三级在线观看一区二区| 欧美性感一区二区三区| 亚洲国产日日夜夜| 欧美性视频一区二区三区| 亚洲精品欧美激情| 色婷婷综合久久久久中文一区二区| 亚洲色图欧美在线| 一本色道久久加勒比精品 | 欧美日韩欧美一区二区| 亚洲精品国产a久久久久久 | 亚洲丰满少妇videoshd| 欧美日韩国产影片| 日韩主播视频在线| 在线不卡免费欧美| 日本特黄久久久高潮| 国产精品自拍av| 日韩国产在线观看| 欧美一二三四在线| 欧美吻胸吃奶大尺度电影 | 国产亚洲va综合人人澡精品 | 欧美曰成人黄网| 日韩免费电影网站| 日韩国产在线一| 欧美成人三级电影在线| 日韩成人午夜电影| 精品久久久久一区| 国产精品亚洲а∨天堂免在线| 久久久国产精华| 国产乱码精品一区二区三区忘忧草| 欧美成人精品福利| 激情综合五月婷婷| 国产精品狼人久久影院观看方式| 成人午夜电影小说| 亚洲免费观看视频| 色综合久久久久| 日本成人在线视频网站| 日韩欧美成人午夜| 国产成人av福利| 国产精品国产三级国产aⅴ无密码 国产精品国产三级国产aⅴ原创 | 国内精品免费**视频| 久久久久久亚洲综合| 91亚洲永久精品| 一区二区三区日韩在线观看| 欧美一区二区三区视频免费| 六月丁香婷婷色狠狠久久| 国产精品三级视频| 色呦呦国产精品| 六月丁香综合在线视频| 欧美激情一区在线| 欧美午夜免费电影| 久久电影网站中文字幕| 中文字幕一区二区不卡 | 国产人伦精品一区二区| 在线亚洲免费视频| 亚洲欧美另类图片小说| 欧美成人a在线| 91性感美女视频| 青青草91视频| 中文字幕在线不卡| 欧美精品亚洲二区| 成人看片黄a免费看在线| 亚洲午夜av在线| 国产欧美综合在线观看第十页| 成人午夜碰碰视频| 91福利社在线观看| 国产精品一区专区| 日本不卡视频在线| 国产亚洲欧美日韩在线一区| 色94色欧美sute亚洲线路一ni| 日本午夜一本久久久综合| 国产精品理伦片| 欧美日韩欧美一区二区| 成人午夜激情影院| 天使萌一区二区三区免费观看| 中国色在线观看另类| 色呦呦网站一区| 国产精品一二三四区| 亚洲免费色视频| 2欧美一区二区三区在线观看视频| 一本色道久久加勒比精品| 久久电影国产免费久久电影 | 91久久国产最好的精华液| 久热成人在线视频| 亚洲黄一区二区三区| 欧美国产精品v| 欧美精品三级在线观看| 色综合久久综合网97色综合| 精品一区二区三区的国产在线播放| 亚洲国产你懂的| 国产精品久久久久一区| 日韩欧美你懂的| 99久久婷婷国产| 激情都市一区二区| 日本女优在线视频一区二区| 综合欧美一区二区三区| 中文字幕成人网| 日韩一二三四区| 在线播放/欧美激情| 97精品超碰一区二区三区| 成人免费视频免费观看| 日本色综合中文字幕| 五月激情六月综合| 亚洲成人手机在线| 国产精品国模大尺度视频| 日本一区二区三区免费乱视频| 日韩手机在线导航| 欧美一区二区三区日韩| 在线一区二区三区| 一本大道久久精品懂色aⅴ| 处破女av一区二区| 国产成人av网站| 亚洲高清免费观看| 亚洲成av人在线观看| 亚洲一区自拍偷拍| 亚洲视频免费在线观看| 综合网在线视频| 国产欧美日韩综合精品一区二区| 久久综合久色欧美综合狠狠| 制服.丝袜.亚洲.另类.中文| 欧美精品久久99久久在免费线| 色噜噜狠狠色综合欧洲selulu| 成人午夜视频在线观看| 国产黑丝在线一区二区三区| 激情欧美日韩一区二区| 国产伦理精品不卡| 国产一区二区三区综合| 国产91在线看| 国产一区免费电影| 国产一区二区三区观看| 国产成人综合在线播放| 国产专区欧美精品| 成人国产精品免费网站| 成人av第一页| 在线视频国内一区二区| 色综合咪咪久久| 欧美精品自拍偷拍| 精品久久久久久久人人人人传媒| 欧美一区二区成人|