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

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

?? boot.s

?? 最新的grub2源代碼
?? S
字號:
/* -*-Asm-*- *//* *  GRUB  --  GRand Unified Bootloader *  Copyright (C) 1999,2000,2001,2002,2005   Free Software Foundation, Inc. * *  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., 675 Mass Ave, Cambridge, MA 02139, USA. */#include <grub/boot.h>#include <grub/machine/boot.h>	/* *  defines for the code go here */	/* Absolute addresses	   This makes the assembler generate the address without support	   from the linker. (ELF can't relocate 16-bit addresses!) */#define ABS(x) (x-_start+0x7c00)	/* Print message string */#define MSG(x)	movw $ABS(x), %si; call message	/* XXX:	binutils-2.9.1.0.x doesn't produce a short opcode for this. */#define	MOV_MEM_TO_AL(x)	.byte 0xa0;  .word x		.file	"boot.S"	.text	/* Tell GAS to generate 16-bit instructions so that this code works	   in real mode. */	.code16.globl _start; _start:	/*	 * _start is loaded at 0x7c00 and is jumped to with CS:IP 0:0x7c00	 */	/*	 * Beginning of the sector is compatible with the FAT/HPFS BIOS	 * parameter block.	 */	jmp	after_BPB	nop	/* do I care about this ??? */	/*	 * This space is for the BIOS parameter block!!!!  Don't change	 * the first jump, nor start the code anywhere but right after	 * this area.	 */	. = _start + 4	/* scratch space */mode:	.byte	0disk_address_packet:	sectors:	.long	0heads:	.long	0cylinders:	.word	0sector_start:	.byte	0head_start:	.byte	0cylinder_start:	.word	0	/* more space... */	. = _start + GRUB_BOOT_MACHINE_BPB_END	/*	 * End of BIOS parameter block.	 */boot_version:		.byte	GRUB_BOOT_VERSION_MAJOR, GRUB_BOOT_VERSION_MINORboot_drive:		.byte 0xff	/* the disk to load kernel from */			/* 0xff means use the boot drive */force_lba:	.byte	0kernel_address:	.word	GRUB_BOOT_MACHINE_KERNEL_ADDRkernel_sector:	.long	1kernel_segment:	.word	GRUB_BOOT_MACHINE_KERNEL_SEGafter_BPB:/* general setup */	cli		/* we're not safe here! */        /*         * This is a workaround for buggy BIOSes which don't pass boot         * drive correctly. If GRUB is installed into a HDD, check if         * DL is masked correctly. If not, assume that the BIOS passed         * a bogus value and set DL to 0x80, since this is the only         * possible boot drive. If GRUB is installed into a floppy,         * this does nothing (only jump).         */boot_drive_check:        jmp     1f        testb   $0x80, %dl        jnz     1f        movb    $0x80, %dl1:		/*	 * ljmp to the next instruction because some bogus BIOSes	 * jump to 07C0:0000 instead of 0000:7C00.	 */	ljmp	$0, $ABS(real_start)real_start:		/* set up %ds and %ss as offset from 0 */	xorw	%ax, %ax	movw	%ax, %ds	movw	%ax, %ss	/* set up the REAL stack */	movw	$GRUB_BOOT_MACHINE_STACK_SEG, %sp	sti		/* we're safe again */	/*	 *  Check if we have a forced disk reference here	 */	MOV_MEM_TO_AL(ABS(boot_drive))	/* movb	ABS(boot_drive), %al */	cmpb	$0xff, %al	je	1f	movb	%al, %dl1:	/* save drive reference first thing! */	pushw	%dx	/* print a notification message on the screen */	MSG(notification_string)	/* do not probe LBA if the drive is a floppy */	testb	$GRUB_BOOT_MACHINE_BIOS_HD_FLAG, %dl	jz	chs_mode				/* check if LBA is supported */	movb	$0x41, %ah	movw	$0x55aa, %bx	int	$0x13	/* 	 *  %dl may have been clobbered by INT 13, AH=41H.	 *  This happens, for example, with AST BIOS 1.04.	 */	popw	%dx	pushw	%dx	/* use CHS if fails */	jc	chs_mode	cmpw	$0xaa55, %bx	jne	chs_mode	/* check if AH=0x42 is supported if FORCE_LBA is zero */	MOV_MEM_TO_AL(ABS(force_lba))	/* movb	ABS(force_lba), %al */	testb	%al, %al	jnz	lba_mode	andw	$1, %cx	jz	chs_mode	lba_mode:	/* set %si to the disk address packet */	movw	$ABS(disk_address_packet), %si	/* set the mode to non-zero */	movb	$1, -1(%si)		movl	ABS(kernel_sector), %ebx	/* the size and the reserved byte */	movw	$0x0010, (%si)	/* the blocks */	movw	$1, 2(%si)		/* the absolute address (low 32 bits) */	movl	%ebx, 8(%si)	/* the segment of buffer address */	movw	$GRUB_BOOT_MACHINE_BUFFER_SEG, 6(%si)	xorl	%eax, %eax	movw	%ax, 4(%si)	movl	%eax, 12(%si)	/* * BIOS call "INT 0x13 Function 0x42" to read sectors from disk into memory *	Call with	%ah = 0x42 *			%dl = drive number *			%ds:%si = segment:offset of disk address packet *	Return: *			%al = 0x0 on success; err code on failure */	movb	$0x42, %ah	int	$0x13	/* LBA read is not supported, so fallback to CHS.  */	jc	chs_mode	movw	$GRUB_BOOT_MACHINE_BUFFER_SEG, %bx	jmp	copy_buffer		chs_mode:		/*	 *  Determine the hard disk geometry from the BIOS!	 *  We do this first, so that LS-120 IDE floppies work correctly.	 */	movb	$8, %ah	int	$0x13	jnc	final_init	/*	 *  The call failed, so maybe use the floppy probe instead.	 */	testb	$GRUB_BOOT_MACHINE_BIOS_HD_FLAG, %dl	jz	floppy_probe	/* Nope, we definitely have a hard disk, and we're screwed. */	jmp	hd_probe_errorfinal_init:		movw	$ABS(sectors), %si	/* set the mode to zero */	movb	$0, -1(%si)		/* save number of heads */	xorl	%eax, %eax	movb	%dh, %al	incw	%ax	movl	%eax, 4(%si)	xorw	%dx, %dx	movb	%cl, %dl	shlw	$2, %dx	movb	%ch, %al	movb	%dh, %ah	/* save number of cylinders */	incw	%ax	movw	%ax, 8(%si)	xorw	%ax, %ax	movb	%dl, %al	shrb	$2, %al	/* save number of sectors */	movl	%eax, (%si)setup_sectors:	/* load logical sector start (bottom half) */	movl	ABS(kernel_sector), %eax	/* zero %edx */	xorl	%edx, %edx	/* divide by number of sectors */	divl	(%si)	/* save sector start */	movb	%dl, 10(%si)	xorl	%edx, %edx	/* zero %edx */	divl	4(%si)		/* divide by number of heads */	/* save head start */	movb	%dl, 11(%si)	/* save cylinder start */	movw	%ax, 12(%si)	/* do we need too many cylinders? */	cmpw	8(%si), %ax	jge	geometry_error/* *  This is the loop for taking care of BIOS geometry translation (ugh!) */	/* get high bits of cylinder */	movb	13(%si), %dl	shlb	$6, %dl		/* shift left by 6 bits */	movb	10(%si), %cl	/* get sector */	incb	%cl		/* normalize sector (sectors go					from 1-N, not 0-(N-1) ) */	orb	%dl, %cl	/* composite together */	movb	12(%si), %ch	/* sector+hcyl in cl, cylinder in ch */	/* restore %dx */	popw	%dx		/* head number */	movb	11(%si), %dh/* * BIOS call "INT 0x13 Function 0x2" to read sectors from disk into memory *	Call with	%ah = 0x2 *			%al = number of sectors *			%ch = cylinder *			%cl = sector (bits 6-7 are high bits of "cylinder") *			%dh = head *			%dl = drive (0x80 for hard disk, 0x0 for floppy disk) *			%es:%bx = segment:offset of buffer *	Return: *			%al = 0x0 on success; err code on failure */	movw	$GRUB_BOOT_MACHINE_BUFFER_SEG, %bx	movw	%bx, %es	/* load %es segment with disk buffer */	xorw	%bx, %bx	/* %bx = 0, put it at 0 in the segment */	movw	$0x0201, %ax	/* function 2 */	int	$0x13	jc	read_error	movw	%es, %bx	copy_buffer:	movw	ABS(kernel_segment), %es	/*	 * We need to save %cx and %si because the startup code in	 * kernel uses them without initializing them.	 */	pusha	pushw	%ds		movw	$0x100, %cx	movw	%bx, %ds	xorw	%si, %si	xorw	%di, %di		cld		rep	movsw	popw	%ds	popa	/* boot kernel */	jmp	*(kernel_address)/* END OF MAIN LOOP *//* * BIOS Geometry translation error (past the end of the disk geometry!). */geometry_error:	MSG(geometry_error_string)	jmp	general_error/* * Disk probe failure. */hd_probe_error:	MSG(hd_probe_error_string)	jmp	general_error/* * Read error on the disk. */read_error:	MSG(read_error_string)general_error:	MSG(general_error_string)/* go here when you need to stop the machine hard after an error condition */        /* tell the BIOS a boot failure, which may result in no effect */        int	$0x18stop:	jmp	stopnotification_string:	.string "GRUB "geometry_error_string:	.string "Geom"hd_probe_error_string:	.string "Hard Disk"read_error_string:	.string "Read"general_error_string:	.string " Error"/* * message: write the string pointed to by %si * *   WARNING: trashes %si, %ax, and %bx */	/*	 * Use BIOS "int 10H Function 0Eh" to write character in teletype mode	 *	%ah = 0xe	%al = character	 *	%bh = page	%bl = foreground color (graphics modes)	 */1:	movw	$0x0001, %bx	movb	$0xe, %ah	int	$0x10		/* display a byte */message:	lodsb	cmpb	$0, %al	jne	1b	/* if not end of string, jmp to display */	ret	/*	 *  Windows NT breaks compatibility by embedding a magic	 *  number here.	 */	. = _start + GRUB_BOOT_MACHINE_WINDOWS_NT_MAGICnt_magic:		.long 0	.word 0	/*	 *  This is where an MBR would go if on a hard disk.  The code	 *  here isn't even referenced unless we're on a floppy.  Kinda	 *  sneaky, huh?	 */part_start:		. = _start + GRUB_BOOT_MACHINE_PART_STARTprobe_values:	.byte	36, 18, 15, 9, 0floppy_probe:/* *  Perform floppy probe. */	movw	$ABS(probe_values-1), %siprobe_loop:	/* reset floppy controller INT 13h AH=0 */	xorw	%ax, %ax	int	$0x13	incw	%si	movb	(%si), %cl	/* if number of sectors is 0, display error and die */	cmpb	$0, %cl	jne	1f/* * Floppy disk probe failure. */	MSG(fd_probe_error_string)	jmp	general_errorfd_probe_error_string:	.string "Floppy"1:	/* perform read */	movw	$GRUB_BOOT_MACHINE_BUFFER_SEG, %bx	movw	$0x201, %ax	movb	$0, %ch	movb	$0, %dh	int	$0x13	/* if error, jump to "probe_loop" */	jc	probe_loop	/* %cl is already the correct value! */	movb	$1, %dh	movb	$79, %ch	jmp	final_init	. = _start + GRUB_BOOT_MACHINE_PART_END/* the last 2 bytes in the sector 0 contain the signature */	.word	GRUB_BOOT_MACHINE_SIGNATURE

