浮点运算单元FPU中ST(I)等类似栈操作的规律.
来源:互联网 发布:淘宝收费的课程靠谱吗 编辑:程序博客网 时间:2024/05/14 12:33
汇编学习中,在涉及到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
FILD 300 ST(0)=300; ST(1)=200 ST(2)=100
FILD 400 ST(0)=400; ST(1)=300 ST(2)=200; ST(3)=100
FMULP ST(1),ST(0)
ST(0)=120000; ST(1)=200 ST(2)=100; ST(3)= ST(4)= ST(5)= ST(6)= ; ST(7)=400
需要说明的是,四则运算中参数缺省时,则相当调用参数序为ST(1),ST(0),同时进行二次弹出,并将结果入ST(0)。数学表达为:ST(0)=ST(1)*ST(0) ;ST(I)《=ST(I+1) 0<I<7 ;ST(7)=ST(0)<原值>
掌握了这个规律,在使用FPU运算时就会心中有数不会出现值差错了。
- 浮点运算单元FPU中ST(I)等类似栈操作的规律.
- 浮点运算单元(FPU)的理解
- ARM处理器的浮点运算单元(FPU)
- 用汇编实现浮点数的乘法运算---FPU
- 关于STM32 浮点运算单元
- java中浮点数的高精度运算
- JAVA中精确的浮点运算
- 关于js中浮点数的运算
- java中浮点数的运算
- JS中准确的浮点运算库
- C语言中浮点数的运算
- 在Java中使用标准输入输出设备进行字符串,整数浮点数等 的输入输出操作
- I/O流操作规律
- OC中 (i++)+i 的值得运算
- java I/O 流的操作规律 小结
- c#字符串中包含的运算符按正常计算 例如按四则运算等,类似公式计算,很好很强大
- c#字符串中包含的运算符按正常计算 例如按四则运算等,类似公式计算,很好很强大
- 操作码5:浮点运算
- RMAN使用说明一
- 成功de态度
- java像素级图像处理与识别方法
- Delphi 中压缩流和解压流的应用
- linux php配置
- 浮点运算单元FPU中ST(I)等类似栈操作的规律.
- Asp.net中防止用户多次登录的方法
- 中国的网络正在走向世界化
- 开张
- ERP顾问出差遇险记(一).恶脸也能保护自己
- oracle触发器和常用内置程序包
- 系统架构中安全性思考
- 系统架构师职业内容
- VC 中用 IPicture 在窗口中显示图片文件