汇编语言学习

本文详细介绍了8086CPU的内部构造,特别是寄存器的作用和类型,包括通用寄存器的拆分。讨论了16位结构CPU的特点,如16位运算器和16位寄存器,并揭示了8086CPU如何通过段地址和偏移地址合成20位物理地址以实现1M的寻址能力。同时,阐述了CS和IP寄存器在指令执行流程中的作用。内容深入浅出,有助于理解8086CPU的工作原理。
摘要由CSDN通过智能技术生成

寄存器概述

CPU由运算器、控制器、寄存器构成在CPU中:
运算器进行信息处理;寄存器进行信息存储;控制器控制各种器件进行工作;内部总线链接各种器件,在它们之间进行数据的传送。
对汇编来说,CPU中的主要部件是寄存器。寄存器是CPU中程序员可以用指令读写的部件。程序员通过改变各种寄存器中的内容来实现对CPU的控制。
不同的CPU,寄存器的个数,结构不同。8086CPU有14个寄存器,每个寄存器有一个名称:AX,BX,CX,DX,Sl,DI,SP,BP,IP,CS,SS,DS,ES,PSW。

通用寄存器

F4:AX BX CX DX
F4常用于存放一般性数据,被称作通用寄存器,8086的寄存器都是16位的,没有例外。
由于历史原因,F4又可以拆分成高八位寄存器和低八位寄存器
AX分为AH和AL
BX分为BH和BL
CX 分为CH和CL
DX 分为DH和DL
在这里插入图片描述

几条汇编指令

在这里插入图片描述
格式:
mov寄存器,立即数 mov寄存器,寄存器
add 寄存器,立即数 add 寄存器,寄存器
在这里插入图片描述
在这里插入图片描述
关于2.1的神回复:
8226H+8226H=1044CH
1044CH显然超出了16位,那么,数据溢出,最高位1被丢弃,所以,AX数据为044CH
在这里插入图片描述
关于2.2的神回复:
C5H+93H=158H
显然超出了8位,最高位1被舍弃,AL=58H,则AX=0058H
前面所用过的指令,我们发现每条指令的两个操作对象位数都是一致的。

物理地址

CPU访问内存单元时,要给出内存单元的地址。所有的内存
单元构成的存储空间是一个一维的线性空间,每一个内存单元在这个空间中都有唯一的地址,我们将这个唯一的地址称为物理地址。
CPU通过地址总线送入存储器的,必须是一个内存单元的物
理地址。在CPU向地址总线上发出物理地址之前,必须要在内部先形成这个物理地址。不同的CPU可以有不同的形成物理地址的方式。
我们一直都在说8086是16位机,那么到底什么是16位结构CPU?
1.运算器一次最多可以处理16位的数据。
2.寄存器的最大宽度为16位。
3.寄存器和运算器之间的通路位16位。
矛盾激化:
8086有20条地址总线,也就是说,可以传送20位地址,达到1M的寻址能力,如果从8086cpu内部来看,如果只是简单的将地址从内部发出,最多只能达到16位,寻址能力只是64K。
既然地址是理想中的,所以8086用了这样的一个方法:在内部用两个16位地址合成->20位物理地址
在这里插入图片描述
当8086CPU读写内存时:
1、CPU中的相关部件提供两个16位的地址,—个成为段地址,另一个成为偏移地址;
2、段地址和偏移地址通过内部总线送入一个成为地址加法器的部件;
3、地址加法器将两个16位地址合成为一个20位的物理地址;
4、地址加法器通过内部总线将20位物理地址送入输入输出控制电路;
5、输入输出控制电路将20位物理地址送上地址总线;
6、20位物理地址被地址总线传送到存储器。
地址加法器(血汗工厂)采用物理地址=段地址×16+偏移地址的方法合成。
在这里插入图片描述

