本文主要是介绍32/64位系统下使用ATT风格汇编调用c函数,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!
32/64位系统下使用AT&T风格汇编调用c函数
- 32 位操作系统使用汇编调用 c 函数
- 演示代码
- 编译方法
- gcc 编译汇编
- as 编译连接汇编
- 编译
- 连接
- 64 位操作系统使用汇编调用 c 函数
- 演示代码
- 编译方法
- gcc 编译汇编
- as 编译连接汇编
- 编译
- 连接
32 位操作系统使用汇编调用 c 函数
演示代码
文件名 : hello.s
.section .dataformat: .asciz "Hello, %s!\n"message: .asciz "World".section .text
.global _start_start:push $messagepush $formatcall printfaddl $8, %esppush $0call exit
编译方法
gcc 编译汇编
使用这种方法需要将 _start
改为 main
, 因为 gcc 编译器是从 main 函数开始的
gcc -m32 -o hello hello.s
as 编译连接汇编
在 64 位操作系统下编译 32 位汇编程序,编译上有两种方法:
编译
1、 修改源代码,在源码最顶部加上 .code32
指令(不推荐)
2、 如果不像修改源代码,则需要修改编译参数
```shell
as --32 -o hello.o hello.s
```
连接
ld -m elf_i386 -I /lib/ld-linux.so.2 -L /usr/lib32/ -o cpuid2 -lc cpuid2.o
64 位操作系统使用汇编调用 c 函数
演示代码
.section .dataformat: .asciz "Hello, %s!\n"message: .asciz "World".section .text
.global _start_start:subq $8, %rspmovq $format, %rdimovq $message, %rsixorl %eax, %eaxcall printfaddq $8, %rspmovl $60, %eaxxorl %edi, %edisyscall
编译方法
gcc 编译汇编
使用这种方法需要将 _start
改为 main
, 因为 gcc 编译器是从 main 函数开始的
在64位系统中,默认情况下启用 PIE,但在某些情况下,它可能会导致链接错误。因此,我们在这里禁用了 PIE。
gcc -no-pie -o hello hello.s
as 编译连接汇编
编译
as -o hello.o hello.s
连接
ld -I /lib/ld-linux-x86-64.so.2 -L /usr/lib64/ -o hello -lc hello.o
这篇关于32/64位系统下使用ATT风格汇编调用c函数的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!