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组合使用表:
EM   MP    说明
0    0  将数值指令传给FPU;WAIT忽略TS
0    1  将数值指令传给FPU;WAIT测试TS
1    0  数值计算指令自陷至仿真软件;WAIT忽略TS
1    0  数值计算指令自陷至仿真软件;WAIT测试TS

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

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值