“段地址×16+偏移地址=物理地址”的本质含义是:CPU在访问内存时,用一个基础地址(段地址×16)和一个相对于基础地址的偏移地址相加,给出内存单元的物理地址。
更一般地说,8086CPU 的这种寻址功能是.“基础地址+偏移地址=物理地址”寻址模式的一种具体实现方案。8086CPU中,段地址x16可看作是基础地址。
扩展阅读:如果对移位和乘法的关系不是很懂,参考王爽《汇编语言》“由段地址x16引发的血案”加果对本质论不懂,参考“单行离模型"
内存分的段是CPU决定的,与其说是段地址,不如叫基础地址,比如我们认为地址10000H~100FFH内存单元组成一个段,段地址1000H,大小100H,也可以认为地址
10000H~1077FH,10080H -10OFFH组成两个段,大小都是80H,段地址分别是1000H、1008H

段寄存器CS与IP

CS为代码段寄存器,IP为指令指针寄存器,它们指示了CPU当前要读取指令的地址。8086CPU将CS:IP指向的内容当做当前指令执行。
在这里插入图片描述
说明书:
1、8086CPU当前状态:CS中的内容为2000H,IP内容为0000H;
2、内存20000H~20009H单元中存放着可执行的机器码;
3、内存20000H~200009H单元中存放的机器码对应的汇编指令如下。
工作过程:
1、从CS:IP指向的内存单元读取指令,读取的指令进入指令缓冲器。
2、IP=IP+所读取指令的长度,从而指向下一条指令。
3、执行指令,转到1,重复过程。

  • 3
    点赞
  • 2
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
课程介绍 第1章 预备知识  1.1 汇编语言的由来及其特点   1 机器语言   2 汇编语言   3 汇编程序   4 汇编语言的主要特点   5 汇编语言的使用领域  1.2 数据的表示和类型   1 数值数据的表示   2 非数值数据的表示   3 基本的数据类型  1.3 习题 第2章 CPU资源和存储器  2.1 寄存器组   1 寄存器组   2 通用寄存器的作用   3 专用寄存器的作用  2.2 存储器的管理模式   1 16位微机的内存管理模式   2 32位微机的内存管理模式  2.3 习题 第3章 操作数的寻址方式  3.1 立即寻址方式  3.2 寄存器寻址方式  3.3 直接寻址方式  3.4 寄存器间接寻址方式  3.5 寄存器相对寻址方式  3.6 基址加变址寻址方式  3.7 相对基址加变址寻址方式  3.8 32位地址的寻址方式  3.9 操作数寻址方式的小结  3.10 习题 第4章 标识符和表达式  4.1 标识符  4.2 简单内存变量的定义   1 内存变量定义的一般形式   2 字节变量   3 字变量   4 双字变量   5 六字节变量   6 八字节变量   7 十字节变量  4.3 调整偏移量伪指令   1 偶对齐伪指令   2 对齐伪指令   3 调整偏移量伪指令   4 偏移量计数器的值  4.4 复合内存变量的定义   1 重复说明符   2 结构类型的定义   3 联合类型的定义   4 记录类型的定义   5 数据类型的自定义  4.5 标号  4.6 内存变量和标号的属性   1 段属性操作符   2 偏移量属性操作符   3 类型属性操作符   4 长度属性操作符   5 容量属性操作符   6 强制属性操作符   7 存储单元别名操作符  4.7 表达式   1 进制伪指令   2 数值表达式   3 地址表达式  4.8 符号定义语句   1 等价语句   2 等号语句   3 符号名定义语句  4.9 习题 第5章 微机CPU的指令系统  5.1 汇编语言指令格式   1 指令格式   2 了解指令的几个方面  5.2 指令系统   1 数据传送指令   2 标志位操作指令   3 算术运算指令   4 逻辑运算指令   5 移位操作指令   6 位操作指令   7 比较运算指令   8 循环指令   9 转移指令   10 条件设置字节指令   11 字符串操作指令   12 ASCII-BCD码调整指令   13 处理器指令  5.3 习题 第6章 程序的基本结构  6.1 程序的基本组成   1 段的定义   2 段寄存器的说明语句   3 堆栈段的说明   4 源程序的结构  6.2 程序的基本结构   1 顺序结构   2 分支结构   3 循环结构  6.3 段的基本属性   1 对齐类型   2 组合类型   3 类别   4 段组  6.4 简化的段定义   1 存储模型说明伪指令   2 简化段定义伪指令   3 简化段段名的引用  6.5 源程序的辅助说明伪指令   1 模块名定义伪指令   2 页面定义伪指令   3 标题定义伪指令   4 子标题定义伪指令  6.6 习题 第7章 子程序和库  7.1 子程序的定义  7.2 子程序的调用和返回指令   1 调用指令   2 返回指令  7.3 子程序的参数传递   1 寄存器传递参数   2 存储单元传递参数   3 堆栈传递参数  7.4 寄存器的保护与恢复  7.5 子程序的完全定义   1 子程序完全定义格式   2 子程序的位距   3 子程序的语言类型   4 子程序的可见性   5 子程序的起始和结束操作   6 寄存器的保护和恢复   7 子程序的参数传递   8 子程序的原型说明   9 子程序的调用伪指令   10 局部变量的定义  7.6 子程序库   1 建立库文件命令   2 建立库文件举例   3 库文件的应用   4 库文件的好处  7.7 习题 第8章 输入输出和中断  8.1 输入输出的基本概念   1 I/O端口地址   2 I/O指令  8.2 中断   1 中断的基本概念   2 中断指令   3 中断返回指令   4 中断和子程序  8.3 中断的分类   1 键盘输入的中断功能   2 屏幕显示的中断功能   3 打印输出的中断功能   4 串行通信口的中断功能   5 鼠标的中断功能   6 目录和文件的中断功能   7 内存管理的中断功能   8 读取和设置中断向量  8.4 习题 第9章 宏  9.1 宏的定义和引用   1 宏的定义   2 宏的引用   3 宏的参数传递方式   4 宏的嵌套定义   5 宏与子程序的区别  9.2 宏参数的特殊运算符   1 连接运算符   2 字符串整体传递运算符   3 字符转义运算符   4 计算表达式运算符  9.3 与宏有关的伪指令   1 局部标号伪指令   2 取消宏定义伪指令   3 中止宏扩展伪指令  9.4 重复汇编伪指令   1 伪指令REPT   2 伪指令IRP   3 伪指令IRPC  9.5 条件汇编伪指令   1 条件汇编伪指令的功能   2 条件汇编伪指令的举例  9.6 宏的扩充   1 宏定义形式   2 重复伪指令REPEAT   3 循环伪指令WHILE   4 循环伪指令FOR   5 循环伪指令FORC   6 转移伪指令GOTO   7 宏扩充的举例   8 系统定义的宏  9.7 习题 第10章 应用程序的设计  10.1 字符串的处理程序  10.2 数据的分类统计程序  10.3 数据转换程序  10.4 文件操作程序  10.5 动态数据的编程  10.6 COM文件的编程  10.7 驻留程序  10.8 程序段前缀及其应用   1 程序段前缀的字段含义   2 程序段前缀的应用  10.9 习题 第11章 数值运算协处理器  11.1 协处理器的数据格式   1 有符号整数   2 BCD码数据   3 浮点数  11.2 协处理器的结构  11.3 协处理器的指令系统   1 操作符的命名规则   2 数据传送指令   3 数学运算指令   4 比较运算指令   5 超越函数运算指令   6 常数操作指令   7 协处理器控制指令  11.4 协处理器的编程举例  11.5 习题 第12章 汇编语言和C语言  12.1 汇编语言的嵌入  12.2 C语言程序的汇编输出  12.3 一个具体的例子  12.4 习题 附录
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

yyysec

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值