Procedures

调用机制

image-20211213220756402

栈顶指针:%rsp

向着小地址增长(从上往下)

栈的指令:

  • pushq Src:

    • 从Src取得指令
    • 增加 %rsp 8
    • write operand at address (%rsp)
  • popq Dest

    • 同理

例子:

image-20211213221621521

第一步:callq

  • %rip的值改编为调用程序的IP
  • 将原程序下一条指令入栈
image-20211213221929187

第二步:Passing Data

image-20211213222806676

栈的结构:%rbp%rsp的位置

image-20211213223407897

%rdi%rsi前两个调用参数

image-20211213224135631

寄存器保存Convention:

哪些是caller保存,哪些是callee保存

image-20211213225136147

image-20211213225152117

参数位置的转换

image-20211213230608935

callee-Saved例子:将x交给rbx,让被调用程序保存

image-20211213231107547

循环调用的代码:

image-20211213231850943

!!!

image-20211213232517806

posted on 2022-05-13 21:38  Eddiewdy  阅读(291)  评论(0)    收藏  举报

导航