enter 指令分析

enter指令分析

enter指令是为了支持高级语言中的变量作用于而加入的,它不是一个伪指令,但是却由于效率原因被各大编译器所摒弃,取而代之的是用多条指令去模拟来提升效率,确实是很悲哀的一个指令。。。

格式                  ENTER reservedVarSize, level

reservedVarSize       局部变量占用内存的大小

level                 嵌套的级别

当level = 0时,例如 enter x, 0

相当于

push ebp

mov  ebp, esp

add  esp, -x

而level != 0时,这个就是要说的关键

我们压到栈中的内容应该要保证能访问到访问级别更高的变量,那么我们就需要保存指向这些内容的栈帧的指针

例如

enter 10, 3

相当于

push ebp
mov  ebp, esp
sub  esp, (3 - 1) * 4
push ebp
sub  esp, 10

第一步push ebp是上一嵌套级别的ebp,用来供leave指令返回到上一嵌套层

sub  esp, (3 - 1) * 4这条指令是用来保存可访问的栈帧的指针,能访问几层就有几个

下面那条push  ebp是保存当前栈帧的

最后sub掉esp,保存局部变量

看英特尔的文档纠结了很久,最后得出的结论就是intel文档上有一个图片画错了。。。这个很纠结。。。

發表評論
所有評論
還沒有人評論,想成為第一個評論的人麼? 請在上方評論欄輸入並且點擊發布.
相關文章