【MCS-51】51单片机结构原理

news/2024/4/20 9:37:43/文章来源:https://blog.csdn.net/m0_61151031/article/details/130095984

至今为止,MCS-51系列单片机有许多种型号的产品:其中又分为普通型51(8031、8051、89S51)和增强型52(8032、8052、89S52等)。它们最大的区别在于存储器配置各有差异。下面我举例子的都是8051这一系列的单片机。

目录

8051单片机的构成

CPU

🐱计算器

🎈计算单元及其寄存器

🎈PSW寄存器

🐱控制器

ROM

RAM

🐍特殊功能寄存器SFR与寄存器

🐍RAM内部存储分布

🐍RAM外部存储区

IO口

🎂特殊引脚

🎂P3.x


8051单片机的构成

下面是51单片机的板内基本构成,其共分为8大模块和连接它们的系统总线。8大模块是:CPUROM(内部程序存储器)RAM(内部数据存储器)中断系统并行端口串行端口、计数器时钟电路。 

😀一、首先是CPU,8051是8位CPU,CPU由运算器和控制器组成,其中运算器ALU负责逻辑和二进制运算控制器负责翻译指令和协同单片机各模块有序工作

😀二、ROM,ROM是程序存储器,我们单片机的程序、原始的数据就存在这里。8051单片机片内有4KB空间的ROM。8051地址总线有16条,所以地址空间为0000H-FFFFH,而ROM的地址空间为0000H-0FFFH共有2^12=4096个地址。又因为8051的数据总线有8条,所以存储空间为4096*8=32768bit=4KB。

😀三、RAM,RAM为数据存储器,其共占256个字节单元,其中高128位为21个特殊功能寄存器SFR,低128位为供给用户使用

😀四、定时器和计数器,8051有2个16位的定时器。

😀五、并行I/O口,8051片内有4个8位的并行IO口,他们可用于输入(input)和输出(ouput)。这八个IO口为P0、P1、P2、P3。

  1. P0口用作8位数据总线低8位的地址总线的数据传输;
  2. P1口常用作一般数据IO口
  3. P2口常用作高8位地址总线数据传输;
  4. P3口常用作特殊功能的输入输出。

😀六、串行串口,单片机有2个1位的串行串口,其中包含输出口TXD和输入口RXD,可用作执行串口通信的模式。

😀七、中断控制,MSC-51有5个中断,包含2个外部中断源、1个串行中断源和2个定时器中断源。中断可以将正在执行的程序挂起而执行其它功能后再回来执行该程序。

😀八、扩展部分,如果片内空间不够,我们还可以扩展64KB的片外ROM和64KB的片外RAM。

CPU

🐱计算器

🎈计算单元及其寄存器

前面说过,CPU的组成部件大概是运算器和控制器。

首先是运算器,运算器是进行算术运算(加减乘除等运算)、逻辑运算(取反、抑或、与非等运算)和位操作等操作的。

其中我们的操作的结果状态都会被存到状态寄存器PSW中。

其中运算器组成由算数运算单元ALU、8位的数据累加器ACC、8位的寄存器B、8位的程序状态寄存器PSW、8位暂存器TMP1、TMP2组成:

 其中ALU负责完成传过来的数字的运算,然后将运算结果的状态传输给PSW寄存器,并且将运算结果传送给ACC(简称A),所以A就是我们数据进出ALU计算单元的守门员。然后还有B寄存器,B寄存器一般用于乘法、除法高字节运算时放除数或者余数。其余时刻可做通用寄存器使用。

🎈PSW寄存器

PSW寄存器是一个8位寄存器,它会存放着我们ALU计算后的结果的状态。我们看看它里面8位分别会存储什么信息:

我们可以看到其8个位中有7个已经有存储信息的作用了(下面1默认为有):

D7是存储的是运算时是否向最高位借位/进位了;

D6存储的是计算时低4位是否有向高四位借位/进位了;

D5为用户标志位;

D4和D3为工作寄存器选择标准位,通过改变这两个位数可以挑选我们RAM中的4个工作寄存器。

D2溢出标志位,如果结果超过8位数的表达范围,则被置为1;

D1未定义;

D0奇偶校验位,如果计算结果有奇数个1则为1,反之则为0。

🐱控制器

接下来我们来看看控制器,控制器的功能是对指令进行译码,然后将指令对应的工作分发下去。其中与这些功能实现有关的部件有:

时钟发生器指令地址寄存器IR指令译码器ID数据指针DPTR程序计数器PC堆栈指针SP等。 

