nasm汇编和C语言函数之间参数传递

1. 前言

图片.png
堆栈生长方向: 高地址在栈底,底地址在栈顶
参数入栈顺序: 从右到左依次入栈
函数调用入栈顺序: 函数调用入栈顺序

2. 测试案例

  1. 汇编代码
    hello.asm
extern compare
section .data
    enter_ch db 0x0a
    num1 dd 3
    num2 dd 3
section .text
global _start
global printstr

_start:
    mov edx, [num2]
    push edx; second num
    mov edx, [num1]
    push edx; first num
    call compare

    mov eax, 1
    int 0x80

printstr:
    mov eax, 4
    mov ebx, 1
    mov ecx, [esp+4] ; esp指向调用处的下一条地址
    mov edx, [esp+8]
    int 0x80
    ret
  1. main.c
extern void printstr(char* str, int len);
void compare(int num1, int num2)
{
    if (num1 == num2)
        printstr("Equal\n", 6);
    else
        printstr("Not equal\n", 10);
}
  1. makefile
.DEFAULT_GOAL := default

main.o: main.c
	gcc -m32 -c main.c -o main.o

hello.o:hello.asm
	nasm -felf32 hello.asm -o hello.o

default:
	make main.o
	make hello.o
	# ld -m elf_i386 -e main hello.o main.o -o main
	ld -m elf_i386 hello.o main.o -o main
	# rm -rf *.o
  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值