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

? 歡迎來(lái)到蟲(chóng)蟲(chóng)下載站! | ?? 資源下載 ?? 資源專(zhuān)輯 ?? 關(guān)于我們
? 蟲(chóng)蟲(chóng)下載站

?? bootloader.c

?? Linux內(nèi)核源代碼 為壓縮文件 是<<Linux內(nèi)核>>一書(shū)中的源代碼
?? C
字號(hào):
/* * arch/ia64/boot/bootloader.c * * Loads an ELF kernel. * * Copyright (C) 1998, 1999 Hewlett-Packard Co * Copyright (C) 1998, 1999 David Mosberger-Tang <davidm@hpl.hp.com> * Copyright (C) 1998, 1999 Stephane Eranian <eranian@hpl.hp.com> * * 01/07/99 S.Eranian modified to pass command line arguments to kernel */#include <linux/config.h>#include <linux/elf.h>#include <linux/init.h>#include <linux/kernel.h>#include <asm/elf.h>#include <asm/pal.h>#include <asm/pgtable.h>#include <asm/sal.h>#include <asm/system.h>/* Simulator system calls: */#define SSC_CONSOLE_INIT		20#define SSC_GETCHAR			21#define SSC_PUTCHAR			31#define SSC_OPEN			50#define SSC_CLOSE			51#define SSC_READ			52#define SSC_WRITE			53#define SSC_GET_COMPLETION		54#define SSC_WAIT_COMPLETION		55#define SSC_CONNECT_INTERRUPT		58#define SSC_GENERATE_INTERRUPT		59#define SSC_SET_PERIODIC_INTERRUPT	60#define SSC_GET_RTC			65#define SSC_EXIT			66#define SSC_LOAD_SYMBOLS		69#define SSC_GET_TOD			74#define SSC_GET_ARGS			75struct disk_req {	unsigned long addr;	unsigned len;};struct disk_stat {	int fd;	unsigned count;};#include "../kernel/fw-emu.c"static voidcons_write (const char *buf){	unsigned long ch;	while ((ch = *buf++) != '\0') {		ssc(ch, 0, 0, 0, SSC_PUTCHAR);		if (ch == '\n')		  ssc('\r', 0, 0, 0, SSC_PUTCHAR);	}}voidenter_virtual_mode (unsigned long new_psr){	long tmp;	asm volatile ("movl %0=1f" : "=r"(tmp));	asm volatile ("mov cr.ipsr=%0" :: "r"(new_psr));	asm volatile ("mov cr.iip=%0" :: "r"(tmp));	asm volatile ("mov cr.ifs=r0");	asm volatile ("rfi;;");	asm volatile ("1:");}#define MAX_ARGS 32void_start (void){	register long sp asm ("sp");	static char stack[16384] __attribute__ ((aligned (16)));	static char mem[4096];	static char buffer[1024];	unsigned long flags, off;	int fd, i;	struct disk_req req;	struct disk_stat stat;	struct elfhdr *elf;	struct elf_phdr *elf_phdr;	/* program header */	unsigned long e_entry, e_phoff, e_phnum;	char *kpath, *args;	long arglen = 0;	asm volatile ("movl gp=__gp;;" ::: "memory");	asm volatile ("mov sp=%0" :: "r"(stack) : "memory");	asm volatile ("bsw.1;;");#ifdef CONFIG_ITANIUM_ASTEP_SPECIFIC	asm volative ("nop 0;; nop 0;; nop 0;;");#endif /* CONFIG_ITANIUM_ASTEP_SPECIFIC */	ssc(0, 0, 0, 0, SSC_CONSOLE_INIT);	/*	 * S.Eranian: extract the commandline argument from the 	 * simulator	 *	 * The expected format is as follows:         *	 *	kernelname args...	 *	 * Both are optional but you can't have the second one without the 	 * first.	 */	arglen = ssc((long) buffer, 0, 0, 0, SSC_GET_ARGS);	kpath = "vmlinux";	args = buffer;	if (arglen > 0) {		kpath = buffer;		while (*args != ' ' && *args != '\0')			++args, --arglen;		if (*args == ' ')			*args++ = '\0', --arglen;	}	if (arglen <= 0) {		args = "";		arglen = 1;	}	fd = ssc((long) kpath, 1, 0, 0, SSC_OPEN);	if (fd < 0) {		cons_write(kpath);		cons_write(": file not found, reboot now\n");		for(;;);	}	stat.fd = fd;	off = 0;	req.len = sizeof(mem);	req.addr = (long) mem;	ssc(fd, 1, (long) &req, off, SSC_READ);	ssc((long) &stat, 0, 0, 0, SSC_WAIT_COMPLETION);	elf = (struct elfhdr *) mem;	if (elf->e_ident[0] == 0x7f && strncmp(elf->e_ident + 1, "ELF", 3) != 0) {		cons_write("not an ELF file\n");		return;	}	if (elf->e_type != ET_EXEC) {		cons_write("not an ELF executable\n");		return;	}	if (!elf_check_arch(elf)) {		cons_write("kernel not for this processor\n");		return;	}	e_entry = elf->e_entry;	e_phnum = elf->e_phnum;	e_phoff = elf->e_phoff;	cons_write("loading ");	cons_write(kpath);	cons_write("...\n");	for (i = 0; i < e_phnum; ++i) {		req.len = sizeof(*elf_phdr);		req.addr = (long) mem;		ssc(fd, 1, (long) &req, e_phoff, SSC_READ);		ssc((long) &stat, 0, 0, 0, SSC_WAIT_COMPLETION);		if (stat.count != sizeof(*elf_phdr)) {			cons_write("failed to read phdr\n");			return;		}		e_phoff += sizeof(*elf_phdr);		elf_phdr = (struct elf_phdr *) mem;		req.len = elf_phdr->p_filesz;		req.addr = __pa(elf_phdr->p_vaddr);		ssc(fd, 1, (long) &req, elf_phdr->p_offset, SSC_READ);		ssc((long) &stat, 0, 0, 0, SSC_WAIT_COMPLETION);		memset((char *)__pa(elf_phdr->p_vaddr) + elf_phdr->p_filesz, 0,		       elf_phdr->p_memsz - elf_phdr->p_filesz);	}	ssc(fd, 0, 0, 0, SSC_CLOSE);	cons_write("starting kernel...\n");	/* fake an I/O base address: */	asm volatile ("mov ar.k0=%0" :: "r"(0xffffc000000UL));	/*	 * Install a translation register that identity maps the	 * kernel's 256MB page.	 */	ia64_clear_ic(flags);	ia64_set_rr(          0, (0x1000 << 8) | (_PAGE_SIZE_1M << 2));	ia64_set_rr(PAGE_OFFSET, (ia64_rid(0, PAGE_OFFSET) << 8) | (_PAGE_SIZE_256M << 2));	ia64_srlz_d();	ia64_itr(0x3, 0, 1024*1024,		 pte_val(mk_pte_phys(1024*1024, __pgprot(__DIRTY_BITS|_PAGE_PL_0|_PAGE_AR_RWX))),		 _PAGE_SIZE_1M);	ia64_itr(0x3, 1, PAGE_OFFSET,		 pte_val(mk_pte_phys(0, __pgprot(__DIRTY_BITS|_PAGE_PL_0|_PAGE_AR_RWX))),		 _PAGE_SIZE_256M);	ia64_srlz_i();	enter_virtual_mode(flags | IA64_PSR_IT | IA64_PSR_IC | IA64_PSR_DT | IA64_PSR_RT			   | IA64_PSR_DFH | IA64_PSR_BN);	sys_fw_init(args, arglen);	ssc(0, (long) kpath, 0, 0, SSC_LOAD_SYMBOLS);	/*	 * Install the kernel's command line argument on ZERO_PAGE	 * just after the botoparam structure.	 * In case we don't have any argument just put \0	 */	memcpy(((struct ia64_boot_param *)ZERO_PAGE_ADDR) + 1, args, arglen);	sp = __pa(&stack);	asm volatile ("br.sptk.few %0" :: "b"(e_entry));	cons_write("kernel returned!\n");	ssc(-1, 0, 0, 0, SSC_EXIT);}

