linux汇编文件无法调用c函数,无法从汇编(yasm)代码调用64位Linux上的C标准库函数...

我有一个用汇编编写的函数foo,并在

Linux(Ubuntu)64位上用yasm和GCC编译.它只是使用puts()向stdout输出一条消息,它的外观如下:

bits 64

extern puts

global foo

section .data

message:

db 'foo() called', 0

section .text

foo:

push rbp

mov rbp, rsp

lea rdi, [rel message]

call puts

pop rbp

ret

它由GCC编译的C程序调用:

extern void foo();

int main() {

foo();

return 0;

}

构建命令:

yasm -f elf64 foo_64_unix.asm

gcc -c foo_main.c -o foo_main.o

gcc foo_64_unix.o foo_main.o -o foo

./foo

这是问题所在:

运行程序时,它会打印一条错误消息,并在调用puts期间立即发生段错误:

./foo: Symbol `puts' causes overflow in R_X86_64_PC32 relocation

Segmentation fault

用objdump反汇编后,我看到调用的地址错误:

0000000000000660 :

660: 90 nop

661: 55 push %rbp

662: 48 89 e5 mov %rsp,%rbp

665: 48 8d 3d a4 09 20 00 lea 0x2009a4(%rip),%rdi

66c: e8 00 00 00 00 callq 671

671: 5d pop %rbp

672: c3 retq

(671是下一条指令的地址,不是put的地址)

但是,如果我在C中重写相同的代码,则调用方式会有所不同:

645: e8 c6 fe ff ff callq 510

即它引用了PLT的投注.

有可能告诉yasm生成类似的代码吗?

  • 0
    点赞
  • 0
    收藏
    觉得还不错? 一键收藏
  • 0
    评论

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

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

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值