?? 快捷鍵說明

復制代碼 Ctrl + C
搜索代碼 Ctrl + F
全屏模式 F11
切換主題 Ctrl + Shift + D
顯示快捷鍵 ?
增大字號 Ctrl + =
減小字號 Ctrl + -
亚洲欧美第一页_禁久久精品乱码_粉嫩av一区二区三区免费野_久草精品视频
亚洲色图一区二区| 欧美在线一区二区| 伊人夜夜躁av伊人久久| 中文字幕不卡三区| 欧美亚洲综合在线| 岛国精品在线播放| 久久精品免费观看| 亚洲永久免费av| 久久久www成人免费毛片麻豆| 91黄色免费观看| 成人国产精品免费观看| 美女网站在线免费欧美精品| 亚洲一区二区三区美女| 中文字幕一区不卡| 国产日韩影视精品| 日韩欧美黄色影院| 欧美日韩国产片| 91在线丨porny丨国产| 国产一区二区免费在线| 美女脱光内衣内裤视频久久网站 | 精品久久国产老人久久综合| 在线观看成人小视频| aaa欧美日韩| 国产白丝网站精品污在线入口| 免费精品视频在线| 婷婷综合五月天| 亚洲高清免费观看| 夜夜揉揉日日人人青青一国产精品 | 欧美高清dvd| 色八戒一区二区三区| 99久久久免费精品国产一区二区| 黑人精品欧美一区二区蜜桃| 美腿丝袜在线亚洲一区| 日本欧洲一区二区| 天堂久久一区二区三区| 亚洲综合成人在线视频| 一级特黄大欧美久久久| 亚洲精品成人精品456| 一区二区三区丝袜| 亚洲精品va在线观看| 一区二区三区精品在线| 洋洋成人永久网站入口| 亚洲综合成人在线视频| 亚洲福利一二三区| 免费观看在线综合| 精彩视频一区二区| 国产精品1024| www.亚洲在线| 在线观看国产91| 欧美精品丝袜中出| 精品日韩在线观看| 国产三级精品在线| 最新热久久免费视频| 一区二区三区四区乱视频| 亚洲综合区在线| 日本三级韩国三级欧美三级| 久久国产精品免费| 国产**成人网毛片九色 | 久久精子c满五个校花| 中文一区在线播放| 一区二区三区美女视频| 日韩国产高清影视| 国产精品91一区二区| www.激情成人| 7777女厕盗摄久久久| ww久久中文字幕| 1区2区3区国产精品| 亚洲成人www| 国产老女人精品毛片久久| 成人精品免费网站| 欧美日韩精品免费观看视频| 欧美成人官网二区| 亚洲天堂网中文字| 日韩不卡一区二区| 成人午夜视频在线| 欧美精品乱码久久久久久按摩| 欧美电影免费观看高清完整版| 国产欧美日韩在线| 亚洲国产一区二区在线播放| 久久99精品一区二区三区| www.成人网.com| 欧美一级一级性生活免费录像| 亚洲国产精品高清| 丝瓜av网站精品一区二区| 国产成人综合网| 欧美私模裸体表演在线观看| 久久婷婷国产综合国色天香| 亚洲美女偷拍久久| 国模娜娜一区二区三区| 欧美性一二三区| 日本一区二区三区dvd视频在线| 亚洲国产精品一区二区久久| 国产成人在线看| 亚洲男人电影天堂| 另类小说一区二区三区| 91激情五月电影| 国产亚洲精品资源在线26u| 亚洲成人777| www..com久久爱| 26uuu亚洲婷婷狠狠天堂| 亚洲国产三级在线| av一区二区三区黑人| 精品国产乱码久久久久久老虎| 一个色综合av| a亚洲天堂av| 国产婷婷精品av在线| 秋霞国产午夜精品免费视频| 色婷婷av久久久久久久| 欧美极品美女视频| 九一九一国产精品| 7777精品伊人久久久大香线蕉完整版| 国产精品久久久久久久蜜臀| 狠狠色丁香久久婷婷综合丁香| 欧美日韩精品免费| 亚洲激情综合网| av在线不卡网| 中文字幕欧美激情| 国产一区在线不卡| 精品久久久久香蕉网| 麻豆精品在线播放| 91麻豆精品国产91| 天天亚洲美女在线视频| 欧洲av一区二区嗯嗯嗯啊| 亚洲色图在线播放| 99久久99久久免费精品蜜臀| 欧美国产禁国产网站cc| 国产精品99久久久久久有的能看| 精品黑人一区二区三区久久| 免费成人在线网站| 日韩一区二区不卡| 毛片av一区二区三区| 日韩精品影音先锋| 久久不见久久见免费视频1| 日韩一区二区三区观看| 青草av.久久免费一区| 日韩你懂的电影在线观看| 久久99精品一区二区三区三区| 日韩免费看的电影| 国产中文字幕一区| 久久精品水蜜桃av综合天堂| 国产激情视频一区二区三区欧美| 久久精品免费在线观看| 国产91综合一区在线观看| 国产精品青草久久| 色综合久久久久综合体桃花网| 亚洲人成精品久久久久久| 在线观看一区日韩| 亚洲18女电影在线观看| 在线不卡欧美精品一区二区三区| 日本特黄久久久高潮| 精品国产免费久久| 成人手机在线视频| 国产精品不卡一区二区三区| 日本韩国一区二区| 日韩制服丝袜av| 久久蜜臀中文字幕| 99久久免费精品高清特色大片| 一区二区三区波多野结衣在线观看| 欧美日韩一级片在线观看| 麻豆成人91精品二区三区| 日本一区二区三区高清不卡| 色综合天天综合网天天看片| 五月婷婷色综合| 久久综合网色—综合色88| 成人99免费视频| 午夜精品123| 久久久综合网站| 色婷婷av一区二区三区大白胸| 日韩电影免费在线观看网站| 久久久久九九视频| 日本久久一区二区| 免费在线观看不卡| 国产精品女同互慰在线看| 欧美日韩一区二区三区四区五区| 韩日欧美一区二区三区| 亚洲精品国产精华液| 欧美变态凌虐bdsm| 色国产综合视频| 久久精品72免费观看| **网站欧美大片在线观看| 欧美一区二区久久久| 99在线精品一区二区三区| 视频一区二区三区在线| 日本强好片久久久久久aaa| 国产午夜精品一区二区三区嫩草 | 在线亚洲高清视频| 精品一区二区免费视频| 一区二区三区精密机械公司| 精品黑人一区二区三区久久| 在线一区二区三区| 国产剧情一区二区三区| 亚洲成人动漫一区| 1000精品久久久久久久久| 日韩女优视频免费观看| 色呦呦网站一区| 国产福利91精品| 免费的成人av| 亚洲成人自拍网| ●精品国产综合乱码久久久久 | 欧美一三区三区四区免费在线看 |