其中IR就是负责将指令暂存起来,交给ID翻译出对应的指令后就通过控制的电路将控制信号发送出去给各执行部件。ID负责将指令翻译成对应的操作。而程序寄存器PC负责存储即将执行的下一个指令的地址,每当我们执行完一个指令后PC会自动加一。因为PC没有地址,所以用户本身无法对PC进行访问,但可以通过某些指令修改其内容,因为地址总线有16根,所以自然而然PC就是一个16位的寄存器。

而对于SP,SP是专门寄存堆栈存储位置地址的寄存器。最后的DPTR由两部分组成,包括低8位的DPL寄存器和高8位的DPH寄存器,其功能是专门用来存储片外RAM数据的地址寄存器


MCS-51的存储部分共分为两部分四块,片内的ROM和片外的ROM,片内的RAM和片外的RAM。其中片内的ROM大小为4KB,片外ROM大小为64KB,片内RAM大小为256B,片外RAM大小为64KB。

ROM

ROM的作用是存储用户编好的程序,内部ROM大小为4KB,因为PC位数是16,所以可以扩展到64KB的寻址空间。

对于ROM来说,它会有一个EA描述,当EA=1时,单片机内外都会用统一的地址,片内0-4KB地址范围为000H-FFFH,而新扩展的片外RAM地址为1000-FFFFH,舍弃片外0-4KB间的空间。而当EA=0时,只能执行片外的ROM程序,舍弃片内0-4KB的空间,此时地址为0000H-FFFFH

左边EA=1,右边EA=0

 而ROM本身就存储了很多程序入口,即存在许多具有特殊功能的单元,下图为一些特殊功能单元的位置,其中包括1个复位后的PC指向位置和6个中断执行的地址位置,这些位置注意不要占用。由于复位后下一条指令会在0000H处。所以我们一般汇编代码第一句就会在此处写一个跳转指令跳转到主程序的入口。

RAM

🐍特殊功能寄存器SFR与寄存器

MCS-51有32个工作寄存器(00H-01FH),它们共分为四个组,每个组有8个通用寄存器(R0-R7)。前面PSW中的状态位RS1RS0就是用来确定由哪个组的寄存器们工作,并且每一个时刻只能由一个组的寄存器来工作。其中R0和R1除了做工作寄存器外还会做间接寻址的地址指针

而除了平常我们用到的工作寄存器外,还有一些特殊功能寄存器分布在80H-FFH中,共占据高128个字节的存储工具,其中地址能够被8整除的SFR都能够进行位寻址

🐍RAM内部存储分布

上图为RAM中256字节存储分布,其中共分为4大部分:工作寄存器区位寻址区通用RAM区SFR区。 

🦁工作寄存器区

其中工作寄存器区00H-01FH共存放32个寄存器,一旦某一组被确定是工作寄存器后,其内部就会根据地址高低按字节为单位划分出R0-R7,8个通用寄存器,就可以被寻址访问。那么另外三组原先占据的位置就可以被我们用来读写。

🦁位寻址区

位寻址区位于20H-2FH之间,它占了16个字节的存储单位,这个区的地址单元除了原来的字节操作以外还可以进行位操作。

🦁用户区

在位操作区上面、专用寄存器区下面(30H-7FH)还有一个区被称为用户区,这个区用来存放数据运算的结果的。但是我们可以选择作为用户区的空间不止这里,我们还可以选择没有用到的工作寄存器的位置作为用户区使用。

🦁堆栈区

在这些区之外,我们还可以开一个堆栈区,人为地去设计一个堆栈结构。而这个堆栈结构一般我们选取在用户区比较靠后的位置。有了堆栈区之后,我们就可以在其内部写入中断操作和子程序了。特别值得注意的一点是:一般我们会选择先将堆栈指针加加之后再往其指向的内部存储空间放入数据。设置堆栈区的一个重要的功能就是保护断点和保护现场。当我们执行中断操作时,我们需要中断结束后继续返回原程序执行,这就是保护断点;而保护现场是指当我们主程序和中断程序用到同一个寄存器,那么我们中断服务函数会提前将其放入堆栈区中。

🦁SFR

SFR又称为特殊功能寄存器,这个位置存放的寄存器也就是我们在CPU的控制部分、运算部分、IO部分等等地方用到的寄存器,那些寄存器就来自此处。其中SFR中地址能被8整除的都被被位寻址。

我们常见的SFR特殊寄存器就包括:累加器A、寄存器B、PSW寄存器、PC、SP、DPTR、SBUF、IP、IE等等。

在我们进行复位时,单片机内位寻址区即20H-2FH的标志位状态不会变,而特殊功能寄存器SFR和工作寄存器R0-R7会被清0。

🐍RAM外部存储区

对于RAM的外部存储区,我们需要注意外部RAM最大可扩容到64KB,并且对于外部的数据存储器来说。数据区和外扩IO口是统一进行编址的,所以我们要保证RAM和IO口的端口地址分配合理,以此保证译码唯一。

