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

单片机原理

AT89S51单片机片内硬件结构

(  本节以AT89S51为例介绍51单片机的基本结构,如下图所示)

AT89S51单片机的片内结构,从图中可见 AT89S51单片机的基本组成:

1. CPU:8位的CPU 由控制器和运算器构成

2. 数据存储器(RAM):128B 用于存放读写数据、运算的中间结果

3. 程序存储器(ROM):4KB 用于存放用户程序、原始数据或表格

4. 4个8位的并行I/O口:P0~P3 用于数据的输入/输出

5. 1个全双工的异步串行口:UART 用于与其他设备间的串行数据传送

6. 中断系统: 具有5个中断源,2级中断优先级

7. 定时/计数器:有2个16位的T/C 可作为定时器也可作为计数器使用

8. 特殊功能寄存器:SFR 在80H~FFH地址区间内,离散地分布26个特殊功能寄存器

9. 看门狗定时器:WDT 可将单片机复位,使程序恢复正常运行

单片机的外部结构

   目前,51单片机多采用40引脚双列直插式(PDIP)封装形式。此外,还有44引脚塑料方型扁平式(TQFP)封装形式的芯片,如下图所示

AT89S51的引脚功能

40个引脚按其功能可分为4类:

1.电源引脚:Vcc(40脚):接+5V电源正端          

                     Vss(20脚):接+5V电源地端

2.时钟电路引脚:XTAL1(19脚):片内振荡器的反相放大器输入端

                            XTAL2(18脚):片内振荡器的反相放大器输出端。

3.并行I/O口引脚: 4个并行I/O口(P0~P3),每个口都有8个引脚,用于传送数据和地址  

4. 控制引脚

(1)RST(9脚):复位信号输入引脚,在该引脚出现2个机器周期以上的高电平,可使单片机复位。正常工作,此引脚应为≤ 0.5V的低电平

(2) PSEN(29脚):片外程序存储器读选通信号输出引脚,低电平有效

(3)ALE/PROG(30脚):低8位地址锁存控制信号输出引脚,低电平有效

         ① CPU访问外部程序存储器或外部数据存储器时,将低8位地址锁存在片外的地址锁存器中

         ② 单片机正常运行时,ALE端一直有正脉冲信号输出,此频率为时钟振荡器频率fosc的1/6

(4)EA/VPP(31脚):外部程序存储器访问允许控制信号输入引脚

AT89S51单片机存储器的结构

存储器分为两大类:

数据 存储器 (RAM):CPU在运行时,能随时对其进行数据的写入和读出。但在关闭电源时,其所存储的数据信息将丢失。它用来存放暂时性的输入输出数据、运算的中间结果

程序 存储器 (ROM):是一种写入信息后,不易改写的存储器。 断电后,ROM中的信息保留不变。用来存放固定的程序、原始的数据或表格等

AT89S51单片机的存储器有4个存储物理空间,具体如下图所示:

存储器中的每个存储单元是8位,每一个单元有一个地址编号,从0000H~FFFFH

~ROM和RAM分别在两个独立的空间,即分开编址

程序存储器(ROM)

1. 计算机的工作原理:计算机在工作时,CPU自动从程序存储器中逐条取出指令、分析指令,并根据指令的操作类型和操作对象执行指令,完成相应的操作。如此重复,直至执行完程序的所有指令,从而实现程序的基本功能,这就是微型计算机的基本工作原理

2.程序计数器PC: PC是CPU中的一个16位寄存器,用于存放CPU将要从ROM中读取的下一个指令字节码的地址,因此也称为地址指针;单片机复位后,PC的值为0000H,CPU从程序存储器0000H地址单元开始读取一个指令字节,并开始执行程序,同时PC+1→PC;依次进行,一次读取一个指令字节

3.片内与片外程序存储器的选择:

(1)EA引脚接高电平,EA接+5V

        ① 当PC值没有超出0FFFH时,只读取片内Flash存储器中程序

        ② 当PC值超出0FFFH时,CPU会自动转向读取片外程序存储器空间1000H~FFFFH内的程序

(2)EA引脚接低电平,EA接地

        CPU只根据PC值读取片外程序存储器(0000H~FFFFH)中的程序。不会读取片内4KB Flash存储器

4.程序存储器低端的几个特殊单元

程序存储器中几个低端的地址固定用作特定的入口地址

        0000H:单片机复位后的地址

        0003H:外部中断0的中断程序入口地址

        000BH:定时/计数器0溢出中断程序入口地址

        0013H:外部中断1的中断程序入口地址

        001BH:定时/计数器1溢出中断程序入口地址

        0023H:串行口的中断程序入口地址

数据存储器(RAM)

一、 片内数据存储器

AT89S51片内RAM 128字节(00H—7FH) AT89S52片内RAM 256字节(00H—FFH)

1.工作寄存器区

片内RAM前32个单元(00H—1FH)是4个工作寄存器区                                

4个工作 寄存器区:每个工作寄存器区有8个工作寄存器: R0、R1、R2、R3、R4、R5、R6、R7

注:当前工作寄存器区只能有一个

     当前工作寄存器的选择:首先由RS1,RS0选择工作寄存器区,然后确定工作寄存器对应的单元。 复位后,默认的工作寄存器区为0区

程序状态字寄存器PSW:

▼RS1(PSW.4)、RS0(PSW.3)工作寄存器区选择位

