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

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

?? armlinux.c.svn-base

?? S3c2443 based u-boot loader source code for lib_arm folders and related source
?? SVN-BASE
字號:
/* * (C) Copyright 2002 * Sysgo Real-Time Solutions, GmbH <www.elinos.com> * Marius Groeger <mgroeger@sysgo.de> * * Copyright (C) 2001  Erik Mouw (J.A.K.Mouw@its.tudelft.nl) * * 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 <command.h>#include <image.h>#include <zlib.h>#include <asm/byteorder.h>#ifdef CONFIG_HAS_DATAFLASH#include <dataflash.h>#endif/*cmd_boot.c*/extern int do_reset (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[]);#if defined (CONFIG_SETUP_MEMORY_TAGS) || \    defined (CONFIG_CMDLINE_TAG) || \    defined (CONFIG_INITRD_TAG) || \    defined (CONFIG_SERIAL_TAG) || \    defined (CONFIG_REVISION_TAG) || \    defined (CONFIG_VFD)static void setup_start_tag (bd_t *bd);# ifdef CONFIG_SETUP_MEMORY_TAGSstatic void setup_memory_tags (bd_t *bd);# endifstatic void setup_commandline_tag (bd_t *bd, char *commandline);#if 0static void setup_ramdisk_tag (bd_t *bd);#endif# ifdef CONFIG_INITRD_TAGstatic void setup_initrd_tag (bd_t *bd, ulong initrd_start,			      ulong initrd_end);# endifstatic void setup_end_tag (bd_t *bd);# if defined (CONFIG_VFD)static void setup_videolfb_tag (gd_t *gd);# endifstatic struct tag *params;#endif /* CONFIG_SETUP_MEMORY_TAGS || CONFIG_CMDLINE_TAG || CONFIG_INITRD_TAG */#ifdef CONFIG_SHOW_BOOT_PROGRESS# include <status_led.h># define SHOW_BOOT_PROGRESS(arg)	show_boot_progress(arg)#else# define SHOW_BOOT_PROGRESS(arg)#endifextern image_header_t header;	/* from cmd_bootm.c */void do_bootm_linux (cmd_tbl_t *cmdtp, int flag, int argc, char *argv[],		     ulong addr, ulong *len_ptr, int verify){	DECLARE_GLOBAL_DATA_PTR;	ulong len = 0, checksum;	ulong initrd_start, initrd_end;	ulong data;	void (*theKernel)(int zero, int arch, uint params);	image_header_t *hdr = &header;	bd_t *bd = gd->bd;#ifdef CONFIG_CMDLINE_TAG	char *commandline = getenv ("bootargs");#endif	theKernel = (void (*)(int, int, uint))ntohl(hdr->ih_ep);	/*	 * Check if there is an initrd image	 */	if (argc >= 3) {		SHOW_BOOT_PROGRESS (9);		addr = simple_strtoul (argv[2], NULL, 16);		printf ("## Loading Ramdisk Image at %08lx ...\n", addr);		/* Copy header so we can blank CRC field for re-calculation */#ifdef CONFIG_HAS_DATAFLASH		if (addr_dataflash (addr)) {			read_dataflash (addr, sizeof (image_header_t),					(char *) &header);		} else#endif			memcpy (&header, (char *) addr,				sizeof (image_header_t));		if (ntohl (hdr->ih_magic) != IH_MAGIC) {			printf ("Bad Magic Number\n");			SHOW_BOOT_PROGRESS (-10);			do_reset (cmdtp, flag, argc, argv);		}		data = (ulong) & header;		len = sizeof (image_header_t);		checksum = ntohl (hdr->ih_hcrc);		hdr->ih_hcrc = 0;		if (crc32 (0, (char *) data, len) != checksum) {			printf ("Bad Header Checksum\n");			SHOW_BOOT_PROGRESS (-11);			do_reset (cmdtp, flag, argc, argv);		}		SHOW_BOOT_PROGRESS (10);		print_image_hdr (hdr);		data = addr + sizeof (image_header_t);		len = ntohl (hdr->ih_size);#ifdef CONFIG_HAS_DATAFLASH		if (addr_dataflash (addr)) {			read_dataflash (data, len, (char *) CFG_LOAD_ADDR);			data = CFG_LOAD_ADDR;		}#endif		if (verify) {			ulong csum = 0;			printf ("   Verifying Checksum ... ");			csum = crc32 (0, (char *) data, len);			if (csum != ntohl (hdr->ih_dcrc)) {				printf ("Bad Data CRC\n");				SHOW_BOOT_PROGRESS (-12);				do_reset (cmdtp, flag, argc, argv);			}			printf ("OK\n");		}		SHOW_BOOT_PROGRESS (11);		if ((hdr->ih_os != IH_OS_LINUX) ||		    (hdr->ih_arch != IH_CPU_ARM) ||		    (hdr->ih_type != IH_TYPE_RAMDISK)) {			printf ("No Linux ARM Ramdisk Image\n");			SHOW_BOOT_PROGRESS (-13);			do_reset (cmdtp, flag, argc, argv);		}#ifdef CONFIG_B2		/*		 *we need to copy the ramdisk to SRAM to let Linux boot		 */		memmove ((void *) ntohl(hdr->ih_load), (uchar *)data, len);		data = ntohl(hdr->ih_load);#endif /* CONFIG_B2 */		/*		 * Now check if we have a multifile image		 */	} else if ((hdr->ih_type == IH_TYPE_MULTI) && (len_ptr[1])) {		ulong tail = ntohl (len_ptr[0]) % 4;		int i;		SHOW_BOOT_PROGRESS (13);		/* skip kernel length and terminator */		data = (ulong) (&len_ptr[2]);		/* skip any additional image length fields */		for (i = 1; len_ptr[i]; ++i)			data += 4;		/* add kernel length, and align */		data += ntohl (len_ptr[0]);		if (tail) {			data += 4 - tail;		}		len = ntohl (len_ptr[1]);	} else {		/*		 * no initrd image		 */		SHOW_BOOT_PROGRESS (14);		len = data = 0;	}#ifdef	DEBUG	if (!data) {		printf ("No initrd\n");	}#endif	if (data) {		initrd_start = data;		initrd_end = initrd_start + len;	} else {		initrd_start = 0;		initrd_end = 0;	}	SHOW_BOOT_PROGRESS (15);	debug ("## Transferring control to Linux (at address %08lx) ...\n",	       (ulong) theKernel);#if defined (CONFIG_SETUP_MEMORY_TAGS) || \    defined (CONFIG_CMDLINE_TAG) || \    defined (CONFIG_INITRD_TAG) || \    defined (CONFIG_SERIAL_TAG) || \    defined (CONFIG_REVISION_TAG) || \    defined (CONFIG_VFD)	setup_start_tag (bd);#ifdef CONFIG_SERIAL_TAG	setup_serial_tag (&params);#endif#ifdef CONFIG_REVISION_TAG	setup_revision_tag (&params);#endif#ifdef CONFIG_SETUP_MEMORY_TAGS	setup_memory_tags (bd);#endif#ifdef CONFIG_CMDLINE_TAG	setup_commandline_tag (bd, commandline);#endif#ifdef CONFIG_INITRD_TAG	if (initrd_start && initrd_end)		setup_initrd_tag (bd, initrd_start, initrd_end);#endif#if defined (CONFIG_VFD)	setup_videolfb_tag ((gd_t *) gd);#endif	setup_end_tag (bd);#endif	/* we assume that the kernel is in place */	printf ("\nStarting kernel ...\n\n");#ifdef CONFIG_USB_DEVICE	{		extern void udc_disconnect (void);		udc_disconnect ();	}#endif	cleanup_before_linux ();	theKernel (0, bd->bi_arch_number, bd->bi_boot_params);}#if defined (CONFIG_SETUP_MEMORY_TAGS) || \    defined (CONFIG_CMDLINE_TAG) || \    defined (CONFIG_INITRD_TAG) || \    defined (CONFIG_SERIAL_TAG) || \    defined (CONFIG_REVISION_TAG) || \    defined (CONFIG_VFD)static void setup_start_tag (bd_t *bd){	params = (struct tag *) bd->bi_boot_params;	params->hdr.tag = ATAG_CORE;	params->hdr.size = tag_size (tag_core);	params->u.core.flags = 0;	params->u.core.pagesize = 0;	params->u.core.rootdev = 0;	params = tag_next (params);}#ifdef CONFIG_SETUP_MEMORY_TAGSstatic void setup_memory_tags (bd_t *bd){	int i;	for (i = 0; i < CONFIG_NR_DRAM_BANKS; i++) {		params->hdr.tag = ATAG_MEM;		params->hdr.size = tag_size (tag_mem32);		params->u.mem.start = bd->bi_dram[i].start;		params->u.mem.size = bd->bi_dram[i].size;		params = tag_next (params);	}}#endif /* CONFIG_SETUP_MEMORY_TAGS */static void setup_commandline_tag (bd_t *bd, char *commandline){	char *p;	if (!commandline)		return;	/* eat leading white space */	for (p = commandline; *p == ' '; p++);	/* skip non-existent command lines so the kernel will still	 * use its default command line.	 */	if (*p == '\0')		return;	params->hdr.tag = ATAG_CMDLINE;	params->hdr.size =		(sizeof (struct tag_header) + strlen (p) + 1 + 4) >> 2;	strcpy (params->u.cmdline.cmdline, p);	params = tag_next (params);}#ifdef CONFIG_INITRD_TAGstatic void setup_initrd_tag (bd_t *bd, ulong initrd_start, ulong initrd_end){	/* an ATAG_INITRD node tells the kernel where the compressed	 * ramdisk can be found. ATAG_RDIMG is a better name, actually.	 */	params->hdr.tag = ATAG_INITRD2;	params->hdr.size = tag_size (tag_initrd);	params->u.initrd.start = initrd_start;	params->u.initrd.size = initrd_end - initrd_start;	params = tag_next (params);}#endif /* CONFIG_INITRD_TAG */#if defined (CONFIG_VFD)static void setup_videolfb_tag (gd_t *gd){	/* An ATAG_VIDEOLFB node tells the kernel where and how large	 * the framebuffer for video was allocated (among other things).	 * Note that a _physical_ address is passed !	 *	 * We only use it to pass the address and size, the other entries	 * in the tag_videolfb are not of interest.	 */	params->hdr.tag = ATAG_VIDEOLFB;	params->hdr.size = tag_size (tag_videolfb);	params->u.videolfb.lfb_base = (u32) gd->fb_base;	/* 7168 = 256*4*56/8 - actually 2 pages (8192 bytes) are allocated */	params->u.videolfb.lfb_size = 7168;	params = tag_next (params);}#endifstatic void setup_end_tag (bd_t *bd){	params->hdr.tag = ATAG_NONE;	params->hdr.size = 0;}#endif /* CONFIG_SETUP_MEMORY_TAGS || CONFIG_CMDLINE_TAG || CONFIG_INITRD_TAG */

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
欧美午夜寂寞影院| 国产丝袜欧美中文另类| 精品88久久久久88久久久| 国产精品久久99| 麻豆精品新av中文字幕| av不卡免费在线观看| 日韩免费一区二区| 亚洲午夜免费福利视频| 成人av手机在线观看| 精品国产一二三| 午夜影视日本亚洲欧洲精品| 成人理论电影网| 久久综合久久久久88| 亚洲成人激情综合网| 色婷婷综合激情| 亚洲品质自拍视频网站| 国产精品一区免费在线观看| 日韩精品最新网址| 日本欧美在线观看| 精品污污网站免费看| 一区二区三区免费网站| 99久久综合99久久综合网站| 国产欧美一区二区精品仙草咪| 国产成人小视频| 久久精品夜色噜噜亚洲aⅴ| 久久精品久久综合| 欧美一级日韩免费不卡| 日韩高清电影一区| 欧美精品丝袜久久久中文字幕| 亚洲午夜精品一区二区三区他趣| 色香蕉成人二区免费| 亚洲日本一区二区| 91免费版在线看| 一区二区成人在线视频| 日本久久电影网| 亚洲黄一区二区三区| 在线视频中文字幕一区二区| 夜夜精品视频一区二区| 欧美性感一区二区三区| 亚洲va中文字幕| 欧美一区二区三区在线观看视频| 首页国产欧美日韩丝袜| 日韩亚洲欧美成人一区| 国内精品在线播放| 精品国产sm最大网站| 国产乱理伦片在线观看夜一区| 久久久久国产免费免费| 成人高清伦理免费影院在线观看| 一区视频在线播放| 欧美综合一区二区三区| 日韩中文字幕91| 久久久久亚洲蜜桃| av一区二区不卡| 亚洲一区二区在线视频| 欧美一个色资源| 国产麻豆9l精品三级站| 亚洲欧美日韩久久精品| 欧美精品99久久久**| 国产一区二区三区不卡在线观看 | 亚洲成在线观看| 欧美乱妇23p| 国产一区在线看| 亚洲欧美日韩国产中文在线| 欧美狂野另类xxxxoooo| 国产一区二区三区电影在线观看| 亚洲日本成人在线观看| 欧美日韩激情一区二区三区| 国产真实乱子伦精品视频| 亚洲视频一区在线| 在线不卡欧美精品一区二区三区| 紧缚捆绑精品一区二区| 一区二区三区日韩欧美精品| 日韩一区二区视频| 99精品欧美一区二区三区小说 | 韩国女主播成人在线| 亚洲欧洲综合另类| 日韩精品专区在线影院重磅| 成人性生交大合| 麻豆成人av在线| 一区二区三区日韩精品视频| 欧美v日韩v国产v| 欧美日韩一级二级三级| 成人av免费在线| 久久精品国产一区二区| 亚洲一区二区三区四区不卡| 国产欧美日韩精品a在线观看| 69堂国产成人免费视频| 91欧美一区二区| 国内欧美视频一区二区 | 国产在线一区观看| 亚洲123区在线观看| 亚洲欧美自拍偷拍色图| www国产成人| 91精品国产综合久久精品图片| www.欧美亚洲| 懂色av一区二区三区蜜臀| 久久99久久久久久久久久久| 亚洲大型综合色站| 一区二区三区在线视频播放| 国产精品久久久久四虎| 久久婷婷国产综合精品青草| 宅男在线国产精品| 欧美性大战久久久| 在线免费观看不卡av| 波多野结衣中文字幕一区| 国产精品亚洲专一区二区三区 | 成人性生交大片免费看视频在线 | 国产老妇另类xxxxx| 六月丁香婷婷色狠狠久久| 日韩电影一区二区三区四区| 亚洲综合成人网| 亚洲尤物视频在线| 夜夜爽夜夜爽精品视频| 亚洲在线免费播放| 一区二区三区在线高清| 一区二区三区免费观看| 亚洲国产精品久久久久秋霞影院| 亚洲一区二区美女| 亚洲尤物在线视频观看| 午夜欧美在线一二页| 亚洲成av人片在www色猫咪| 偷拍日韩校园综合在线| 蜜桃视频在线一区| 五月婷婷久久综合| 午夜精品福利一区二区三区av| 午夜国产不卡在线观看视频| 日韩激情av在线| 精品综合免费视频观看| 高清免费成人av| 91网站在线播放| 欧美无砖砖区免费| 欧美成人伊人久久综合网| 久久久久久久久伊人| 国产精品久久久久桃色tv| 一区二区三区加勒比av| 日韩vs国产vs欧美| 精品无人码麻豆乱码1区2区| 成人丝袜高跟foot| 欧美午夜一区二区三区| 日韩一区二区免费高清| 国产午夜亚洲精品理论片色戒| 国产精品传媒视频| 亚洲一级二级三级| 日本v片在线高清不卡在线观看| 久久精品99国产精品| 99久久国产免费看| 欧美日韩国产美女| 国产欧美一区二区精品性色超碰| 一区二区不卡在线播放| 麻豆精品一区二区av白丝在线| 成人福利在线看| 欧美一级理论片| 亚洲欧美在线另类| 日本美女一区二区三区视频| 成人免费毛片高清视频| 欧美精品日韩综合在线| 欧美激情综合在线| 日本不卡不码高清免费观看| 91在线视频官网| 精品国产伦理网| 亚洲自拍另类综合| 国产另类ts人妖一区二区| 欧美日韩精品一区二区天天拍小说 | 久久国产精品露脸对白| 色哟哟在线观看一区二区三区| 精品久久久久久综合日本欧美| 亚洲美女在线国产| 国产很黄免费观看久久| 欧美丰满美乳xxx高潮www| 国产精品国产成人国产三级| 美女视频网站久久| 欧美三日本三级三级在线播放| 亚洲国产高清不卡| 免费在线观看一区| 欧美日韩在线精品一区二区三区激情| 亚洲精品一区二区三区在线观看| 亚洲一区精品在线| 91免费国产在线| 亚洲国产激情av| 国产精品一区二区三区乱码| 欧美色综合网站| 有码一区二区三区| 97久久人人超碰| 中文字幕第一页久久| 国产成人精品综合在线观看 | 欧美午夜电影网| 亚洲免费观看高清完整版在线观看熊 | 日韩黄色免费网站| 在线影院国内精品| 亚洲天堂免费在线观看视频| 国产69精品久久久久777| 亚洲精品一区二区三区99| 麻豆精品精品国产自在97香蕉| 欧美军同video69gay| 亚洲福利视频三区| 欧美日韩精品欧美日韩精品| 舔着乳尖日韩一区| 7777精品伊人久久久大香线蕉| 天堂蜜桃一区二区三区| 337p亚洲精品色噜噜|