• AT&T 格式汇编语言语法


    GNU 汇编器是 GNU 二进制实用程序 (binutils) 的一部分,也是 GNU 编译器集合的后端。尽管 as 不是编写相当大的汇编程序的首选汇编程序,但它是当代类 Unix 系统的重要组成部分,特别是对于内核级黑客攻击。 经常因其神秘的 AT&T 风格语法而受到批评,有人认为,as 的编写重点是用作 GCC 的后端,而很少关心“开发人员友好性”。 如果您是一位来自 INTEL 语法背景的汇编程序员,您将在代码可读性和代码生成方面遇到一定程度的窒息。 然而,必须指出的是,许多操作系统的代码库依赖于汇编器来生成低级代码

    1.  基本格式

        AT&T 语法中的程序结构与任何其他汇编器语法类似,由一系列伪指令(directives)、标签(labels)、指令(instructions)组成——由助记符和最多三个操作数组成。 AT&T 语法中最显著的差异源于操作数的顺序(注:与intel格式汇编语法刚好相反)。

        例如:通用的基本数据移动指令,intel汇编语法是:

    助记符(mnemonic)   目标操作数(destination)    源操作数(source)

    而AT&T汇编语法则是:

    助记符(mnemonic)   源操作数(source)     目标操作数(destination)   

    对于某些人来说,这种格式更直观。以下部分描述了 X64 架构的 AT&T 汇编指令的操作数类型。

    例如:

    instr   source,dest
    movl    (%ecx),%eax  (括号()表示取地址,相当于intel格式的[%ecx])
    movb    %bl,%al
    movw    %bx,%ax
    movl    %ebx,%eax
    movl    (%ebx),%eax

    2.  寄存器

             AT&T语法要求在指令后面加上后缀表示长度,根据操作的是1字节、2字节、4字节、8字节,分别对应后缀b(byte), w(word,一个字,即16字节), l(long word,即双字), q(quad word,四字,即64字节),不加后缀默认是w。

             X64的所有寄存器都带前缀符号‘%’ ,例如,%rax,%rbx, %rcx,等等。例如:

    movq %rax, %rbx  ;(movq的q指quadword,即4字,1个字16字节)

        例如:

        movl    $1,%eax

    movl    $0xff,%ebx

    int     $0x80

    3.  文字量(literal values)

        所有文字量必须带前缀符号‘$’,例如:

    movw     $100,    %bx

    movb     $0x0A,   %al

    注意:使用gcc 嵌入汇编译时,‘%号要使用两个‘%%’。

    例如:

    __asm__ __volatile__ ("movw $100, %%bx" : "=b"(a));

  • 相关阅读:
    JSONObject将json字符串转成java嵌套对象
    无胁科技-TVD每日漏洞情报-2022-11-16
    https和http的区别及安全性
    使用Java和NLP技术实现AI伪原创文章自动生成:一个详细的编程指南
    【Java】Netty创建网络服务端客户端(TCP/UDP)
    MongoDB 备忘
    项目引入jar从私服Nexus 拉去遇到的一个问题
    Vulnhub靶机:PRESIDENTIAL_ 1
    做接口测试的流程一般是怎么样的?UI功能6大流程、接口测试8大流程这些你真的全会了吗?
    从零使用GAN(生成对抗网络)进行图像生成
  • 原文地址:https://blog.csdn.net/ComputerInBook/article/details/133951003