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

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

?? articias.c

?? gumstiz u-boot loader in linux
?? 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"#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){    DECLARE_GLOBAL_DATA_PTR;	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 */		{1, 11, 8, 8, 0x00840f00},

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产欧美精品一区二区色综合| 一区二区三区免费看视频| 国产精品美日韩| 日本vs亚洲vs韩国一区三区 | 91浏览器入口在线观看| 在线播放91灌醉迷j高跟美女 | 亚洲精品美国一| 国产精品亚洲一区二区三区妖精 | 91在线一区二区| 国产亚洲自拍一区| 美女一区二区三区| 欧美人动与zoxxxx乱| 亚洲激情综合网| 99r国产精品| 久久久三级国产网站| 久久国产综合精品| 7799精品视频| 亚洲香肠在线观看| 94-欧美-setu| 亚洲人成精品久久久久| 成人丝袜18视频在线观看| 欧美精品一区二区在线观看| 青青草97国产精品免费观看无弹窗版| 欧美亚洲尤物久久| 一区二区三区在线免费播放| 97精品电影院| 伊人一区二区三区| 欧美在线啊v一区| 亚洲成人在线网站| 欧美日韩精品一二三区| 亚洲香肠在线观看| 欧美久久免费观看| 午夜电影一区二区| 欧美一区在线视频| 麻豆国产精品视频| 久久久五月婷婷| 成人精品在线视频观看| 欧美经典三级视频一区二区三区| 岛国精品一区二区| 综合精品久久久| 欧美色图片你懂的| 麻豆国产精品视频| 久久精品人人做人人爽97| 国产成人av一区二区三区在线观看| 国产日韩精品一区二区三区 | 国产精品久久久久久久久果冻传媒| 国产精品白丝av| 国产欧美一区二区精品秋霞影院| 国产69精品久久久久毛片| 国产精品福利一区| 色94色欧美sute亚洲线路一久| 一区二区免费在线播放| 欧美美女直播网站| 国产综合色在线| 亚洲色欲色欲www| 欧美日韩国产电影| 国产乱人伦精品一区二区在线观看| 国产人妖乱国产精品人妖| 成人福利视频网站| 亚洲国产成人av好男人在线观看| 日韩欧美高清一区| 成人国产精品视频| 天天av天天翘天天综合网| 精品国产一区二区三区久久影院 | 欧美三级电影精品| 卡一卡二国产精品| 亚洲色欲色欲www| 日韩免费成人网| 色哟哟一区二区在线观看| 蜜臀精品久久久久久蜜臀 | jlzzjlzz亚洲女人18| 亚洲综合久久av| 精品国产露脸精彩对白| 99re视频精品| 精品一区二区三区的国产在线播放 | 91在线观看成人| 久久99精品久久久久久动态图| 国产精品国产三级国产普通话蜜臀 | 国产乱码字幕精品高清av| 亚洲免费大片在线观看| 日韩欧美激情在线| 91国产成人在线| 成人综合婷婷国产精品久久 | 一区二区成人在线视频| 久久久亚洲精华液精华液精华液| 欧美网站大全在线观看| 成人毛片视频在线观看| 理论片日本一区| 亚洲国产日韩在线一区模特 | 国产亚洲成年网址在线观看| 欧美性一二三区| 成人免费黄色在线| 国产麻豆精品theporn| 日韩中文字幕1| 一级精品视频在线观看宜春院 | 99国产精品久久久久久久久久 | 一区二区三区不卡在线观看| 国产情人综合久久777777| 欧美大片国产精品| 欧美蜜桃一区二区三区| 欧美亚洲精品一区| 在线观看亚洲精品视频| aa级大片欧美| 99精品1区2区| 不卡视频一二三四| 国产91清纯白嫩初高中在线观看 | 国内精品伊人久久久久影院对白| 午夜精品久久久久久久久久久 | 亚洲精品久久久蜜桃| 中文字幕av不卡| 国产日本亚洲高清| 日本一区二区三区四区在线视频| 久久天天做天天爱综合色| 亚洲精品在线免费观看视频| 精品国产一区久久| 久久久久久亚洲综合影院红桃| 欧美mv日韩mv| 久久久午夜精品理论片中文字幕| 久久综合色8888| 中文字幕精品—区二区四季| 国产精品久久久久久亚洲伦| 日韩理论片在线| 亚洲综合免费观看高清在线观看| 亚洲一区二区三区影院| 午夜伦理一区二区| 日韩二区在线观看| 精品综合免费视频观看| 国产精品一区在线| www.久久精品| 欧美日韩亚洲综合一区二区三区| 91麻豆精品国产91| 精品国产污污免费网站入口 | 日本高清视频一区二区| 欧美性xxxxxxxx| 欧美一级理论片| 欧美极品少妇xxxxⅹ高跟鞋 | 国产成人夜色高潮福利影视| 风间由美性色一区二区三区| 色94色欧美sute亚洲线路一ni| 欧美日韩一区不卡| 精品国产髙清在线看国产毛片| 国产日韩亚洲欧美综合| 一区二区在线免费| 美女尤物国产一区| 不卡大黄网站免费看| 欧美日韩国产成人在线免费| 久久久久国产免费免费 | 欧美色涩在线第一页| 精品少妇一区二区三区免费观看 | 国产精品进线69影院| 亚洲成人av电影| 国产黑丝在线一区二区三区| 色婷婷综合在线| 日韩三级免费观看| 国产精品久久久久久久久免费相片 | 亚洲国产综合在线| 国产一区在线观看视频| 欧美伊人久久久久久久久影院| 欧美精品一区二区久久婷婷| 一区二区三区免费在线观看| 紧缚捆绑精品一区二区| 欧美日韩亚洲国产综合| 欧美韩日一区二区三区四区| 日本中文一区二区三区| 色综合中文字幕国产| 久久精品亚洲国产奇米99| 亚洲成人精品影院| 99久久精品情趣| 久久精品水蜜桃av综合天堂| 日韩福利电影在线| 欧美亚洲国产bt| 中文字幕在线一区| 久久国产日韩欧美精品| 欧美丝袜丝nylons| 成人欧美一区二区三区白人| 国产精品一线二线三线| 日韩精品一区二区三区在线| 亚洲第一在线综合网站| 色欧美日韩亚洲| 亚洲天堂2016| 成人av在线影院| 日本一区二区免费在线观看视频| 精品中文av资源站在线观看| 欧美日韩国产一区二区三区地区| 一区二区在线免费| 91网址在线看| 亚洲男女一区二区三区| 99久久久国产精品| 综合在线观看色| 一本大道综合伊人精品热热| 中文字幕一区日韩精品欧美| 粉嫩绯色av一区二区在线观看| 久久精品视频免费观看| 国产精品亚洲专一区二区三区| 久久久久高清精品| 国产a级毛片一区| 中文字幕第一区综合| www.成人网.com| 亚洲欧美日韩小说| 91黄色免费观看|