浮点运算单元FPU中ST(I)等类似栈操作的规律.

        汇编学习中,在涉及到FPU部分时,由于其操作类似于栈但又不同于栈,所以经常会让我等初学者迷惑。其实了解了FPU的运行的特点也就自然走出了这个迷雾。

        现在的FPU的浮点寄存器多是由连续的8个80位的内存单元组成,其编号由ST(0)~ST(7)。浮点运算就在这段FPU内存中进行。与通常意义上的内存不同,所有浮点运算都必须有栈顶即ST(0)寄存器参与。运算中虽然与栈操作类似,但栈顶确始终是固定的ST(0)寄存器,当有新值压栈时,则原ST(0)中的值则自动顺移至ST(1)。当第9次压栈时,虽然仍能正确入栈,但原第一次入栈值将被挤出FPU。这种情况将在FPU中的状态寄存器中进行标志。相反,当有值从栈顶ST(0)弹出,则ST(1~7)中值将顺次递补至ST(0)。 而刚弹出值,并未立即丢弃,以循环的形式压入栈底ST(7)。换句话说,这种情况就如在FPU浮点寄存器的内存单元中形成了一个单向循环的出栈数据流。就如:装只容最近8个值,出则按8个值循环出,(当然ST7值为原ST0值,而ST0值则由运算结果定)。

        从上面情况看,正常栈操作是栈底固定,通过栈顶指针确定当前栈操作值。而这个FPU则是栈顶固定,任何栈操作都不用指针,只对栈顶即ST0进行压/弹.因此运算中,参数中也要求必有ST0参与。而无论是谁参加与ST0运算,只要运算中有弹出操作,则原ST0必移至ST7处,原ST1移至ST0处并被运算结果取代。

        例:

FILD    100      ST(0)=100;

FILD    200      ST(0)=200;    ST(1)=100

  • 3
    点赞
  • 3
    收藏
    觉得还不错? 一键收藏
  • 3
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论 3
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值