下面主要研究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,重新启动.