若在一个实际的单片机应用系统中,并不需要4个工作寄存器区,这个区域的多余单元可以作为一般的数据缓冲器使用

2. 位寻址区

片内RAM中,20H-2FH 这16个单元是位寻址区

这16个单元中共有128位, 每一位都有一个位地址

位地址空间:00H—7FH    

CPU对位寻址区内的RAM单元(20H~2FH):

1、既可以采用字节操作指令,整体操作某个字节

2、又可以采用位操作指令,直接对字节中的某一位进行操作

用途: 一般可用作程序运行标志、开关量控制以及位变量等

           这种位寻址能力是一般微机所不具备的,是单片机所独有的

位寻址区多余的RAM单元也可以作为一般的数据缓冲器使用

3.  数据缓冲区

地址:30H-7FH(30H-FFH)单元  

用途:存放各种读写数据和中间结果,起到数据缓冲的作用       

二、片外数据存储器

片内RAM不够用时,AT89S51最多可外扩64KB的片外RAM

注意:片外RAM和外扩的I/O接口是统一编址的,要注意地址分配的问题

特殊功能寄存器区

特殊功能寄存器区:80H~FFH的地址空间,只允许直接寻址SFR,26个特殊功能寄存器 离散地分布在80H~FFH的地址空间

特殊功能寄存器SFR(专用寄存器) 专用于控制、选择、管理、存放单片机内部各功能部件的工作方式、条件、状态、结果的寄存器

不同的SFR管理不同的功能部件,负责不同的功能——各司其职

换言之:要让单片机内部各功能部件实现预定的功能,很重要的一项工作就是对SFR写命令(编程)

AT89C51特殊功能寄存器位地址和字节地址表,如下图所示

注:字节地址尾数为0或8的特殊功能寄存器,每位都有位地址,可位操作

特殊功能寄存器每一位的定义和作用与单片机的各个部件直接相关

特殊功能寄存器详细用法在相应的章节进行说明

AT89S51的中央处理器(CPU)

组成:运算器+控制器

功能:从ROM中读取指令、分析指令并根据指令的操作类型和操作对象,控制各个功能部件执行指令

运算器

组成:算术逻辑单元ALU+有关寄存器

功能:进行数据的算术运算、逻辑运算、位操作运算以及数据传输等

专用寄存器

1.累加器A(E0H):是CPU中使用最频繁的一个8位寄存器。它既是ALU的输入数据源之一,同时又是ALU运算结果的存放单元之一;CPU中的数据传送大多都通过累加器A

2.通用寄存器B(F0H):用于乘、除法运算;若不作乘除法运算时,则可作为通用寄存器使用

3.程序状态字PSW(D0H):用于保存指令执行结果的状态信息,以供程序查询和判断

▼CY(PSW.7) 进位/借位标志位:若在执行某些算术运算类指令时,最高位发生了进位或借位,则CY=1,否则CY=0。它也是位处理器中的位累加器C,可用于位操作

▼AC(PSW.6) 辅助进位/借位标志位:若在执行某些算术运算类指令时,D3位向D4位发生了进位或借位,则AC=1,否则AC=0

▼F0(PSW.5) 用户自定义标志位:在编程时,用户可根据需要对F0赋予一定的含义,通过指令来使它置1或清0;也可由指令来测试该标志位,根据测试结果控制程序的流向

▼OV (PSW.2) 溢出标志位:当执行带符号8位二进制数(-128~+127)的某些算术运算类指令时,用来指示运算结果是否产生溢出(超出范围)。如果结果产生溢出,OV=1;否则,OV=0

▼P (PSW.0) 奇偶标志位:在指令执行完后,CPU根据累加器A中“1”的个数是奇数还是偶数自动给该标志位置1或清0。累加器A中“1”的个数为奇数:P=1;为偶数:P=0  

控制器 

组成:程序计数器(PC)、指令寄存器、指令译码器、定时控制逻辑电路等

功能:是整个单片机的控制中心;

           对内:控制指令的读入、译码和执行,从而对各功能部件进行定时和逻辑控制

           对外:发出ALE、PSEN等控制信号


http://www.kler.cn/a/272402.html

相关文章:

  • 【AI | pytorch】torch.view_as_complex的使用
  • 【Linux系统编程】—— 深入理解Linux中的环境变量与程序地址空间
  • Google地图瓦片爬虫
  • ubuntu18.04开发环境下samba服务器的搭建
  • Linux中安装mysql8,很详细
  • Html5 video标签学习
  • SQLiteC/C++接口详细介绍之sqlite3类(七)
  • 【Flink SQL】Flink SQL 基础概念(四):SQL 的时间属性
  • go和rust使用protobuf通信
  • PWM驱动舵机
  • Vue2 + node.js项目
  • 大语言模型相关工具使用链接
  • 异常GPT:使用LVLMs检测工业异常
  • 【金三银四】掌趣科技24.3.7 H项目 服务端开发笔试题
  • C++面试100问(十)
  • 【K8s】肿么办??Kubernetes Secrets并不是Secret哟!!
  • 数据结构概述
  • Spring6--IOC反转控制 / 基于XML管理bean
  • 数据结构之双向链表
  • Sklearn K-均值算法
  • python提取身份证中的生日和性别
  • 远程办公、企业内网服务器的Code-Server上如何配置使用CodeGeeX插件
  • 图解Kafka架构学习笔记(一)
  • C语言经典面试题目(十八)
  • unityprotobuf自动生成C#
  • fastapi 的css js文件地址修改