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

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

?? elpt860.c

?? u-boot1.3.0的原碼,從配了網絡驅動和FLASH的驅動,并該用ESC竟如
?? C
字號:
/***=====================================================================**** Copyright (C) 2000, 2001, 2002, 2003** The LEOX team <team@leox.org>, http://www.leox.org**** LEOX.org is about the development of free hardware and software resources**   for system on chip.**** Description: U-Boot port on the LEOX's ELPT860 CPU board** ~~~~~~~~~~~****=====================================================================**** 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****=====================================================================*//*** Note 1: In this file, you have to provide the following functions:** ------**              int             board_early_init_f(void)**              int             checkboard(void)**              long int        initdram(int board_type)** called from 'board_init_f()' into 'common/board.c'****              void            reset_phy(void)** called from 'board_init_r()' into 'common/board.c'*/#include <common.h>#include <mpc8xx.h>/* ------------------------------------------------------------------------- */static long int dram_size (long int, long int *, long int);/* ------------------------------------------------------------------------- */#define	_NOT_USED_	0xFFFFFFFFconst uint init_sdram_table[] = {	/*	 * Single Read. (Offset 0 in UPMA RAM)	 */	0x0FFCCC04, 0xFFFFFC04, 0x0FFC3C04, 0xFFFFFC04,	0xFFFFFC04,		/* last */	/*	 * SDRAM Initialization (offset 5 in UPMA RAM)	 *	 * This is no UPM entry point. The following definition uses	 * the remaining space to establish an initialization	 * sequence, which is executed by a RUN command.	 *	 */	0xFFFFFC04, 0xFFFFFC04, 0x0FFC3C04,	/* last */	/*	 * Burst Read. (Offset 8 in UPMA RAM)	 */	0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04,	0x0FFC3C04, 0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04,	0xFFFFFC04, 0x0FFC3C04, 0xFFFFFC04, 0xFFFFFC04,	0xFFFFFC04, 0xFFFFFC04, 0x0FFC3C04, 0xFFFFFC04,	/* last */	/*	 * Single Write. (Offset 18 in UPMA RAM)	 */	0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04, 0x0FFC3C04,	0xFFFFFC04, 0xFFFFFC04, 0x0FFFFC04, 0xFFFFFC04,	/* last */	/*	 * Burst Write. (Offset 20 in UPMA RAM)	 */	0x0FFC3C04, 0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04,	0xFFFFFC04, 0x0FFC3C04, 0xFFFFFC04, 0xFFFFFC04,	0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC34, 0x0FAC0C34,	0xFFFFFC05, 0xFFFFFC04, 0x0FFCFC04, 0xFFFFFC05,	/* last */};const uint sdram_table[] = {	/*	 * Single Read. (Offset 0 in UPMA RAM)	 */	0x0F0FFC24, 0x0F0CFC04, 0xFF0FFC04, 0x00AF3C04,	0xFF0FFC00,		/* last */	/*	 * SDRAM Initialization (offset 5 in UPMA RAM)	 *	 * This is no UPM entry point. The following definition uses	 * the remaining space to establish an initialization	 * sequence, which is executed by a RUN command.	 *	 */	0x0FFCCC04, 0xFFAFFC05, 0xFFAFFC05,	/* last */	/*	 * Burst Read. (Offset 8 in UPMA RAM)	 */	0x0F0FFC24, 0x0F0CFC04, 0xFF0FFC04, 0x00AF3C04,	0xF00FFC00, 0xF00FFC00, 0xF00FFC00, 0xFF0FFC00,	0x0FFCCC04, 0xFFAFFC05, 0xFFAFFC04, 0xFFAFFC04,	0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04,	/* last */	/*	 * Single Write. (Offset 18 in UPMA RAM)	 */	0x0F0FFC24, 0x0F0CFC04, 0xFF0FFC04, 0x00AF0C00,	0xFF0FFC04, 0x0FFCCC04, 0xFFAFFC05,	/* last */	_NOT_USED_,	/*	 * Burst Write. (Offset 20 in UPMA RAM)	 */	0x0F0FFC24, 0x0F0CFC04, 0xFF0FFC00, 0x00AF0C00,	0xF00FFC00, 0xF00FFC00, 0xF00FFC04, 0x0FFCCC04,	0xFFAFFC04, 0xFFAFFC05, 0xFFAFFC04, 0xFFAFFC04,	0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04,	/* last */	/*	 * Refresh  (Offset 30 in UPMA RAM)	 */	0x0FFC3C04, 0xFFFFFC04, 0xFFFFFC04, 0xFFFFFC04,	0xFFFFFC05, 0xFFFFFC04, 0xFFFFFC05, _NOT_USED_,	0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04, 0xFFAFFC04,	/* last */	/*	 * Exception. (Offset 3c in UPMA RAM)	 */	0x0FFFFC34, 0x0FAC0C34, 0xFFFFFC05, 0xFFAFFC04,	/* last */};/* ------------------------------------------------------------------------- */#define CFG_PC4    0x0800#define CFG_DS1    CFG_PC4/* * Very early board init code (fpga boot, etc.) */int board_early_init_f (void){	volatile immap_t *immr = (immap_t *) CFG_IMMR;	/*	 * Light up the red led on ELPT860 pcb (DS1) (PCDAT)	 */	immr->im_ioport.iop_pcdat &= ~CFG_DS1;	/* PCDAT (DS1 = 0)                */	immr->im_ioport.iop_pcpar &= ~CFG_DS1;	/* PCPAR (0=general purpose I/O)  */	immr->im_ioport.iop_pcdir |= CFG_DS1;	/* PCDIR (I/O: 0=input, 1=output) */	return (0);		/* success */}/* * Check Board Identity: * * Test ELPT860 ID string * * Return 1 if no second DRAM bank, otherwise returns 0 */int checkboard (void){	char *s = getenv ("serial#");	if (!s || strncmp (s, "ELPT860", 7))		printf ("### No HW ID - assuming ELPT860\n");	return (0);		/* success */}/* ------------------------------------------------------------------------- */long int initdram (int board_type){	volatile immap_t *immap = (immap_t *) CFG_IMMR;	volatile memctl8xx_t *memctl = &immap->im_memctl;	long int size8, size9;	long int size_b0 = 0;	/*	 * This sequence initializes SDRAM chips on ELPT860 board	 */	upmconfig (UPMA, (uint *) init_sdram_table,		   sizeof (init_sdram_table) / sizeof (uint));	memctl->memc_mptpr = 0x0200;	memctl->memc_mamr = 0x18002111;	memctl->memc_mar = 0x00000088;	memctl->memc_mcr = 0x80002000;	/* CS1: SDRAM bank 0 */	upmconfig (UPMA, (uint *) sdram_table,		   sizeof (sdram_table) / sizeof (uint));	/*	 * Preliminary prescaler for refresh (depends on number of	 * banks): This value is selected for four cycles every 62.4 us	 * with two SDRAM banks or four cycles every 31.2 us with one	 * bank. It will be adjusted after memory sizing.	 */	memctl->memc_mptpr = CFG_MPTPR_2BK_8K;	/*	 * The following value is used as an address (i.e. opcode) for	 * the LOAD MODE REGISTER COMMAND during SDRAM initialisation. If	 * the port size is 32bit the SDRAM does NOT "see" the lower two	 * address lines, i.e. mar=0x00000088 -> opcode=0x00000022 for	 * MICRON SDRAMs:	 * ->    0 00 010 0 010	 *       |  |   | |   +- Burst Length = 4	 *       |  |   | +----- Burst Type   = Sequential	 *       |  |   +------- CAS Latency  = 2	 *       |  +----------- Operating Mode = Standard	 *       +-------------- Write Burst Mode = Programmed Burst Length	 */	memctl->memc_mar = 0x00000088;	/*	 * Map controller banks 2 and 3 to the SDRAM banks 2 and 3 at	 * preliminary addresses - these have to be modified after the	 * SDRAM size has been determined.	 */	memctl->memc_or1 = CFG_OR1_PRELIM;	memctl->memc_br1 = CFG_BR1_PRELIM;	memctl->memc_mamr = CFG_MAMR_8COL & (~(MAMR_PTAE));	/* no refresh yet */	udelay (200);	/* perform SDRAM initializsation sequence */	memctl->memc_mcr = 0x80002105;	/* CS1: SDRAM bank 0 */	udelay (1);	memctl->memc_mcr = 0x80002230;	/* CS1: SDRAM bank 0 - execute twice */	udelay (1);	memctl->memc_mamr |= MAMR_PTAE;	/* enable refresh */	udelay (1000);	/*	 * Check Bank 0 Memory Size for re-configuration	 *	 * try 8 column mode	 */	size8 = dram_size (CFG_MAMR_8COL,			   SDRAM_BASE1_PRELIM, SDRAM_MAX_SIZE);	udelay (1000);	/*	 * try 9 column mode	 */	size9 = dram_size (CFG_MAMR_9COL,			   SDRAM_BASE1_PRELIM, SDRAM_MAX_SIZE);	if (size8 < size9) {	/* leave configuration at 9 columns       */		size_b0 = size9;		/* debug ("SDRAM Bank 0 in 9 column mode: %ld MB\n", size >> 20); */	} else {		/* back to 8 columns                      */		size_b0 = size8;		memctl->memc_mamr = CFG_MAMR_8COL;		udelay (500);		/* debug ("SDRAM Bank 0 in 8 column mode: %ld MB\n", size >> 20); */	}	udelay (1000);	/*	 * Adjust refresh rate depending on SDRAM type, both banks	 * For types > 128 MBit leave it at the current (fast) rate	 */	if (size_b0 < 0x02000000) {		/* reduce to 15.6 us (62.4 us / quad) */		memctl->memc_mptpr = CFG_MPTPR_2BK_4K;		udelay (1000);	}	/*	 * Final mapping: map bigger bank first	 */	memctl->memc_or1 = ((-size_b0) & 0xFFFF0000) | CFG_OR_TIMING_SDRAM;	memctl->memc_br1 = (CFG_SDRAM_BASE & BR_BA_MSK) | BR_MS_UPMA | BR_V;	{		unsigned long reg;		/* adjust refresh rate depending on SDRAM type, one bank */		reg = memctl->memc_mptpr;		reg >>= 1;	/* reduce to CFG_MPTPR_1BK_8K / _4K */		memctl->memc_mptpr = reg;	}	udelay (10000);	return (size_b0);}/* ------------------------------------------------------------------------- *//* * Check memory range for valid RAM. A simple memory test determines * the actually available RAM size between addresses `base' and * `base + maxsize'. Some (not all) hardware errors are detected: * - short between address lines * - short between data lines */static long intdram_size (long int mamr_value, long int *base, long int maxsize){	volatile immap_t *immap = (immap_t *) CFG_IMMR;	volatile memctl8xx_t *memctl = &immap->im_memctl;	memctl->memc_mamr = mamr_value;	return (get_ram_size (base, maxsize));}/* ------------------------------------------------------------------------- */#define CFG_PA1     0x4000#define CFG_PA2     0x2000#define CFG_LBKs    (CFG_PA2 | CFG_PA1)void reset_phy (void){	volatile immap_t *immr = (immap_t *) CFG_IMMR;	/*	 * Ensure LBK LXT901 ethernet 1 & 2 = 0 ... for normal loopback in effect	 *                                          and no AUI loopback	 */	immr->im_ioport.iop_padat &= ~CFG_LBKs;	/* PADAT (LBK eth 1&2 = 0)        */	immr->im_ioport.iop_papar &= ~CFG_LBKs;	/* PAPAR (0=general purpose I/O)  */	immr->im_ioport.iop_padir |= CFG_LBKs;	/* PADIR (I/O: 0=input, 1=output) */}

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
久久电影网电视剧免费观看| 26uuu亚洲综合色| 欧美剧在线免费观看网站| 欧美日韩国产中文| 久久一区二区三区四区| 亚洲乱码国产乱码精品精的特点| 日韩精品一区第一页| 国产福利精品一区二区| 日本精品一级二级| 欧美一区二区人人喊爽| 中文字幕巨乱亚洲| 亚洲3atv精品一区二区三区| 国产成人午夜片在线观看高清观看| 色婷婷狠狠综合| 精品国产乱码久久久久久老虎| 1024精品合集| 久久超级碰视频| 一本到高清视频免费精品| 欧美v国产在线一区二区三区| 国产精品久久久久久久久动漫 | 9色porny自拍视频一区二区| 欧美在线你懂得| 国产欧美视频一区二区| 婷婷丁香激情综合| 国产电影一区在线| 91麻豆精品91久久久久久清纯 | av动漫一区二区| 日韩精品一区二区三区四区| 亚洲精品va在线观看| 国产精品综合久久| 欧美日韩不卡在线| 亚洲免费av观看| 国产精品亚洲一区二区三区在线| 欧美三级蜜桃2在线观看| 国产精品久久久爽爽爽麻豆色哟哟 | 青青青伊人色综合久久| 91在线观看一区二区| 久久免费偷拍视频| 天涯成人国产亚洲精品一区av| www.亚洲色图| xvideos.蜜桃一区二区| 午夜不卡av在线| 91年精品国产| 国产精品区一区二区三区| 久久精品99国产国产精| 欧美少妇xxx| 亚洲色图制服丝袜| 成人免费三级在线| 国产亚洲欧洲997久久综合| 婷婷六月综合亚洲| 一本久久精品一区二区| 国产精品五月天| 国产精品99久久不卡二区| 日韩限制级电影在线观看| 亚洲一区在线观看视频| 97国产一区二区| 国产精品狼人久久影院观看方式| 久久电影网站中文字幕| 欧美一区二区三区白人| 天堂久久一区二区三区| 欧美性受xxxx黑人xyx性爽| 亚洲少妇中出一区| 成人高清免费观看| 欧美激情一区在线| 国产宾馆实践打屁股91| 国产夜色精品一区二区av| 精一区二区三区| 欧美一区二区福利在线| 日韩va亚洲va欧美va久久| 欧美日韩一区成人| 亚洲mv在线观看| 欧美日韩视频第一区| 亚洲成av人片一区二区三区| 欧美影视一区二区三区| 一区二区三区高清在线| 色8久久精品久久久久久蜜| 亚洲精品水蜜桃| 91激情在线视频| 亚洲国产精品久久久久婷婷884| 色吧成人激情小说| 亚洲综合999| 欧美日韩免费一区二区三区| 日韩精品一级二级 | 国产一区二区三区四| 久久久久成人黄色影片| 国产99久久久国产精品潘金网站| 欧美激情自拍偷拍| 97成人超碰视| 亚洲伊人色欲综合网| 欧美妇女性影城| 日韩福利电影在线| 精品蜜桃在线看| 粉嫩在线一区二区三区视频| 国产精品久久久久久久久免费相片 | 欧美艳星brazzers| 婷婷综合五月天| 91精品国产一区二区三区蜜臀| 奇米四色…亚洲| 久久久久久久久99精品| 成人av综合在线| 亚洲一区二区三区小说| 91精品国产欧美一区二区| 激情国产一区二区| 国产精品二三区| 欧美亚州韩日在线看免费版国语版| 婷婷成人综合网| 久久久噜噜噜久久中文字幕色伊伊| 成人小视频免费在线观看| 一区二区三区蜜桃网| 欧美一区二区福利视频| 国产成人精品免费网站| 亚洲高清视频在线| 欧美精品一区二区不卡 | 精品制服美女久久| 久久影院电视剧免费观看| 成人动漫一区二区在线| 亚洲图片自拍偷拍| 欧美va在线播放| va亚洲va日韩不卡在线观看| 天天做天天摸天天爽国产一区| 久久香蕉国产线看观看99| 91搞黄在线观看| 国产一级精品在线| 亚洲国产精品久久一线不卡| 久久婷婷国产综合精品青草| 色综合婷婷久久| 久久99国产精品久久99| 亚洲同性同志一二三专区| 欧美一级在线观看| 一本色道久久综合亚洲91| 麻豆国产精品视频| 最新中文字幕一区二区三区| 欧美一级黄色大片| 91丨九色porny丨蝌蚪| 久久精品99久久久| 亚洲另类在线视频| 国产亚洲精品免费| 欧美精品乱人伦久久久久久| www.日韩av| 久久精品久久99精品久久| 亚洲免费毛片网站| 国产亚洲精品久| 欧美一区二区三区四区高清| 91女神在线视频| 久久国产免费看| 樱桃视频在线观看一区| 久久久久久久久蜜桃| 91精品国产一区二区人妖| 91麻豆国产香蕉久久精品| 国产一区激情在线| 午夜精品久久久久久久久久久| 国产精品亲子伦对白| 日韩免费视频一区二区| 精品视频全国免费看| 91在线播放网址| 粉嫩高潮美女一区二区三区| 免费成人美女在线观看.| 亚洲一区在线观看视频| **性色生活片久久毛片| 国产欧美精品一区aⅴ影院| 日韩亚洲欧美高清| 欧美三级视频在线观看| 色av成人天堂桃色av| 99久久精品99国产精品| 国产成人综合自拍| 九九久久精品视频| 美女视频一区在线观看| 日韩高清在线电影| 亚洲第一久久影院| 一区二区三区日韩在线观看| 亚洲色图第一区| 中文字幕亚洲成人| 中文字幕的久久| 久久精品人人做人人综合| 久久这里只精品最新地址| 精品国产91乱码一区二区三区 | 日韩电影免费一区| 亚洲成人av福利| 亚洲自拍偷拍欧美| 一区二区三区日韩在线观看| 一区二区三区.www| 亚洲自拍偷拍综合| 亚洲一级电影视频| 亚洲午夜影视影院在线观看| 伊人开心综合网| 一区二区三区鲁丝不卡| 亚洲国产视频a| 五月天激情综合| 视频一区国产视频| 日韩国产欧美视频| 日韩精品免费专区| 蜜桃av一区二区三区电影| 久久电影国产免费久久电影| 蜜桃视频在线一区| 国精品**一区二区三区在线蜜桃| 国产一区二区美女| 成人动漫一区二区| 在线观看成人免费视频| 欧美人伦禁忌dvd放荡欲情| 欧美绝品在线观看成人午夜影视|