orange's学习--第五章:f 移动栈和GDT

本文探讨了内核程序获取控制权时各寄存器的状态,详细解析了cs、ds、es、fs、ss及gs指向的内存地址,esp、GDT等在Loader中的位置,并计划将其移至内核区以便控制。文章还强调了C代码编程时需确保ds、es、ss段寄存器值一致的重要性。

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

我们需要了解在内核程序获得控制权之时各个寄存器的情况,在内核中我们需要这些信息。cs、ds、es、fs、ss表示的段统统指向内存地址0h,gs表示的段则指向显存,这是我们在进入保护模式之后设置的。同时,esp、GDT等内容也在Loader中,下面对内核进行扩充时,我们会将它们都挪到内核中,以便于控制。  后续loader所在的内存区域可以被覆盖掉,所以要挪到内核区域

    ; 注意! 在使用 C 代码的时候一定要保证 ds, es, ss 这几个段寄存器的值是一样的
    ; 因为编译器有可能编译出使用它们的代码, 而编译器默认它们是一样的. 比如串拷贝操作会用到 ds 和 es.

实现移动栈和GDT的代码:

StackTop是在kernel.asm定义的标号,编译出来的地址就是转换后偏移地址,可以直接使用。

start.c里面其实就是简单的指针操作,仔细理解一下即可。

 

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值