ShuangChenYue ShuangChenYue
首页
  • Cpp之旅
  • Cpp专栏
  • Effective_CPP
  • muduo网络库
  • Unix环境高级编程
  • Cpp提高编程
  • 计算机网络
  • 操作系统
  • 数据结构
  • Linux
  • 算法
  • 基础篇
  • MySql
  • Redis
  • 电子嵌入式通信协议
  • 深入浅出SSD
  • 文件系统
  • 汇编语言
  • STM32
  • 随笔(持续更新)
  • Git知识总结
  • Git 创建删除远程分支
  • nvm使用小结
  • 虚拟机固定 IP 地址
  • Shell 脚本学习笔记
  • VScode 插件 CodeGeeX 使用教程
  • KylinV10 将项目上传至 Github教程
  • KylinV10 安装 MySQL 教程(可防踩雷)
  • kylinV10-SP1 安装 QT
  • 高并发内存池
  • USBGUARD 项目编译环境配置
  • Power_Destory 项目
  • U 盘清除工具编译教程
  • 个人博客代码推送教程
  • HTML与CSS
  • JS学习
  • Vue3入门
  • Vue3进阶
  • 黑马Vue3
  • MFC编程随记
  • MFC实现ini配置文件的读取
  • MFC实现点击列表头排序
  • 贴图法美化Button按钮
  • 如何高效阅读嵌入式项目代码
  • NAND Flash
  • ARM 处理器
  • 嵌入式基础知识-存储器
  • 闪存存储和制造技术概述
  • 芯片IO驱动力
  • 主流先进封装技术介绍
  • 虎牙C++技术面经
  • 金山一面复习
  • 完美世界秋招 C++ 游戏开发面经(Cpp部分)
  • 博客搭建
  • 网站收藏箱
首页
  • Cpp之旅
  • Cpp专栏
  • Effective_CPP
  • muduo网络库
  • Unix环境高级编程
  • Cpp提高编程
  • 计算机网络
  • 操作系统
  • 数据结构
  • Linux
  • 算法
  • 基础篇
  • MySql
  • Redis
  • 电子嵌入式通信协议
  • 深入浅出SSD
  • 文件系统
  • 汇编语言
  • STM32
  • 随笔(持续更新)
  • Git知识总结
  • Git 创建删除远程分支
  • nvm使用小结
  • 虚拟机固定 IP 地址
  • Shell 脚本学习笔记
  • VScode 插件 CodeGeeX 使用教程
  • KylinV10 将项目上传至 Github教程
  • KylinV10 安装 MySQL 教程(可防踩雷)
  • kylinV10-SP1 安装 QT
  • 高并发内存池
  • USBGUARD 项目编译环境配置
  • Power_Destory 项目
  • U 盘清除工具编译教程
  • 个人博客代码推送教程
  • HTML与CSS
  • JS学习
  • Vue3入门
  • Vue3进阶
  • 黑马Vue3
  • MFC编程随记
  • MFC实现ini配置文件的读取
  • MFC实现点击列表头排序
  • 贴图法美化Button按钮
  • 如何高效阅读嵌入式项目代码
  • NAND Flash
  • ARM 处理器
  • 嵌入式基础知识-存储器
  • 闪存存储和制造技术概述
  • 芯片IO驱动力
  • 主流先进封装技术介绍
  • 虎牙C++技术面经
  • 金山一面复习
  • 完美世界秋招 C++ 游戏开发面经(Cpp部分)
  • 博客搭建
  • 网站收藏箱
  • 电子嵌入式通信协议

  • 深入浅出SSD

  • 文件系统

  • 汇编语言

    • 第1章 基础知识
    • 第2章 寄存器
      • 2.1 同用寄存器
      • 2.2 物理地址
      • 2.3 8086 CPU 给出物理地址的方法
      • 2.4 段的概念
      • 2.5 段寄存器
      • 2.6 CS 和 IP
      • 2.7 总结
      • 2.8 Debug
    • 第3章 寄存器(内存访问)
    • 第4章 第一个程序
    • 第5章 [BX]和loop指令
    • 第6章 包含多个段的程序
    • 第7章 更灵活的定位内存地址的方法
    • 第8章 数据处理的两个基本问题
  • STM32

  • 嵌入式软件开发
  • 汇编语言