?? 快捷鍵說(shuō)明

復(fù)制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號(hào) Ctrl + =
減小字號(hào) Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
国产精品久久久久久妇女6080 | 91小宝寻花一区二区三区| 亚洲制服丝袜av| 久久精品视频网| 欧美色视频在线观看| 国产高清亚洲一区| 青娱乐精品视频在线| 亚洲视频免费观看| 欧美国产一区视频在线观看| 欧美一区三区二区| 欧美日韩中文精品| 99精品国产99久久久久久白柏| 免费高清在线视频一区·| 亚洲精品国产品国语在线app| 久久久精品2019中文字幕之3| 91精品国产综合久久精品麻豆| 99久精品国产| 成人免费视频国产在线观看| 男女男精品视频| 午夜av一区二区| 亚洲精选一二三| 中文字幕一区在线观看| 国产午夜精品福利| 久久伊人中文字幕| 欧美成人一级视频| 欧美一区国产二区| 日韩一区二区三| 69堂成人精品免费视频| 欧美日韩成人在线| 欧美特级限制片免费在线观看| 97se亚洲国产综合自在线观| 99这里都是精品| 99久久综合色| 99国内精品久久| 99re这里只有精品首页| 99久久精品免费| 91亚洲国产成人精品一区二区三| 成人精品一区二区三区中文字幕 | 韩国精品一区二区| 美日韩黄色大片| 免费观看久久久4p| 麻豆成人在线观看| 国产一区二区久久| 成人av资源在线| 91亚洲国产成人精品一区二三 | 色综合久久中文综合久久97| 成人av资源在线| 色综合中文综合网| 亚洲综合在线视频| 一区二区日韩电影| 日欧美一区二区| 美女一区二区三区在线观看| 国产一区视频在线看| 国产一级精品在线| 91在线观看高清| 欧美性猛片xxxx免费看久爱| 宅男在线国产精品| 精品国产免费人成电影在线观看四季| 久久日韩精品一区二区五区| 国产日韩精品一区| 亚洲欧美另类综合偷拍| 亚洲一区二区三区在线看| 日韩国产一二三区| 国产乱人伦精品一区二区在线观看 | 日韩精品一区二区三区老鸭窝| 日韩欧美中文字幕公布| 国产人久久人人人人爽| 亚洲精品欧美综合四区| 日本aⅴ亚洲精品中文乱码| 国产高清在线观看免费不卡| 91猫先生在线| 欧美一级xxx| 国产精品嫩草影院com| 亚洲成人综合视频| 国产丶欧美丶日本不卡视频| 色伊人久久综合中文字幕| 欧美一区二区三区在线| 欧美国产一区在线| 日韩精品亚洲专区| 岛国一区二区在线观看| 欧美日本国产视频| 亚洲国产高清aⅴ视频| 亚洲午夜电影网| 国产.欧美.日韩| 欧美日韩免费电影| 日本一区二区三区国色天香| 污片在线观看一区二区| 国产激情精品久久久第一区二区| 欧美亚洲综合色| 亚洲国产精品成人综合| 日韩国产精品久久久久久亚洲| bt7086福利一区国产| 精品国产乱码久久| 午夜av电影一区| 91在线视频免费91| 久久久不卡影院| 日本不卡一区二区三区高清视频| 成人av网站免费| 欧美mv日韩mv亚洲| 亚瑟在线精品视频| 99久久精品国产导航| 久久亚洲一级片| 奇米精品一区二区三区在线观看 | 成人性生交大片免费看中文| 欧美一区二区三区精品| 亚洲制服丝袜一区| 91香蕉视频在线| 中文字幕乱码日本亚洲一区二区 | 亚洲欧洲av在线| 国精品**一区二区三区在线蜜桃| 欧美丝袜丝交足nylons图片| 成人欧美一区二区三区黑人麻豆| 久久er99精品| 欧美一区二区三区公司| 三级精品在线观看| 欧美午夜宅男影院| 亚洲精品国产精华液| 91在线观看下载| 亚洲三级在线看| 99久久久久久| 亚洲色图清纯唯美| av男人天堂一区| 国产精品美女久久久久久| 国产成人精品亚洲777人妖| 精品国产一区二区三区av性色| 日韩精品一区第一页| 7777精品伊人久久久大香线蕉 | 偷拍自拍另类欧美| 欧美日韩国产a| 日本欧美一区二区在线观看| 欧美一级搡bbbb搡bbbb| 麻豆精品一二三| 欧美大片免费久久精品三p| 日韩一区精品视频| 欧美zozo另类异族| 国产一区二区在线影院| 日本一区二区三区在线不卡| 不卡视频免费播放| 亚洲视频 欧洲视频| 欧亚一区二区三区| 亚洲第一电影网| 91精品国产综合久久香蕉的特点| 日本亚洲电影天堂| 精品国产一区二区三区av性色| 国产精品一二三在| 国产精品三级久久久久三级| 波多野结衣在线aⅴ中文字幕不卡 波多野结衣在线一区 | 在线视频亚洲一区| 一级女性全黄久久生活片免费| 欧美三级日韩三级国产三级| 五月开心婷婷久久| 精品免费国产一区二区三区四区| 精品午夜一区二区三区在线观看| 久久久精品免费免费| 日韩欧美一区二区在线视频| 热久久国产精品| 久久久精品免费网站| 成人av免费在线观看| 亚洲国产日日夜夜| 久久综合五月天婷婷伊人| 99久久精品情趣| 午夜精品久久久久久久99樱桃| 欧美成人乱码一区二区三区| 国产宾馆实践打屁股91| 亚洲激情成人在线| 在线综合亚洲欧美在线视频| 国产伦精品一区二区三区视频青涩 | 国产成人免费视频| 韩国精品主播一区二区在线观看 | 国产精品情趣视频| 欧洲av一区二区嗯嗯嗯啊| 免费xxxx性欧美18vr| 国产欧美日韩综合精品一区二区| 色综合久久88色综合天天 | 日本道色综合久久| 喷白浆一区二区| 专区另类欧美日韩| 日韩欧美一级精品久久| 99久久精品国产一区二区三区| 日韩av一级电影| 中文字幕亚洲一区二区av在线 | 国产拍欧美日韩视频二区| 91片在线免费观看| 久久疯狂做爰流白浆xx| 亚洲人精品午夜| 精品人在线二区三区| 色婷婷综合久色| 国产精品一区二区三区99| 午夜伦欧美伦电影理论片| 国产精品免费人成网站| 欧美一区二区三区日韩视频| 99精品久久久久久| 国产美女精品人人做人人爽| 亚洲成人三级小说| 亚洲三级免费观看| 久久久久久亚洲综合影院红桃| 欧美精品在线观看播放| 91视频.com| 成人动漫一区二区| 久久国产视频网|