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​