汇编(三)

作者: 小小鱼类 | 来源:发表于2017-07-22 12:47 被阅读5次

8086的寻址方式

  • CPU访问内存单元时,要给出内存单元的地址,所有的内存单元都有唯一的地址,叫做物理地址
  • 8086有20位地址总线,可以传送20位的地址,1M的寻址能力
  • 但它又是16位结构的CPU,它内部能够一次性处理、传输、暂时存储的地址为16位。如果将地址从内部简单地发出,那么它只能送出16位的地址,表现出来的寻址能力只有64KB

8086采用一种在内部用2个16位地址合成的方法来生成1个20位的物理地址


image.png image.png image.png image.png

内存分段管理

  • 8086是用“基础地址(段地址×16) + 偏移地址 = 物理地址”的方式给出物理地址
  • 为了开发方便,我们可以采取分段的方法来管理内存,比如:
image.png

地址10000H~100FFH的内存单元组成一个段,该段的起始地址(基础地址)为10000H,段地址为1000H,大小为100H
地址10000H1007FH、10080H100FFH的内存单元组成2个段,它们的起始地址(基础地址)为:10000H和10080H,段地址为1000H和1008H,大小都为80H

在编程时可以根据需要,将若干连续地址的内存单元看做一个段,用段地址×16定为段的起始地址(基础地址),用偏移地址定位段中的内存单元段地址×16必然是16的倍数,所以一个段的起始地址(基础地址)也一定是16的倍数
偏移地址为16位,16位地址的寻址能力为64KB,所以一个段的长度最大为64KB

image.png

段寄存器

  • 8086在访问内存时要由相关部件提供内存单元的段地址和偏移地址,送入地址加法器合成物理地址

  • 是什么部件提供段地址?段地址在8086的段寄存器中存放

  • 8086有4个段寄存器:CS、DS、SS、ES,当CPU需要访问内存时由这4个段寄存器提供内存单元的段地址

    • CS (Code Segment):代码段寄存器
    • DS (Data Segment):数据段寄存器
    • SS (Stack Segment):堆栈段寄存器
    • ES (Extra Segment):附加段寄存器

CS和IP

  • CS为代码段寄存器,IP为指令指针寄存器,它们指示了CPU当前要读取指令的地址
  • 任意时刻,8086CPU都会将CS:IP指向的指令作为下一条需要取出执行的指令
image.png image.png

指令的执行过程

12 13 14 15 16 17 18 19 20 21 22 23 24 25 26 总结

指令和数据

  • 在内存或者磁盘上,指令和数据没有任何区别,都是二进制信息

  • CPU在工作的时候把有的信息看做指令,有的信息看做数据,为同样的信息赋予了不同的意义


    image.png
  • CPU根据什么将内存中的信息看做指令?

    • CPU将CS:IP指向的内存单元的内容看做指令
    • 如果内存中的某段内容曾被CPU执行过,那么它所在的内存单元必然被CS:IP指向过

jmp指令

  • CPU从何处执行指令是由CS、IP中的内容决定的,我们可以通过改变CS、IP的内容来控制CPU执行目标指令
  • 8086提供了一个mov指令(传送指令),可以用来修改大部分寄存器的值,比如
    • mov ax,10、mov bx,20、mov cx,30、mov dx,40
  • 但是,mov指令不能用于设置CS、IP的值,8086没有提供这样的功能
  • 8086提供了另外的指令来修改CS、IP的值,这些指令统称为转移指令,最简单的是jmp指令
image.png image.png

jmp指令 -- 练习

image.png image.png image.png

代码段

image.png image.png image.png image.png

文章链接:http://www.jianshu.com/p/e85e2d64ed1e

只为收藏,不成敬意!

相关文章

  • <安全攻防之汇编基础>

    &关于汇编基础请点击 <汇编一> <汇编二> <汇编三> <汇编四> <汇编五> <汇编六> <汇编七> <汇编八...

  • (二) LLDB理解汇编

    1. 汇编寄存器调用约定 1.1 汇编101 看看下面的汇编片段: 在这段汇编代码中有三个操作码pushq、sub...

  • 汇编(三)

    8086的寻址方式 CPU访问内存单元时,要给出内存单元的地址,所有的内存单元都有唯一的地址,叫做物理地址 808...

  • 汇编三

    完整的汇编指令:#### 汇编由两种指令组成1.汇编指令如mov、add、sub等有对应的机器指令,可以被编译为机...

  • 汇编(三)

    8086的寻址方式 CPU访问内存单元时,要给出内存单元的地址,所有的内存单元都有唯一的地址,叫做物理地址 808...

  • 汇编(三)

    一. 8086的寻址方式 CPU访问内存单元是,要给出内存单元的地址,所有的内存单元都有唯一的地址,叫做物理地址 ...

  • 汇编(三)

    1.函数的局部变量 定义一个局部变量c,断点查看汇编中c的存储调用 2.函数的嵌套调用 定义2个函数,funcA中...

  • 汇编(三)

    一. 函数的参数 1.1 多个参数创建空工程001--Demo,编写代码如下 test方法调用处打断点,运行工程断...

  • 汇编程序基础

    汇编程序基础 一、汇编程序基本结构 二、汇编指令 1.汇编指令基本结构 三、伪指令 1.段定义 2.数据定义 数据...

  • 提高代码执行效率的几个小技巧

    前言 目录 一、方法参数限制 二、反汇编 switch case & if else 三、C 中写汇编代码 四、 ...

网友评论

    本文标题:汇编(三)

    本文链接:https://www.haomeiwen.com/subject/jzqukxtx.html