当前位置: 首页 > news >正文

【汇编语言】寄存器(CPU工作原理)(六)—— 修改CS,IP的指令以及代码段

在这里插入图片描述

文章目录

  • 前言
  • 1. 修改CS、IP的指令
  • 2. 问题分析:CPU运行的流程
  • 3. 代码段
  • 小结
  • 结语

前言

📌

汇编语言是很多相关课程(如数据结构、操作系统、微机原理)的重要基础。但仅仅从课程的角度出发就太片面了,其实学习汇编语言可以深入理解计算机底层工作原理,提升代码效率,尤其在嵌入式系统和性能优化方面有重要作用。此外,它在逆向工程和安全领域不可或缺,帮助分析软件运行机制并增强漏洞修复能力。

本专栏的汇编语言学习章节主要是依据王爽老师的《汇编语言》来写的,和书中一样为了使学习的过程容易展开,我们采用以8086CPU为中央处理器的PC机来进行学习。

文章主要内容:修改CS、IP的指令以及代码段的学习

1. 修改CS、IP的指令

在CPU中,程序员能够用指令读写的部件只有寄存器,程序员可以通过改变寄存器中的内容实现对CPU的控制。

CPU从何处执行指令是由CS、IP中的内容决定的,程序员可以通过改变CS、IP中的内容来控制CPU执行目标指令。

我们如何改变CS、IP的值呢?

显然,8086CPU必须提供相应的指令。我们如何修改AX中的值?可以用mov指令,如mov ax, 123将ax中的值设为 123,显然,我们也可以用同样的方法设置其他寄存器的值,如mov bx, 123mov cx, 123mov dx, 123等。其实,8086CPU大部分寄存器的值,都可以用mov指令来改变,mov指令被称为传送指令

但是,mov指令不能用于设置CS、IP的值,原因很简单,因为8086CPU没有提供这样的功能。8086CPU为CS、IP提供了另外的指令来改变它们的值。能够改变CS、IP的内容的指令被统称为转移指令(我们以后会深入研究)。我们现在介绍一个最简单的可以修改CS、IP的指令:jmp指令

✍若想同时修改 CS、IP的内容,可用形如“jmp段地址:偏移地址”的指令完成,如

在这里插入图片描述

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

✍若想仅修改IP的内容,可用形如“jmp 某一合法寄存器”的指令完成,如

在这里插入图片描述

“jmp 某一合法寄存器”指令的功能为:用寄存器中的值修改IP。

jmp ax,在含义上好似:mov IP,ax。

❗❗❗注意,我们在适当的时候,会用已知的汇编指令的语法来描述新学的汇编指令的功能。采用一种“用汇编解释汇编”的方法来使读者更好地理解汇编指令的功能,这样做有助于读者进行知识的相互融会。要强调的是,我们是用“已知的汇编指令的语法”进行描述,并不是用“已知的汇编指令”来描述,比如,我们用mov IP,ax来描述jmp ax,并不是说真有 mov IP,ax这样的指令,而是用 mov指令的语法来说明jmp指令的功能。我们可以用同样的方法描述jmp 3:01B6的功能:jmp 3:01B6在含义上好似mov CS,3 mov IP,01B6

2. 问题分析:CPU运行的流程

内存中存放的机器码和对应的汇编指令情况如下图所示,设CPU初始状态:CS=2000H,IP=0000H,请写出指令执行序列。思考后看分析。

在这里插入图片描述

分析如下

在这里插入图片描述

3. 代码段

前面讲过,对于8086PC机,在编程时,可以根据需要,将一组内存单元定义为一个段。我们可以将长度为N(N≤64KB)的一组代码,存在一组地址连续、起始地址为16的倍数的内存单元中,我们可以认为,这段内存是用来存放代码的,从而定义了一个代码段。比如,将:

在这里插入图片描述

这段长度为10个字节的指令,存放在123B0H-123B9H的一组内存单元中,我们就可以认为,123B0H-123B9H这段内存是用来存放代码的,是一个代码段,它的段地址为123BH,长度为10个字节。

如何使得代码段中的指令被执行呢?

将一段内存当作代码段,仅仅是我们在编程时的一种安排,CPU并不会由于这种安排,就自动地将我们定义的代码段中的指令当作指令来执行。CPU 只认被CS:IP指向的内存单元中的内容为指令。所以,要让CPU执行我们放在代码段中的指令,必须要将CS:IP指向所定义的代码段中的第一条指令的首地址。对于上面的例子,我们将一段代码存放在123B0H~123B9H内存单元中,将其定义为代码段,如果要让这段代码得到执行,可设CS=123BH、IP=0000H。

小结

​ (1)段地址在8086CPU的段寄存器中存放。当8086CPU要访问内存时,由段寄存器提供内存单元的段地址。8086CPU有4个段寄存器,其中CS用来存放指令的段地址。

​ (2)CS存放指令的段地址,IP存放指令的偏移地址。

​ 8086机中,任意时刻,CPU将CS:IP指向的内容当作指令执行。

​ (3)8086CPU的工作过程:

​ ①从CS:IP指向的内存单元读取指令,读取的指令进入指令缓冲器
​ ②IP指向下一条指令
​ ③ 执行指令。(转到步骤①,重复这个过程)

​ (4)8086CPU提供转移指令修改CS、IP的内容。

结语

今天的分享到这里就结束啦!如果觉得文章还不错的话,可以三连支持一下。

也可以点点关注,避免以后找不到我哦!

Crossoads主页还有很多有趣的文章,欢迎小伙伴们前去点评,您的支持就是作者前进的动力!

在这里插入图片描述

http://www.lryc.cn/news/458779.html

相关文章:

  • 机器学习与神经网络:从技术前沿到诺贝尔奖的跨越与未来展望
  • java 洛谷题单【数据结构1-2】二叉树
  • 项目优化内容及实战
  • 科研绘图系列:R语言蝴蝶图(Butterfly Chart)
  • 【FPGA开发】Modelsim如何给信号分组
  • Apache SeaTunnel 9月份社区发展记录
  • 系统架构设计师:数据库系统相关考题预测
  • 污水排放口细粒度检测数据集,污-水排放口的类型包括10类目标,10000余张图像,yolo格式目标检测,9GB数据量。
  • c++(多态)
  • 【网络协议】TCP协议常用机制——延迟应答、捎带应答、面向字节流、异常处理,保姆级详解,建议收藏
  • 财政部官宣: 国家奖学金,涨了!
  • antd table合并复杂单元格、分组合并行、分组合并列、动态渲染列、嵌套表头
  • 一键安装与配置Stable Diffusion,轻松实现AI绘画
  • 模板和静态文件
  • Android Studio 打包aar丢失远程依赖问题解决
  • Chromium 搜索引擎功能浅析c++
  • DDoS攻击快速增长,如何在抗ddos防护中获得主动?
  • MongoDB 死锁 锁定问题
  • 鸿蒙--商品列表
  • 【Fargo】5:根据网络带宽动态调整发送速率
  • 入门C语言:从原码、反码、补码到位运算
  • 18770 差值最大
  • 【Flutter】合并多个流Stream
  • 【SQL学习笔记】
  • contact form 7设置方法与详细步骤
  • 第170天:应急响应-战中溯源反制对抗上线CSGoby蚁剑Sqlmap等安全工具
  • 5-容器管理工具Docker
  • OCR+PDF解析配套前端工具开源详解!
  • 【操作系统】引导(Boot)电脑的奇妙开机过程
  • 国产云桌面迁移对接信创AD域控方案