AT&T汇编语言基础

INDEXED MEMORY MODE


.section .data
values:
    .int 10,15,20,25,30,35,40,45,50,55,60

base_address(offset_address, index,size)
==> base_address + offset_address + index*size

movl $2, %edi
movl values(,%edi,4),%eax

间接寻址

  • 在寄存器标号前加$取得是地址
  • 在寄存器标号加()取的是该寄存器地址所指向的内存的内容
    在这里插入图片描述
  • example:
.section .data
values:
    .int 10,15,20,25,30,35,40,45,50,55,60
.sectio .text
.globl main
main:
    nop
    movl values, %eax    # %eax=10
    movl $values, %edi   # %edi=&values
    movl $100, 4(%edi)   # 15换成100
    movl $1, %edi        # %edi=1
    movl values(,%edi,4),%ebx # 100赋给%ebx
    movl $1  %eax        # %eax = 1
    int $0x80  
在这里插入图片描述
  • inc = ++
  • cmpl 比较
  • jne jump if not equal

DATA EXCHANGE

  • XCHG operand1, operand2
  • bubble sort:


    bubblesort
  • %esi作为指针(保存数组起点)
  • jge jump greater then equal 后-前是否>=0
  • dec = --
  • jnz 上一条语句的结果是否为0
  • xchg 寄存器和操作数

ADD

  • add? sourcr destination 把source加到destination

  • Source operand: register,memory,immediate value

  • Destination operand:register,memory


    在这里插入图片描述
  • CF: 若进位则为1

  • OF: 前面两个高位相同且与第三个高位不同则为1

  • SF: 结果的高位是什么就是什么

  • ZF: 结果是0就是1 否则为0

  • sub? source destination:destination - source

  • neg? destination:取反(negative)

  • inc? destination :--

  • dec? destination :++

  • mul? source:无符号数乘法

    • 8位的数与%al相乘,结果放入%ax
    • imul? source
    • imul? source, destination
    • imul? multipler, source, destination:destination = multipler*source
multiple rules

在这里插入图片描述

DIVIDE

  • dividend / devisor = quotient * divisor + remainder
  • div? divisor
  • idiv? divisor
  • 被除数是除数长度的两倍
div

SHIFT LEFT(MULTIPLY 2^N)

  • sal? destination : *2
  • sal? %cl,destination : *2^cl
  • sal? shifter destination : *2^shifter(立即数)
  • shl? (as same as sal)

SHIFT RIGHT(DIVIDED BY 2^N)

  • sar? destination
  • sar? %cl,destination : /2^cl
  • sar? shifter destination : /2^shifter(立即数)
  • shr? (same as sar except always filling zero)

ROTATE SHIFT

在这里插入图片描述

BOOLEAN LOGIC

  • NOT
    • not? destination
  • AND
  • OR
  • XOR
    • and?/or?/xor? source, destination
      在这里插入图片描述
  • 清零
    • xor 三个时钟周期
    • mov 四个时钟周期

REVIEW

在这里插入图片描述

INSTRUCTION POINTER

在这里插入图片描述
  • jmp无条件跳
在这里插入图片描述

CMOVE

在这里插入图片描述

COMPARE

在这里插入图片描述

LOOP

在这里插入图片描述

PRINTF

p
在这里插入图片描述
©著作权归作者所有,转载或内容合作请联系作者
平台声明:文章内容(如有图片或视频亦包括在内)由作者上传并发布,文章内容仅代表作者本人观点,简书系信息发布平台,仅提供信息存储服务。

推荐阅读更多精彩内容

  • 1.地址总线,数据总线,控制总线在哪里,它们有什么作用?答:它们都是cpu连接外部组件的线路。地址总线:地址总线A...
    MagicalGuy阅读 1,530评论 0 1
  • 计算机通过执行指令序列来使机器得以工作,所以对于每一系列的计算机都有指定的一组指令集供计算机使用,这组指令...
    未来科技工作室阅读 8,145评论 1 10
  • 汇编语言分位数和标准,位数是根据cpu寄存器的位数发展而变化,而标准主要有两类: AT&T 标准, 主要用于UNI...
    洽白阅读 2,260评论 1 1
  • Logic Instructions AND DST, SRC ; (DST)<--(DST) & (SRC) O...
    金发萌音阅读 896评论 0 1
  • 2106.9.9房租预定 2016.11.11开始装修 2017.1.10门面挂牌 2017.1.18厨房开火 2...
    元月10号阅读 258评论 0 0