X86保护模式编程总结(3)

配置数值计算环境:
系统必需装入CR0中的MP,EM,NE位,来控制浮点指令的软件仿真,FPU和CPU环境之间的同步,以及浮点异常的软件或外部中断处理,这些位在CPU复位时被清0.
MP位(监控协处理器):一般对于有FPU的CPU,MP应=1,反正为0.用来确定FPU环境不同于当前执行任务环境时,WAIT指令是否自陷,当MP=1&&TS=1时,WAIT将产生设备不可用故障.
EM位(仿真协处理器):一般对于有FPU的CPU,EM=0. 决定了ESC指令是由FPU(EM=0)执行,还是通过中断向量7自陷,由软件来处理(EM=1).注意,如果EM=1且没有FPU仿真软件,系统将挂起.
NE位(数值计算异常):决定了非屏蔽浮点异常是通过中断向量16(NE=1),还是通过外部中断(NE=0)进行处理.

EM和MP组合使用表:
EMMP说明
00将数值指令传给FPU;WAIT忽略TS
01将数值指令传给FPU;WAIT测试TS
10数值计算指令自陷至仿真软件;WAIT忽略TS
10数值计算指令自陷至仿真软件;WAIT测试TS

EM,MP,TS不同组合所采取的动作:
EMTSMP浮点指令等待指令
000 执行 执行
001 执行 执行
010 异常7 执行
011 异常7 异常7
100 异常7 执行
101 异常7 执行
110 异常7 执行
111 异常7 异常7
注:仿真X387处理器的CR0设置:EM=1;MP=0,NE=1
将CR0中CD和NW位清0,可使高速缓冲能用

你可能感兴趣的:(编程,软件测试)