过程调用指令CALL介绍.ppt
文本预览下载声明
过程调用指令CALL 1.段内直接调用 CALL near_proc ; (SP)←(SP)-2 , ((SP)+1: (SP))←(IP) ; (IP)←(IP)+disp 指令的操作数是一个近过程,该过程在本段内。 指令汇编以后,得到CALL的下一条指令与被调用的过程入 口地址之间的16位相对位移量disp。 指令的操作是将指令指针IP压入堆栈,然后将相对位移量disp加到IP上,从而使程序转移到被调用的过程处执行。 相对位移量 disp的范围为-32768~+32767,占2个字节,段内直接调用指令为3字符指令。 例如: NAME1 PROC FAR CALL NAME2 RET NAME2 PROC NEAR RET NAME2 ENDP NAME1 ENDP 2.段内间接调用 CALL reg16/mem16 ; (SP)←(SP)-2 , ((SP)+1:(SP))←(IP) ; (IP)←(reg16)/(mem16) 指令的操作数是一个16位的寄存器或存储器,其中的内容是一个近过程的入口地址。 本指令将IP寄存器压入堆栈,然后将寄存器或存储器的内容传送到IP。 例如: CALL AX CALL WORD PTR [BX] (BX所指内存字单元中存放的是子程序的偏移量) 假设某程序中定义了字变量SADR CALL SADR 3.段间直接调用 CALL far_proc ; (SP)←(SP)-2 , ((SP)+1:(SP))←(CS) ; (CS)←SEG far_proc ; (SP)←(SP)-2 , ((SP)+1:(SP))←(IP) ; (IP)←OFFSET far_proc 指令的操作数是一个远过程,该过程在另外的代码段内。 段间直接调用指令先将CS中的段地址压入堆栈,并将远过程所在段的段地址SEG far_proc送入CS;再将IP中的偏移地址压入堆栈,然后将远过程的偏移地址OFFSET far_proc送入IP。 例如:CODE1 SEGMENT CALL RRR CODE1 ENDS CODE2 SEGMENT RRR PROC FAR RET RRR ENDP CODE2 ENDS 4.段间间接调用 CALL mem32 ; (SP)←(SP)-2 , ((SP)+1:(SP))←(CS) ; (CS)←(mem32+2) ; (SP)←(SP)-2 , ((SP)+1:(SP))←(IP)
显示全部