下面主要研究ReactOS 系统的引导过程;我们只研究文件系统为FAT32的引导过程; 1:开机,打开PC电源; 2:x86结构的CPU会自动进入实模式,并从地址0XFFFF0开始自动执行,这个地址通常是BIOS自检程序; 3:BIOS自检后,在物理地址0处开始初始化中断向量。 4:读硬盘第一个扇区0头0道1扇区(引导扇区)到0000:7c00处 5:检测引导扇区结尾是否等于0xaa55 6:开始执行引导扇区,此时操作系统的第一个代码开始执行; 引导扇区 >首先调用int 13h计算机硬盘扇区数,并保存到BiosCHSDriveSize中 > ... /* Load the GDT */ lgdt gdtptr ;装载描述符 /* Load the IDT */ lidt i386idtptr ;装载中断 /* Enable Protected Mode */ mov %cr0,%eax orl $CR0_PE_SET,%eax ;设置cr0 保护模式位 mov %eax,%cr0 freeldr 加载windows2003内核: LoadAndBootWindows() { /*初始化LPB*/ AllocateAndInitLPB(&LoaderBlock); ... /*检测硬件 检测结构赋于LPB*/ ... /*装载内核SYSTEM32//NTOSKRNL.EXE*/ WinLdrLoadImage(); /*装载HAL*/ WinLdrLoadImage(); /*扫描导入表*/ ... /*装载注册表,NLS,OEM,驱动列表*/ WinLdrLoadAndScanSystemHive(); } 总结freeldr.sys的工作: 1, 数据初始化 2, 加载GDT 3, 加载LDT 4, 修改CR0的PE位进入保护模式 5, 跳转到保护模式下 6, 保存全局变量 7, 调用_BootMain调用FreeLdr 8, 修改CR0的PE位进入实模式 9, 加载实模式的LDT 10, 重新启动.
ReactOS 系统引导原理
最新推荐文章于 2019-06-29 19:09:05 发布