曲径通幽论坛

 找回密码
 立即注册
搜索
查看: 5734|回复: 0
打印 上一主题 下一主题

FPU 寄存器堆栈

[复制链接]

4917

主题

5879

帖子

3万

积分

GROAD

曲径通幽,安觅芳踪。

Rank: 6Rank: 6

积分
34382
跳转到指定楼层
楼主
发表于 2010-2-27 01:39:12 | 只看该作者 回帖奖励 |倒序浏览 |阅读模式
FPU 是个自持单元,并不属于标准处理器寄存器中的一部分并支持浮点操作。

FPU 寄存器包含 8 个 80 位数据寄存器和 3 个 16 位寄存器。这 3 个 16 为寄存器分别是 控制寄存器 (control register),状态寄存器 (status register) 和 标记寄存器 (tag register)。

数据寄存器
FPU 数据寄存器称为 R0 到 R7 (实际使用中并不直接使用这个名称)。这 8 个寄存器组成一个环形堆栈,也就是说堆栈中的最后一个寄存器连接回堆栈中的第一个寄存器。

堆栈顶部的寄存器是在 FPU 的控制字寄存器中定义的,名为 ST(0),其他寄存器依次为 ST(1)-ST(7)。

当数据被加载到 FPU 堆栈时,堆栈顶部沿着 8 个向下移动,当 8 个值被加载到寄存器堆栈中,这时堆栈满,如果再推入第 9 个值,那么堆栈指针回绕到第 1 个寄存器,并且使用新的值替换这个寄存器中的值,这会产生 FPU 异常错误。
您需要登录后才可以回帖 登录 | 立即注册

本版积分规则

小黑屋|手机版|Archiver|曲径通幽 ( 琼ICP备11001422号-1|公安备案:46900502000207 )

GMT+8, 2024-5-15 07:42 , Processed in 0.084185 second(s), 23 queries .

Powered by Discuz! X3.2

© 2001-2013 Comsenz Inc.

快速回复 返回顶部 返回列表