IO口

IO口是单片机输入或者输出的通道,8051有32个并行的IO口,分别为P0.x、P1.x、P2.x和P3.x。这些引脚除了可以作为通用引脚外还可自动切换为数据总线、地址总线和控制总线的外部引脚。

 上面除了IO引脚以外,还有几个特殊的引脚。

🎂特殊引脚

特殊的引脚首先是VCCGND,它们分别是驱动电压和接地,一般驱动电压是5V。

XTAL2、XTAL1分别连接晶体震荡器的信号输出和晶体振荡器的信号输入,需要外接一个震荡电路,这震荡信号可以帮助设置单片机时钟:

 ALE/PROG是地址锁存信号端;

PSEN是外部程序存储器读取信号端;

EA/Vpp是程序存储器选择信号端和编程电源信号输入端,就是我们之前控制访问外部ROM时地址是在原来内部ROM的地址基础上扩展还是舍弃内部ROM直接全部采用外部ROM;

RST/VPD是复位端,通常接复位电路;

🎂P3.x

对于P3.x口来说它会和其它引脚不同,自然它可以作为IO口进行输入和输出,但是它支持的第二功能更加丰富:

P3.0--RXD串行数据输入口;

P3.1--TXD串行数据输出口;

P3.2--INT0外部中断0;

P3.3--INT1外部中断1;

P3.4--T0定时/计数器0外部计数脉冲输入端;

P3.5--T1定时/计数器1外部计数脉冲输入端;

P3.6--WR片外RAM写选信号输出端;

P3.7--WR片外RAM读选信号输出端;

本文来自互联网用户投稿,该文观点仅代表作者本人,不代表本站立场。本站仅提供信息存储空间服务,不拥有所有权,不承担相关法律责任。如若转载,请注明出处:http://www.luyixian.cn/news_show_103508.aspx

如若内容造成侵权/违法违规/事实不符,请联系dt猫网进行投诉反馈email:809451989@qq.com,一经查实,立即删除!

相关文章

STM32-HAL-定时器(无源蜂鸣器的驱动)

文章目录 一、蜂鸣器的介绍二、常用的无源蜂鸣器的电路三、测试准备四、初始化片上外设4.1 初始化定时器4的通道2为PWM输出模式4.2 编写驱动代码4.3 Logic分析仪查看波形4.4 代码分析 一、蜂鸣器的介绍 有源蜂鸣器: 有源蜂鸣器内部有一个发声电路,也就是“源”&…

数据湖Iceberg-Hive集成Iceberg(3)

文章目录 Hive集成Iceberg环境准备Hive与Iceberg的版本对应关系如下上传jar包,拷贝到Hive的auxlib目录中修改hive-site.xml,添加配置项启动 HMS 服务启动 Hadoop 创建和管理 Catalog默认使用 HiveCatalog指定 Catalog 类型使用 HiveCatalog使用 HadoopCa…

C++学习记录——이십 map和set

文章目录 1、setmultiset 2、map3、map::operator[] 1、set vector/list/deque等是序列式容器,map,set是关联式容器。序列式容器的特点就是数据线性存放,而关联式容器的数据并不是线性,数据之间有很强的关系。 它们的底层是平衡…

在当前互联网行情下,Android想转音视频开发,会有前景吗?

前言 近年来,由于三年疫情的影响,很多公司都开始陆陆续续的在裁员,Android开发工作岗位也是,可能有些从事Android开发的朋友还没有意识到,Android开发岗位正在变少,求职者,僧多粥少&#xff0c…

视频大文件传输的演变:从“卷轴男孩”到自动化

200年前,从纽约市到英国伦敦的单程旅行需要乘坐一艘跨大西洋轮船将近三周——如果你能负担得起的话,那就是。那些不能在满是汗水、狭窄的帆船上安顿大约一个半月的人。 今天,视频专业人士能够在几小时甚至几分钟内跨越相同的物理距离传输大量…

《用于估计血压变化的光电体积描记图和心电图的特征》阅读笔记

目录 一、摘要 二、十大问题 Q1论文试图解决什么问题? Q2这是否是一个新的问题? Q3这篇文章要验证一个什么科学假设? Q4有哪些相关研究?如何归类?谁是这一课题在领域内值得关注的研究员? Q5论文中提…

微信小程序第五节——登录那些事儿(超详细的前后端完整流程)

📌 微信小程序第一节 ——自定义顶部、底部导航栏以及获取胶囊体位置信息。 📌 微信小程序第二节 —— 自定义组件 📌 微信小程序第三节 —— 页面跳转的那些事儿 📌 微信小程序第四节—— 网络请求那些事儿 😜作 …

MFC之CRect详解

