一个神奇的问题:
我一个简单的裸机程序, 有 mbr 和 kernel, 在 bochs 中执行 kernel 的时候, 进入保护模式, 并开启了页机制.
一切看起来很正常, 但是当我通过 TSS 进行任务切换的时候, 发生了问题, 描述如下:
1. 执行 call far 进行任务切换. 如图:
2. 我们单步进入, 如图:
3. 目前, 我们将要执行一个 mov eax, eax 的指令, 我认为这条指令应该顺利通过, 但是先让我们来看一下寄存器状态吧, 如图:
4. 问题这就来了, 如果我再次单步 s 后, 则会引发异常, 如图:
5. 再来看看 0xa000 处的页情况, 如图:
问题很是奇怪, 实在理解不能, 不知道为什么 s 会失败. 我的观点是:
1) DPL 在 TSS 任务切换的时候就检查过了, 所以不是 DPL 权限问题.
2) cs:eip 在代码段的界限内, 并具有执行权限, 因此不是段访问违规.
3) 分页开启了, 因此 page 0xa000 映射的物理地址就是 0xa000, 因此不是缺页问题.
实在无解, 请各位看看有没有我疏漏的地方, 造成了这个异常? 这个问题困扰我很久了, 会的请指教, 不会的请帮忙问问周围高手, 在下感激不尽.
内核 汇编 操作系统 bochs 保护模式
------解决方案--------------------
不好意思刚才没看到。