x87 FPU的寄存器
| 寄存器 | 说明 |
|---|---|
| 数据寄存器 | 用于浮点数据的8个80bit寄存器 |
| 状态寄存器 | 报告FPU状态的16bit寄存器 |
| 控制寄存器 | 控制FPU精度的16bit寄存器 |
| 标记寄存器 | 描述8个数据寄存器内容的16bit寄存器 |
| FIP寄存器 | 指向下一条FPU指令的48bitFPU指令指针 |
| FDP寄存器 | 指向内存中的数据的48bit的FPU数据指针 |
| 操作码寄存器 | 保存FPU处理的最后指令的11bit寄存器 |
浮点值传入FPU寄存器栈顶
fld source
fild把整数传入FPU寄存器
ffbld把bcd数据传入FPU寄存器
source可以是32bit/64bit/80bit内存位置
.float创建单精度浮点值 flds float_val
.double创建双精度浮点值 fldl double_val
FPU寄存器栈顶值放到内存位置
fsts/fstl des
fstp指令吧FPU寄存器st0的值复制到内存位置,并将值从堆栈中弹出
使用预置的浮点值

本文详细介绍了x87 FPU的寄存器操作,包括如何将浮点值传入寄存器栈顶,如何将栈顶值放入内存,以及状态和控制寄存器的使用。此外,还涵盖了浮点运算、条件分支、保存恢复FPU状态等关键概念,对于理解和优化浮点计算具有指导意义。
4071

被折叠的 条评论
为什么被折叠?