2023年4月25日,周二晚上。 今天查了不少关于CRect类及其相关内容的资料,学到了不少东西,所以我决定写一篇详细的关于CRect类及其相关内容的文章,以记录今天所学。 CRect类 在 MFC 中,CRect 类表示一个矩形区域。它是…

linux 命令之 tar -czvf和 tar -xzvf

文章目录 一、概述:二、基础知识 一、概述: tar 用于linux 系统中压缩和解压 二、基础知识 tar常用命令参数说明 tar命令的czvf/xzvf参数分别代表的意义如下: -c 或–create 建立新的备份文件。 -x或–extract或–get 从备份文件中还原文件…

SparkStreaming学习之——无状态与有状态转化、遍历kafka的topic消息、WindowOperations

目录 一、状态转化 二、kafka topic A→SparkStreaming→kafka topic B (一)rdd.foreach与rdd.foreachPartition (二)案例实操1 1.需求: 2.代码实现: 3.运行结果 (三)案例实操2 1.需求: 2.代码实现: 3.运行结果 三、W…

Eclipse代码提示突然失灵的解决方案

不知道改动了啥,突然间Eclipse的代码提示就失效了,发现缺少后极不方便。 使用快捷键:Alt/ 提示 No Default Proposals 为什么使用快捷键:Alt/ 会提示“No Default Proposals。”呢? 网上提示可能是热键冲突 但是一套…

数据可视化大屏电商数据展示平台开发实录(Echarts柱图曲线图、mysql筛选统计语句、时间计算、大数据量统计)

数据可视化大屏电商数据展示平台 一、前言二、项目介绍三、项目展示四、项目经验分享4.1 翻牌器4.1.1 翻牌器-今日实时交易4.1.2.翻牌器后端统计SUM函数的使用 4.2 不同时间指标的数据MySql内部的时间计算 4.3 实时交易播报MySql联表查询和内部遍历循环 4.4 每日交易量4.4.1.近…

5.5 高斯型求积公式简历

学习目标: 我会按照以下步骤学习高斯求积公式简介: 理解积分的概念:学习什么是积分以及积分的几何和物理意义,如面积、质量、电荷等概念。 掌握基本的积分技巧:掌握基本的积分公式和技巧,如换元法、分部积…

流辰信息微服务平台:数字化转型的优良工具!

在互联网迅猛发展的今天,越来越多的企业倾向于新兴领域带来的便利性和灵活性了,其中,微服务平台就是其中之一了。流辰信息微服务平台是专注于研发系统开发、数据治理、数据分析的平台,致力于为各中大小型企业提供优质的微服务解决…

Java——字符串的排列

题目链接 牛客网在线oj题——字符串的排列 题目描述 输入一个长度为 n 字符串,打印出该字符串中字符的所有排列,你可以以任意顺序返回这个字符串数组。 例如输入字符串ABC,则输出由字符A,B,C所能排列出来的所有字符串ABC,ACB,BAC,BCA,CBA和CAB。 数…

打造卓越游戏 | 2023 Google 游戏开发者峰会

一款游戏从初始构想的开发到辉煌赛季的策划,开发者们每时每刻都在倾注心血潜心钻研,Google 也致力于在整个开发和发布生命周期中为您提供帮助。我们很高兴能在今年如约而至的 Google 游戏开发者峰会中与您分享诸多更新,展示我们为助力您打造精…

如何有效的开展接口自动化测试,一篇就行

一、简介 接口自动化测试是指使用自动化测试工具和脚本对软件系统中的接口进行测试的过程。其目的是在软件开发过程中,通过对接口的自动化测试来提高测试效率和测试质量,减少人工测试的工作量和测试成本,并且能够快速发现和修复接口错误&…

PCL点云库(2) — IO模块

目录 2.1 IO模块接口 2.2 PCD数据读写 (1) PCD数据解析 (2)PCD文件读写示例 2.3 PLY数据读写 (1)PLY数据解析 (2)PLY文件读写示例 2.4 OBJ数据读写 (1&#xff…

C语言指针2大问题:指针类型有什么用?指针如何运算?

如题,本篇博客主要解决2个疑点:指针类型的用处,指针如何运算。 1.指针类型 C语言中的指针类型,在X86环境下大小是4个字节,在X64环境下大小是8个字节。既然指针的大小和指针类型无关,那么指针类型究竟有什么…

银行系统【GUI/Swing+MySQL】(Java课设)

系统类型 Swing窗口类型Mysql数据库存储数据 使用范围 适合作为Java课设!!! 部署环境 jdk1.8Mysql8.0Idea或eclipsejdbc 运行效果 ​​​​​​​ 本系统源码地址:​​​​​​​https://download.csdn.net/download/qq_50…