linux 51 汇编指令,64位linux 汇编

本文详细解析了一段简单的C源码,并展示了其编译后的64位汇编代码。讨论了64位与32位汇编在系统调用号、寄存器使用和调用方式上的差异,强调了从C到汇编转换的过程。

摘要生成于 C知道 ,由 DeepSeek-R1 满血版支持, 前往体验 >

c源码:testg.c

1 #include

2

3 #define sum(a, b) a + b

4

5 int main(int argc,char **argv)

6 {

7 int num = sum(1,2);

8 printf("num =%d\n", num);

9

10 return0;

11 }

使用命令:gcc -S testg.c

寄存器:8位:al,ah

16位:ax

32位:eax

64位:rax 新增(r8-r15寄存器,低32位r8d-r15d,低16位r8w-r15w,低8位r8b-r15b)

操作符标示:8位:b

16位:w

32位:l

64位:q

1 .file "testg.c"

2 .section .rodata

3 .LC0:

4 .string "num = %d\n"

5 .text

6 .globl main

7 .type main, @function

8 main:

9 .LFB0:

10 .cfi_startproc

11 pushq %rbp

12 .cfi_def_cfa_offset16

13 .cfi_offset6, -16

14 movq %rsp, %rbp

15 .cfi_def_cfa_register6

16 subq $32, %rsp

17 movl %edi, -20(%rbp)

18 movq %rsi, -32(%rbp)

19 movl $3, -4(%rbp)

20 movl -4(%rbp), %eax

21 movl %eax, %esi

22 movl $.LC0, %edi

23 movl $0, %eax

24 call printf

25 movl $0, %eax

26 leave

27 .cfi_def_cfa7, 8

28 ret

29 .cfi_endproc

30 .LFE0:

31 .size main, .-main

32 .ident "GCC: (GNU)5.1.0"

33 .section .note.GNU-stack,"",@progbits

linux系统中64位汇编和32位汇编的系统调用主要有以下不同:

(1)系统调用号不同.比如x86中sys_write是4,sys_exit是1;而x86_64中sys_write是1, sys_exit是60。linux系统调用号实际上定义在/usr/include/asm/unistd_32.h和/usr/include/asm/unistd_64.h中。

(2)系统调用所使用的寄存器不同,x86_64中使用与eax对应的rax传递系统调用号,但是 x86_64中分别使用rdi/rsi/rdx传递前三个参数,而不是x86中的ebx/ecx/edx。

(3)系统调用使用“syscall”而不是“int 80”。

人就像是被蒙着眼推磨的驴子,生活就像一条鞭子;当鞭子抽到你背上时,你就只能一直往前走,虽然连你也不知道要走到什么时候为止,便一直这么坚持着。

评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值