当前位置: 代码迷 >> 汇编语言 >> bochs 中执行 mov eax, eax 就错误了
  详细解决方案

bochs 中执行 mov eax, eax 就错误了

热度:341   发布时间:2016-05-02 04:53:57.0
bochs 中执行 mov eax, eax 就异常了
一个神奇的问题:
我一个简单的裸机程序, 有 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 保护模式

------解决方案--------------------
不好意思刚才没看到。