霜晨月
2024-07-24
目录

第2章 寄存器

# 第2章 寄存器

一个 CPU 由运算器,控制器,寄存器等器件构成,这些器件靠内部总线进行相连。简单的说 CPU 中:

  • 运算器进行信息处理
  • 寄存器进行信息存储
  • 控制器控制各种器件进行工作
  • 内部总线连接各个器件,在他们之间进行各种数据的传送

寄存器是 CPU 中程序员可以用指令读写的部件,程序员可以通过改变各种寄存器的内容实现对 CPU 的控制

8086CPU 由14个寄存器:AX,BX,CX,DX,SI,DI,SP,BP,IP,CS,SS,DS,ES,PSW

  • 外部总线:相对于 CPU 内部而言是外部总线,实现 CPU 和主板上其他器件的联系。
  • 内部总线:实现 CPU 内部各个器件之间的联系。

# 2.1 同用寄存器

8086CPU 的所有寄存器都是16位,可以存放两个字节。AX,BX,CX,DX 这4个通用寄存器,每一个寄存器可以分为两个可独立使用的8位寄存器来使用。

以 AX 为例:寄存器的逻辑结构如图 2.1 所示:

图2.1

  • AX 可以分为 AH 和 AL
  • BX 可以分为 BH 和 BL
  • CX 可以分为 CH 和 CL
  • DX 可以分为 DH 和 DL

以 AX 为例:8086CPU 的16位寄存器分为两个8位寄存器的情况如图 2.3 所示:

图 2.3

AX 的低8位(0位~7位)构成了 AL 寄存器,高8位(8位~15位)构成了 AH 寄存器。

图2.4 展示16位寄存器及其所分成的两个8位寄存器的数据存储情况:

图2.4

# 2.2 物理地址

CPU 访问内存单元,要给出内存单元的地址。每一个内存单元在这个空间中都有一个唯一的地址,我们将这个唯一的地址称之为物理地址

# 2.3 8086 CPU 给出物理地址的方法

image

  1. CPU 中的相关部件提供两个16位地址,一个称之为段地址,一个称之为偏移地址
  2. 段地址和偏移地址通过内部总线送入一个称之为地址加法器的部件
  3. 地址加法器将两个16位地址合成一个20位的物理地址
  4. 地址加法器通过内部总线将20位物理地址送入到输入和输出控制电路
  5. 输入和输出控制电路将20 位物理地址送上地址总线
  6. 20位物理地址被地址总线传送到存储器

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

例如:8086CPU 要访问地址为 123C8H 的内存单元,地址加法器的工作过程如图2.7所示:

图2.7

image

# 2.4 段的概念

在编程时可以根据需要,将若干地址连续的内存单元看作一个段。偏移地址位16位,16位地址的最大寻址能力位 64KB,所以要给段的长度最大位 64KB

# 2.5 段寄存器

段寄存器:CS、DS、SS、ES

CS:代码段寄存器

IP:指令指针寄存器

# 2.6 CS 和 IP

  • CS:代码段寄存器;
  • IP:指令指针寄存器。

假设 CS 中的内容为 M,IP 中内容为 N,8086CPU 将从内存 M✖16+N 单元开始,读取一条指令并执行

在 8086PC 机中,任意时刻,CPU 将 CS: IP 指向内存单元中的内容看作指令

# 2.7 总结

  • CS 存放指令的段地址,IP 存放指令的偏移地址,任意时刻,CPU 将 CS: IP 指向内容当作指令的执行
  • CPU 工作的流程:
  • 从 CS: IP 指向内存单元读取指令,读取的指令进入指令的缓冲器
  • IP = IP + 所读取指令的长度,从而指向下一条指令
  • 执行指令。

image

# 2.8 Debug

  • R 命令查看、改变 CPU 寄存器的内容
  • D 命令查看内存中的内容
  • E 命令改写内存中的内容
  • U 命令将内存中的机器指令翻译成汇编指令
  • T 命令执行一条机器指令
  • A 命令已汇编指令的格式在内存中写入一条机器指令
第1章 基础知识
第3章 寄存器(内存访问)

← 第1章 基础知识 第3章 寄存器(内存访问)→

Theme by Vdoing | Copyright © 2023-2024 霜晨月
  • 跟随系统
  • 浅色模式
  • 深色模式
  • 阅读模式