zoukankan      html  css  js  c++  java
  • 汇编语言第二张寄存器

    ---恢复内容开始---

    通用寄存器

    1.8086CPU的所有寄存器都是16位的,可以存放两个字节。AX,BX,CX,DX这四个寄存器通常用来存放一般性的数据,被称为通用寄存器。

    2.8086CPU的上一代CPU中的寄存器都是8位的,为了保证兼容,使原来基于上代CPU编写的程序稍加修改就可以运行在8086之上,8086CPU的AX,BX,CX,DX这四个寄存器都可分为两个独立使用的8位寄存器来用:

    AX可分为AH和AL;

    BX可分为BH和BL;

    CX可分为CH和CL;

    DX可分为DH和DL。

    字在寄存器中的存储

    1.处于对兼容性的考虑,8086CPU可以一次性处理一下两种尺寸的数据。

          1)字节:记为byte,一个字节有8个bit组成,可以存在8位寄存器中。

          2)字:记为word,一个字由两个字节组成,这两个字节分别称为这个字的高位字节和低位字节

       3)双字:4个字节。

         4)四字:8个字节。

    汇编指令

    在写一条汇编指令或一个寄存器的名称时不区分大小写。

    物理地址

    所有的内存单元构成的存储空间是一个一维的线性空间,每一个内存单元在这个空间中都有唯一的地址,我们称之为物理地址。

    16位结构的CPU

    16位结构(16位机、字长为16位等常见说法,与16位结构含义相同)。描述了一个COU具有下面几方面的结构特性。

    • 运算器一次最多可以处理16位的数据;

    • 寄存器的最大宽度为16位;

    • 寄存器和运算器之间的通路位为16位。

    8086CPU给出物理地址的方法

    8086CPU采用一种在内部用两个16位地址合成的方法来形成一个20位的物理地址。

    地址加法器采用方法:物理地址=段地址*16+偏移地址。

    段的概念

    (1)段是8086为解决用16位寄存器表示20位的物理地址而引入的是一个逻辑上的概念。可以根据需要,将地址连续、起始物理地址为16倍数的一组内存单元(不超过64kb)当作一个段使用。

    (2)8086中,通过段地址:偏移地址来间接描述内存单元的物理地址。CPU根据如下公式计算得到物理地址:段地址×16+偏移地址=物理地址。其中 段地址:偏移地址 也称逻辑地址,段地址×16构成段的起始物理地址,故根据需要划分段使用时,段的起始物理地址必须是16的倍数。

    (3)段的划分是灵活的,一个物理地址可以用不同的 段地址:偏移地址 来表示。只要满足段的起始物理地址是16的倍数。

    CS和IP

    (1)CS:代码段段寄存器,用于存放代码段的段地址。

               IP:指令指针寄存器,用于存放CPU将要读取的指令在代码段中的偏移地址

               CS:IP对应的物理地址存放的是CPU将要读取的指令。

    (2)计算机工作过程

      第一步:CPU基于CS:IP,计算出物理地址,然后到相应的内存单元读取指令,送到指令缓冲区;

      第二步:CPU自动修改IP的值,IP=IP+所读取指令的长度,从而为下一条指令读取做准备;

      第三步:执行指令,转第一步,重复此过程。

       在8086CPU加电启动或复位后(即CPU刚开始工作时)CS和IP被设置为CS=FFFFH,IP=0000H。

    (3)IP和CS的值的修改不能通过mov指令实现,需借助转移指令(如jmp、call等)。

    代码段

  • 相关阅读:
    centos 7 安装Telnet并设为开机自启动、开防火墙端口
    cenos 7 中firewalld开放服务端口
    来自鸟哥的lftp客户端软件使用方法
    关闭Linux无用端口
    家用路由器网络设置DMZ区
    Linux中退出循环命令
    shell函数基本概念
    inode节点用尽处理
    xfs格式化、ext4格式化并指定inode区别
    dd备份命令使用
  • 原文地址:https://www.cnblogs.com/saudade/p/9770850.html
Copyright © 2011-2022 走看看