汇编分析C语言函数堆栈调用

4 篇文章 0 订阅
1 篇文章 0 订阅

C语言代码如下

#include <stdio.h>
int plus(int x,int y){
	return x+y;
}
int main()
{
	printf("hello");
	plus(1,2);
	return 0;
}

我们从调用plus开始分析
ESP表示栈顶
EBP表示栈底
EIP表示下个指令的地址

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述 在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述全部写入CC的目的是让程序可以中断
比如这些栈的空间你没用完,接下来就执行CC中断了

在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述在这里插入图片描述

  • 0
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
要在汇编语言调用C语言函数,需要按照以下步骤进行操作: 1. 定义C语言函数的原型:需要在汇编代码中定义C语言函数的原型,以便编译器知道如何处理函数的参数和返回值。 2. 准备函数参数:将函数的参数保存在寄存器或堆栈中,以便传递给被调用C语言函数。 3. 调用C语言函数使用CALL指令调用C语言函数,将执行流程转移到C语言函数中执行。 4. 处理返回值:将C语言函数的返回值从寄存器或堆栈中读取出来,以便在汇编代码中使用。 以下是一个示例程序,演示如何在汇编语言调用C语言函数: ``` ; 汇编代码中定义C语言函数的原型 extern int add(int a, int b); section .data a dd 10 b dd 20 section .text global _start _start: ; 将函数参数保存在寄存器中 mov eax, dword [a] mov ebx, dword [b] ; 调用C语言函数 call add ; 处理返回值 mov ebx, eax ; 输出计算结果 mov eax, 1 mov ecx, ebx mov edx, 4 int 0x80 ; 退出程序 mov eax, 1 xor ebx, ebx int 0x80 ``` 在上面的示例程序中,我们首先使用extern关键字定义了C语言函数add的原型。然后,我们在.data节中定义了两个变量a和b,并在.text节中将它们的值保存在寄存器eax和ebx中。 接着,我们使用call指令调用C语言函数add,并将执行流程转移到C语言函数中。在C语言函数执行完毕后,我们将返回值从eax寄存器中读取出来,并将它保存在ebx寄存器中。 最后,我们使用int 0x80指令调用系统调用输出计算结果,并使用int 0x80指令退出程序。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值