转载于:http://cs.fjzs.edu.cn/ketang/hbyy/11-3-2.htm
11.3.2 数据传送指令
为了满足协处理器和CPU之间进行数据交流的需求,就需要实现内存单元和协处理器之间进行数据传送的指令。协处理器的指令系统中有三大类数据传送指令:BCD传送指令、浮点数传送和整数传送指令。
一、BCD传送指令
1、FBLD
指令格式:FBLD MemBCD(*)
指令功能:将内存中的BCD数据压入协处理器的堆栈中;
(*) MemType是指定数据类型Type的内存单元,如:MemBCD是BCD类型的存储单元。此后不再说明。
2、FBSTP
指令格式:FBSTP MemBCD
指令功能:将协处理器中的BCD数据存入内存,并进行堆栈的弹出操作。
例如:
.387 | |||
data1 | DT 123, -543 | ||
data2 | DT 2.5 | ||
…… | |||
FBLD | data1 | ;把BCD数据123压进栈 | |
FBSTP | data2 | ;把当前堆顶数据弹出,并传送给BCD型的内参单元 |
二、浮点数传送指令
1、FLD |
||
指令格式: | FLD STReg(*)/MemReal | |
指令功能: | 将浮点数据压入协处理器的堆栈中。当进行内存单元内容压栈时,系统会自动决定传送数据的精度。比如:用DD或REAL4定义的内存单元数值是单精度数等。 |
(*) STReg是协处理器堆栈寄存器ST(0)~ST(7)。
例如:
.387 | |||
data1 | DD 123, -543 | ||
data2 | REAL8 -321.5 | ||
data3 | REAL10 2.5 | ||
…… | |||
FLD | data1 | ;压一个单精度数据进栈 | |
FLD | data2 | ;压一个双精度数据进栈 | |
FLD | ST(0) | ;把堆栈寄存器ST(0)的值再压进栈 | |
FLD | data3 | ;压一个扩展精度数据进栈 |
2、FST
指令格式: | FST STReg/MemReal | |
指令功能: | 将协处理器堆栈栈顶的数据传送到目标操作数中。在进行数据传送时,系统自动根据控制寄存器中舍入控制位的设置把栈顶浮点数舍入成相应精度的数据。 |
3、FSTP
指令格式: | FSTP STReg/MemReal | |
指令功能: | 与FST相类似,所不同的是:指令FST执行完后,不进行堆栈的弹出操作,即:堆栈不发生变化,而指令FSTP执行完后,则需要进行堆栈的弹出操作,堆栈将发生变化。请见11.3.1节中的指令操作符命名规则的说明。 |
4、FXCH
指令格式: | FXCH [STReg] | |
指令功能: | 将指定的寄存器中的浮点数与栈顶浮点数进行交换。如果不指定操作数,那么,默认ST和ST(1)二者之间交换数据。 |
例如:FXCH ST(2)——栈顶数据与堆栈寄存器ST(2)进行数据交换。
三、整数传送指令
1、FILD
指令格式:FILD MemInt
其中:MemInt是定义为整型数据类型的内存单元,但不能是用DB定义的存储单元。下同,不再叙述。
2、FIST/FISTP
指令格式: | FIST MemInt FISTP MemInt |
|
其中: | Mem是定义整型数据类型的内存单元,但不能是用DB定义的存储单元。 | |
指令功能: | 将协处理器堆栈栈顶的数据传送到目标存储单元中。在进行数据传送时,系统自动根据控制寄存器中舍入控制位的设置把栈顶浮点数舍入成整型数据。 |
指令FIST和FISTP的区别在于堆栈操作,详细请见11.3.1中的命名规则说明。
另:一个学习汇编指令的站点:http://courses.engr.illinois.edu/ece390/archive/spr2002/books/labmanual/inst-ref.html
http://blog.csdn.net/chence19871/article/details/7398012