博客
关于我
强烈建议你试试无所不能的chatGPT,快点击我
寄存器知识点
阅读量:6348 次
发布时间:2019-06-22

本文共 1004 字,大约阅读时间需要 3 分钟。

  在CPU中: 运算器进行信息处理;寄存器进行信息存储;控制器控制各种器件进行工作;内部总线连接各种器件,在它们之间进行数据的传送。

  8086CPU中有14个寄存器,每个寄存器有一个名称:AX、BX、CX、DX、SI、DI、SP、BP、IP、CS、SS、DS、ES、PSW。所有寄存器都是16位的,可以存放两个字节。AX可以分为AH和AI;BX可以分为BH和BL;CX可以分为CH和CL;DX可以分为DH和DL;

  8086CPU可以一次性处理字节(byte)和字(word)两种尺寸的数据。

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

  CPU访问内存单元时,要给出内存单元的地址。所有的内存单元构成存储空间是一个一维的线性空间,每个内存单元在这个空间汇总都有唯一的地址,简称:物理地址‘

  CPU通过地址总线送入存储器的,必须是一个内存单元的物理地址。

  在8086内存,能一次性处理、传输、暂时存储的信息的最大长度是16位的。内存单元的地址在送上地址总线之前,必须在CPU中处理、传输、暂时存放。

  8086CPU有20位地址总线,可以传送20位地址,达到1MB寻址能力。其采用一种在内部用两个16位地址合成的方法来形成一个20位的物理地址。

  CPU中的相关部件提供两个16位的地址,一个成为段地址,另一个称为偏移地址。

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

  段地址*16必然是16的倍数,所以一个段的起始地址也一定是16的倍数。偏移地址位16,16位地址的寻址能力为64KB,所以一个段的长度最大位64KB。

  CPU可以用不同的段地址和偏移地址形成同一个物理地址。偏移地址16位,变化范围为0-FFFFH。

  CS和IP是8086CPU中两个最关键的寄存器,它们指示了CPU当前要读取指令的地址。CS位代码段寄存器,IP位指令指针寄存器。设CS中的内容为M,IP中的内容为N,8086CPU将从内存M*16+N单元开始,读取一条指令并执行。

  “jmp段地址:偏移地址”指令功能为:用指令中给出的段地址修改CS,偏移地址修改IP。

  CPU只认被CS:IP指向的内存单元中的内容为指令。所以,要让CPU执行我们放在代码段中的指令,必须要将CS:IP指向所定义的代码段中的第一条指令的首地址。

转载于:https://www.cnblogs.com/smallblog/p/9766170.html

你可能感兴趣的文章
思科表态反对网络中立
查看>>
《HTML5+CSS3网页设计入门必读》——1.5 利用多种Web浏览器执行测试
查看>>
Velocity官方指南-容器
查看>>
国家为何如此重视石墨烯?
查看>>
《Python和Pygame游戏开发指南》——1.14 配套网站上的更多信息
查看>>
Kafka+Flink 实现准实时异常检测系统
查看>>
利用mybatis查询两级树形菜单
查看>>
《慕客网:IOS基础入门之Foundation框架初体验》学习笔记 <一>
查看>>
Spring声明式事务管理之二:核心接口API
查看>>
解决:在微信中访问app下载链接提示“已停止访问该网页”
查看>>
LNMP环境安装(二)
查看>>
MFC对话框编程-图片控件
查看>>
nodejs启动webserver服务
查看>>
小偷被抓叫嚣:我不偷警察没饭吃
查看>>
python初学—-实现excel里面读数据进行排序
查看>>
用户体验升级后 “谁行谁上”让百度Q4财报更有底气
查看>>
直播相关学习链接
查看>>
使用RPM包工具和源码包编译安装Linux应用程序
查看>>
VoIP——开启免费通话新时代的先锋
查看>>
Linux下rsync的用法
查看>>