linux 启动 过程 学习 (x86_64)

本文详细介绍了Linux在x86_64架构下的启动流程,从_start开始,包括设置堆栈、BSS段,到console初始化、内存检测、键盘设置、视频模式调整,直到进入保护模式,启用A20、设置IDT和GDT,逐步过渡到64位模式。过程中涉及了PAE、分页机制和内核解压缩,最后执行解压后的内核代码。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

1.   arch/x86/boot/header.S , kernel setup 从 _start开始。 设置 stack, bss, 最后跳转到 arch/x86/boot/main.c。

2.  在main函数中,把kernel setup header 拷贝到 struct setup_header, 之后初console_init,  init_heap, validate_cpu, detect_memory(e820), keyboard_init, set_video, 最后go_to_protected_mode。

3. go_to_protected_mode 中打开A20, setup_idt, setup_gdt, 最终跳转到 arch/x86/boot/compressed/head_64.S 中的startup_32函数。

4. startup_32中检查是否需要重新加载segments, 之后计算编译地址和实际加载地址的偏移, 然后设置内核栈,检测是否支持long mode,再次计算偏移来确定解压缩的地址。如果支持long mode的话,设置64 bit的GDT,进入PAE模式。再设置最初的4G页表,最后打开分页并进入long mode。跳转到startup_64.

5. startup_64中,确定最终解压缩地址,然后拷贝压缩内核到该地址,清空BSS,跳转到decompress_kernel地址处,开始解压内核。

6. 3.12内核以后, 在解压内核之前会确定是否要随机话内核加载地址,如果是的话,计算一个可用的随机地址,之后把内核解压到该地址,然后跳转到解压后的内核处执行 arch/x86/kernel/head_64.S.



评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值