IT数码 购物 网址 头条 软件 日历 阅读 图书馆
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
图片批量下载器
↓批量下载图片,美女图库↓
图片自动播放器
↓图片自动播放器↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁
 
   -> 嵌入式 -> 汇编语言-寄存器 -> 正文阅读

[嵌入式]汇编语言-寄存器

寄存器

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

CPU由运算器、控制器、寄存器等器件构成,器件通过总线连接,第一章描述的地址、控制、命令总线对于CPU内部来说是外部总线,内部总线实现内部各器件连接
运算器进行信息处理
寄存器进行信息存储
控制器控制各器件工作
内部总线连接各种器件,在他们之间传输数据

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

通用寄存器

8086CPU的寄存器都是16位的,可以放两个字节
AX、BX、CX、DX通常用来存放一般性的数据,成为通用寄存器
为了兼容之前的8位机,将AX、BX、CX、DX拆成了AH、AL这种类型

字在寄存器中的存储

几条汇编指令

mov ax,00
mov al,88H
add al,88H
此时 al的值 = 10,ah的值= 0

88H+88H = 110H 产生的进位,并不会存储到ah寄存器中,因为两者是独立的
在进行数据传送和运算时,注意指令操作的对象的位数要保持一致
汇编程序在编写时,汇编指令或寄存器不区分大小写

物理地址

内存单元的地址 = 物理地址

16位结构的CPU

运算器一次最多可以处理16位的数据
寄存器的最大宽度为16位
寄存器和运算器之间的通路为16位

对于16位CPU能一次性处理,传输,暂时存储16位的地址

8086CPU给出物理地址的方法

8086单片机一次只能处理16位的数据,地址总线数量却是20寻址能力达到1MB
采用两个16位地址合成的方法来形成20位的物理地址

提供两个16位的地址,段地址,偏移地址
段地址和偏移地址通过内部总线送入一个成为地址加法器的部件
地址加法器将个16位地址合成来形成20位的物理地址
地址加法器通过内部总线将20位物理地址送入输入输出控制电路
输入输出控制电路将20位物理地址送入地址总线
20位物理地址被地址总线传送到寄存器

地址加法器过程描述

寻址123C8的内存单元
将123C8分为 = 段地址 1230  位地址 00C8
送入地址加法器
段地址 x 16 = 12300
段地址 + 位地址 = 123C8
地址加法器输出123C8

段地址X16+偏移地址 = 物理地址

偏移地址寻址的本质:用一个基础地址(段地址X16)和相对基础地址的偏移地址相加,当初内存单元的物理地址
段地址:SA
位地址:EA
CPU的段长度不能超过2^N

段的概念

段寄存器

8086有4个段寄存器:CS、DS、SS、ES

CS和IP

CS和IP是8086CPU最关键的寄存器
CS是代码段寄存器,IP为指令指针寄存器
在8086PC机中,任意时刻,设CS = M,IP = N,8086CPU将从内存Mx16+N单元开始,读取指令并执行
CPU将CS:IP指向的内容当作指令执行
通过CS和IP寻址内存空间,将内存中的指令读取回来到指令缓冲器,再由执行控制器执行,IP中的值自动增加,增加的长度 = 指令的长度

从CS:IP指向的内存单元读取指令,读取的指令接入指令缓冲器
IP = IP + 所读取指令的长度,从而指向下一条指令
执行指令

8086CPU启动或者复位后CS = FFFFH,IP = 0000H

修改CS、IP的指令

CPU中,程序员能用指令读写的部件只有寄存器,程序员可以通过改变寄存器中的内容实现对CPU的控制,CPU从何处执行指令是由CS,IP决定的,可以通过改变CS,IP内容控制CPU执行目标指令
mov指令不能用于设置CS、IP的值,MOV指令被称为传送指令
能够改变CS、IP的内容的指令统称为转移指令
jump 2AE3:3,执行后:CS = 2AE3, IP= 0003H,CPU将从2AE33H读取指令
仅想修改IP寄存器的内容,可以通过 jump 寄存器
如jump ax,将ax的值赋值给ip寄存器

段代码

  嵌入式 最新文章
基于高精度单片机开发红外测温仪方案
89C51单片机与DAC0832
基于51单片机宠物自动投料喂食器控制系统仿
《痞子衡嵌入式半月刊》 第 68 期
多思计组实验实验七 简单模型机实验
CSC7720
启明智显分享| ESP32学习笔记参考--PWM(脉冲
STM32初探
STM32 总结
【STM32】CubeMX例程四---定时器中断(附工
上一篇文章      下一篇文章      查看所有文章
加:2021-10-23 12:39:15  更:2021-10-23 12:40:06 
 
开发: C++知识库 Java知识库 JavaScript Python PHP知识库 人工智能 区块链 大数据 移动开发 嵌入式 开发工具 数据结构与算法 开发测试 游戏开发 网络协议 系统运维
教程: HTML教程 CSS教程 JavaScript教程 Go语言教程 JQuery教程 VUE教程 VUE3教程 Bootstrap教程 SQL数据库教程 C语言教程 C++教程 Java教程 Python教程 Python3教程 C#教程
数码: 电脑 笔记本 显卡 显示器 固态硬盘 硬盘 耳机 手机 iphone vivo oppo 小米 华为 单反 装机 图拉丁

360图书馆 购物 三丰科技 阅读网 日历 万年历 2024年11日历 -2024/11/26 6:41:19-

图片自动播放器
↓图片自动播放器↓
TxT小说阅读器
↓语音阅读,小说下载,古典文学↓
一键清除垃圾
↓轻轻一点,清除系统垃圾↓
图片批量下载器
↓批量下载图片,美女图库↓
  网站联系: qq:121756557 email:121756557@qq.com  IT数码