linux汇编语法格式

linux汇编语法格式,第1张

Linux下使用的是AT&T汇编格式和Intel 汇编格式不同。可以参考“ Linux汇编语言 ”。比如:堆栈 *** 作:(AT&T格式:pushl %eax) (Intel 格式:push eax )

在linux源代码中会有一部分c语言与汇编语言相交融的部分。

其中linux中汇编语言采用的不是我们通用的intel的汇编语言,而是采用的是AT&T格式的汇

编语言,它们之间有一些差别:

1

目标与源的方向不大一样

mov

ax,

bx

mov

%bx,

%ax

2

AT&T寄存器前要加入%

ax

%ax

3

AT&T立即数前面要加上$

add

ax,

4

add

%ax,$4

4

对于访问指令的 *** 作数大小

intel的格式是在 *** 作数前加上BYTE

PTR、DWORD

PTR等等

AT&T格式:在 *** 作数后面加上b、l、w等

MOV

AL,

BYTE

PTR

FOO(intel)

movb

FOO,

%al

(AT&T)

5

间接寻址:

SECTION:[BASE+INDEX*SCALE+DISP]

Section:disp(base,

index,

scale)

C语言中插入汇编代码比纯粹的汇编要难,因为要设计到“如何分配使用寄存器、怎样与C语

言中变量相结合”

下面“=”代表只读,“+”代表读写

每个输出部分均以=开始

比如我想定义一个char型的变量,放入ax中

register

char

_temp

asm

("ax")

register

char

_temp

__asm__

("ax")

以上两种方式均正确

在这里我们通常看到普通的寄存器前面有两个%,代表下面的意思:第一寄存器前要有一个%

第二对于一个模板前要加入一个%

下面以一个在内核中常见的目的为了实现原子 *** 作的一个函数为例子atomic_add来介绍

static

__inline__

void

atomic_add(int

i,

atomic_t

*v)

{

__asm__

__volatile__(

LOCK

"addl

%1,

%0"

:"=m"(v->counter)

:"ir"(i),

"m"(v->counter)

)

}

ir代表一个寄存器中的直接 *** 作数

首先一个头部:__asm__

__volatile__()

asm()

__asm__()告诉编译器里面是汇编语言

:第一个冒号是输出部分:第二个冒号是输入部分

其实还有第三个冒号:代表着损坏部分

asm("汇编语句"

:输出部分

:输入部分

:损坏部分)

%0、%1

等等代表着一种模板 *** 作数,其中数字到几取决于cpu寄存器数量

"m",

"v",

"o"

--内存单元

"r"

任意寄存器

"q"

表示eax、ebx、ecx、edx之一

"i",

"h"

表示立即数

"a",

"b",

"c",

"d"表示eax、ebx、ecx、edx

关键字LOCK表示在执行的时候把系统总线锁住,不让其他

cpu干扰。

linux下将C语言编译为汇编代码,需用-S参数:

编译命令为:

$ gcc -S s1.c

如下代码:

void fun(int a,int b)

{

/*这个函数什么也不做*/

}

int main(void)

{

fun(100,200)

return 0

}


欢迎分享,转载请注明来源:内存溢出

原文地址: http://outofmemory.cn/yw/7264890.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2023-04-03
下一篇 2023-04-03

发表评论

登录后才能评论

评论列表(0条)

保存