网站建立教学,wordpress与phpmyadmin,同时优化几个网站,国外学校网站模板目录
一、AT89S51单片机的片内硬件结构
二、AT89S51的引脚功能
2.1 电源及时钟引脚
2.2 控制引脚
2.3 并行 I/O口引脚
三、AT89S51的CPU
3.1 运算器
3.1.1 算术逻辑单元#xff08;ALU#xff09;
3.1.2 累加器A
3.1.3 程序状态字寄存器#xff08;PSW#xff09…目录
一、AT89S51单片机的片内硬件结构
二、AT89S51的引脚功能
2.1 电源及时钟引脚
2.2 控制引脚
2.3 并行 I/O口引脚
三、AT89S51的CPU
3.1 运算器
3.1.1 算术逻辑单元ALU
3.1.2 累加器A
3.1.3 程序状态字寄存器PSW
3.2 控制器
四、AT89S51单片机存储器的结构
4.1 程序存储器空间
4.2 数据存储器空间
4.2.1 片内数据存储器
4.2.2 片外数据存储器
4.3 特殊功能寄存器
4.3.1 堆栈指针SP
4.3.2 寄存器B
4.3.3 AUXR 寄存器
4.3.4 数据指针 DPTR0 和 DPTR1
4.3.5 看门狗定时器WDT
4.4 位地址空间 一、AT89S51单片机的片内硬件结构
AT89S51是一种高性能、低功耗的8位单片机它包含了丰富的片内硬件结构用于实现多种功能。
主要硬件结构如下
1.中央处理器CPUAT89S51采用8位CPU具有高速执行能力可以执行各种指令。
2.程序存储器ROMAT89S51内置了4KB的闪存程序存储器用于存储用户程序和数据。
3.数据存储器RAMAT89S51内置了128字节的RAM用于存储临时变量和数据。
4.输入/输出I/OAT89S51具有4个外部中断引脚、32个可编程I/O引脚用于与外部设备进行数据交互。
5.定时器/计数器AT89S51内置了2个8位定时器/计数器和1个16位定时器/计数器可用于计时、产生定时中断等功能。
6.串口通信AT89S51具有一个可以实现串行通信的UART通用异步收发器。
7.模数转换器ADCAT89S51内置了一个8通道的10位模数转换器可以将模拟信号转换为数字信号。
8.时钟和定时器AT89S51采用外部晶振或者外部时钟源作为系统时钟并具有多种定时器和计数器功能。
除了上述主要硬件结构外AT89S51还包括电源管理单元、中断控制器、数据存储器和编程接口等。这些硬件结构的组合和配置使得AT89S51具有丰富的功能和灵活的应用能力。
AT89S51单片机的片内硬件结构图 二、AT89S51的引脚功能
AT89S51单片机具有40个引脚每个引脚都具有不同的功能。下面是AT89S51的引脚功能列表
P0.0 - P0.7: I/O 可编程口线 P1.0 - P1.7: I/O 可编程口线 P2.0 - P2.7: I/O 可编程口线 P3.0 - P3.7: I/O 可编程口线。
P0口线用作外部数据总线或者低位地址总线P0.0 - P0.7
P1口线用作通用的I/O口线但是在一些特殊情况下某些引脚的功能可能会被限定。
P2口线具有一些特殊功能引脚如外部中断请求、定时器/计数器引脚、串行数据输入/输出引脚。
P3口线具有一些特殊功能引脚如外部中断请求、定时器/计数器引脚、串行数据输入/输出引脚。
另外AT89S51还具有一些特殊引脚功能如下
EA: 外部访问使能引脚用于选择片内或者片外程序存储器。RST: 复位引脚用于对单片机进行复位操作。XTAL1: 晶振输入引脚接晶体振荡器的输出。XTAL2: 晶振输出引脚连接到晶体振荡器的输入端。 2.1 电源及时钟引脚
AT89S51单片机的电源和时钟引脚如下
VCC引脚40正电源引脚连接至电源的正极一般是5V。GND引脚20地引脚连接至电源的负极或地线。
时钟相关引脚有两种选择可以使用外部晶振或外部时钟源
XTAL1引脚19晶振输入引脚用于连接外部晶振的输出端。XTAL2引脚18晶振输出引脚连接至外部晶振的输入端。
或者
XTAL1引脚19时钟输入引脚用于连接外部时钟源。XTAL2引脚18时钟输出引脚不连接。
通过连接外部晶振或外部时钟源可以提供稳定的时钟信号来驱动单片机的运行和计时功能。 2.2 控制引脚
AT89S51单片机的控制引脚如下
RST引脚9复位引脚用于将单片机恢复到初始状态并启动程序的执行。当RST引脚低电平时单片机进入复位状态。PSEN引脚29程序存储器片选引脚用于选择程序存储器一般为闪存或EPROM的使能。当PSEN引脚为低电平时表示读取程序存储器中的指令。ALE/PROG引脚30地址锁存使能/编程引脚用于控制地址锁存器的使能以及编程模式的选择。当ALE/PROG引脚高电平时表示进行地址锁存当ALE/PROG引脚低电平时表示进入编程模式。EA/VPP引脚31外部访问使能/编程使能引脚用于选择外部访问或内部程序存储器的访问模式。当EA/VPP引脚高电平时表示使用外部程序存储器当EA/VPP引脚低电平时表示使用内部程序存储器。在编程模式下EA/VPP引脚用作编程使能引脚。P3.0-P3.7引脚10-17I/O口引脚可配置为输入或输出。P3端口可用于连接外部设备或作为通用输入/输出口。 2.3 并行 I/O口引脚
AT89S51单片机的并行I/O口引脚为P0、P1、P2、P3。
P0引脚32-398位并行输入/输出口可配置为输入或输出。P0端口可用于连接外部设备或作为通用输入/输出口。
P1引脚1-88位并行输入/输出口可配置为输入或输出。P1端口可用于连接外部设备或作为通用输入/输出口。
P2引脚21-288位并行输入/输出口可配置为输入或输出。P2端口可用于连接外部设备或作为通用输入/输出口。
P3引脚10-178位并行输入/输出口可配置为输入或输出。P3端口可用于连接外部设备或作为通用输入/输出口。
P3口的第二功能定义表格
P3口引脚功能说明P3.0RXD串行通信接收器输入。P3.1TXD串行通信发送器输出。P3.2INT0外部中断0输入。P3.3INT1外部中断1输入。P3.4T0定时器0外部输入。P3.5T1定时器1外部输入。P3.6WR外部数据存储器写入控制信号。P3.7RD外部数据存储器读取控制信号。
这些并行I/O口引脚可以与外部设备进行数据通信或者用于控制外部电路的输入/输出操作。 三、AT89S51的CPU
AT89S51的CPU由一个8位算术逻辑单元ALU、8位寄存器组、程序计数器、栈指针、CPU控制逻辑等组成。它能够执行一系列的指令实现各种运算和控制功能。
AT89S51的ROM用于存储程序代码可以存储8K字节的程序。RAM用于存储数据有可供程序使用的内部RAM和可供用户使用的外部RAM。
AT89S51有4个I/O端口每个端口有8个引脚可以连接外部设备和传感器。它还具有两个16位定时器/计数器可以用于测量时间、产生脉冲信号等。
AT89S51还具有一个串行通信接口UART可以进行与其他设备的串行通信如与计算机或其他单片机进行数据传输。 3.1 运算器
运算器是计算机中常见的一个功能部件用于执行算术和逻辑运算。它通常由算术逻辑单元ALU和累加器Accumulator组成。
3.1.1 算术逻辑单元ALU
算术逻辑单元Arithmetic Logic Unit简称ALU是计算机的核心部件之一负责执行算术和逻辑运算。ALU通常由多个逻辑门电路组成可以进行加法、减法、逻辑与、逻辑或、逻辑异或等运算。
ALU一般有以下几个主要功能
算术运算包括加法、减法、乘法、除法等。逻辑运算包括与、或、非、异或等运算。位移运算包括左移、右移等运算。比较运算用于比较两个数据的大小关系。
ALU通常由多个寄存器、加法器、逻辑门电路和控制逻辑组成。寄存器用于存储操作数和结果加法器用于执行加法运算逻辑门电路用于执行逻辑运算控制逻辑用于控制ALU的操作和输出。 3.1.2 累加器A
累加器A是一种特殊的寄存器用于存储和操作数据。在AT89S51的CPU中累加器A是一个8位的寄存器用于执行算术和逻辑运算。
累加器A具有以下功能
存储数据累加器A可以用来存储8位的数据这些数据可以是计算结果、输入数据或者中间数据。算术运算累加器A可以参与各种算术运算包括加法、减法、乘法和除法等。计算结果会保存在累加器A中。逻辑运算累加器A可以参与逻辑运算如与、或、非、异或等。计算结果会保存在累加器A中。数据传输数据可以从其他寄存器或者内存中传输到累加器A或者从累加器A传输到其他寄存器或者内存中。
累加器A在编程中经常被使用可以用于数值计算、逻辑判断和数据传输等操作。它的快速访问和操作能力使得累加器A成为CPU中重要的寄存器之一。 3.1.3 程序状态字寄存器PSW
程序状态字寄存器Program Status Word, PSW是AT89S51中的一个8位寄存器用于存储和表示CPU的各种状态和标志位。
PSW寄存器的各个位的功能如下
CY (Carry Flag)进位标志位用于指示是否发生了进位或借位。AC (Auxiliary Carry Flag)辅助进位标志位用于指示低 4 位的进位或借位。F0 (User Flag 0)用户标志位 0可以根据用户的需要自由设置和使用。RS1 (Register Bank Select 1) 和 RS0 (Register Bank Select 0)寄存器组选择位用于选择寄存器组 0、1、2 或 3。OV (Overflow Flag)溢出标志位用于指示是否发生了有符号数据的溢出。P (Parity Flag)奇偶标志位用于指示结果的低 8 位中 1 的个数是否为奇数。未使用位PSW寄存器的高两位是未使用的位保留为0。 下面是RS1和RS0与四组工作寄存器区的对应关系表格
RS1RS0工作寄存器区000 组片内 RAM地址 00H-07H011 组片内 RAM地址 08H-0FH102 组片内 RAM地址 10H-17H113 组片内 RAM地址 18H-1FH 3.2 控制器
控制器是计算机系统中的关键组件之一主要负责指令的执行和数据的处理。控制器包括以下几个主要部分 程序计数器Program CounterPC用于存储当前指令的地址指示下一条要执行的指令的位置。 指令译码器Instruction Decoder用于解析指令并将其转换为计算机可理解和执行的控制信号。 定时及控制电路负责产生和控制各种时序信号确保指令和数据在正确的时机进行传输和处理。 寄存器组用于存储指令执行所需的数据和中间结果。包括通用寄存器、程序状态字等。 数据通路Data Path负责数据的传输和处理包括算术逻辑单元ALU、数据选择器、数据缓存等。
控制器的功能是根据指令流程控制计算机的工作并将数据和指令传送给其他部件进行处理。 四、AT89S51单片机存储器的结构
4.1 程序存储器空间
AT89S51单片机的片内程序存储器空间为4KB4096字节的Flash存储器从地址0x0000到0x0FFF。用户可在片外扩展程序存储器最多可扩展至64KB的程序存储器。
这个存储器空间用来存储程序指令包括初始化程序、中断向量表、主程序等。在程序存储器中每个存储单元存储一个字节的指令码。程序存储器空间的大小决定了单片机可以存储的程序的长度。
AT89S51微控制器有5个中断源每个中断源都有一个对应的中断入口地址。下面是AT89S51的5个中断源及其中断入口地址的表格
中断源中断入口地址INT0外部中断 00x0003HTF0定时器 T00x000BHINT1外部中断 10x0013HTF1定时器 T10x001BHRI/TI串行口0x0023H
注意
以上地址是16位地址以十六进制表示。中断入口地址是中断服务子程序的起始地址在中断发生时程序会跳转到对应的中断入口地址执行中断服务程序。 4.2 数据存储器空间
AT89S51的数据存储器空间掉电易失性包括片内RAM和片外RAM。
4.2.1 片内数据存储器
AT89S51是一种8位微控制器具有片内RAM用于存储程序的变量和临时数据。它的片内RAM总共有128个字节地址范围从0x00到0x7F。
AT89S51的片内RAM主要用途包括
存储特殊功能寄存器(SFR)0x00到0x07地址范围内的RAM用于存储与微控制器的控制和状态相关的寄存器例如控制I/O口、外部中断控制和定时器/计数器控制等。I/O寄存器0x08到0x1F地址范围内的RAM用于存储与外部设备进行数据交互的I/O口的寄存器包括输入口和输出口的配置和控制。通用寄存器0x20到0x2F地址范围内的RAM用作通用寄存器可以用于存储程序的变量和临时数据。这些寄存器的使用是由程序员决定的可以根据程序的需要进行分配和使用。堆栈指针和堆栈数据0x2F地址用作堆栈指针指示当前堆栈的顶部位置用于存储函数调用和中断处理时的现场保存。0x30到0x7E地址范围内的RAM用于存储堆栈中的数据。特殊功能位0x7F地址用于存储特殊功能位。这些位用于控制和配置微控制器的特殊功能例如中断使能、时钟源选择等。 AT89S51的片内RAM结构图 4.2.2 片外数据存储器
AT89S51的片外RAM可以为系统提供额外的存储空间扩展了片内RAM的容量。片外RAM通常用于存储大量的数据、变量、缓冲区等。它可以提高系统的处理能力、灵活性和可拓展性。
在连接片外RAM时需要注意以下几点 地址空间片外RAM的地址空间通常比片内RAM大因此需要使用更多的地址线来寻址。在AT89S51中片外RAM的地址空间可以达到64KB。 片选信号为了区分片内RAM和片外RAM的地址范围需要使用特定的片选信号。这样当片外RAM的地址范围被选中时MCU会将数据读取或写入到片外RAM中。 时序要求在使用片外RAM时需要注意时序要求。外部RAM的读写操作需要按照特定的时序进行以确保正常的数据传输和存储。
总结来说AT89S51的片外RAM可以通过外部芯片或模块扩展系统的存储空间。通过连接片外RAM可以提供额外的存储空间提升系统的处理能力和灵活性。连接片外RAM需要注意地址空间、片选信号和时序要求等方面的配置。 4.3 特殊功能寄存器
下面是AT89S51微控制器的SFR特殊功能寄存器的名称及其分布表格
序号特殊功能寄存器符号名称字节地址H复位值1ACC累加器0xE00x002BB寄存器0xF00x003SP堆栈指针0x810x074DPL数据指针低位0x820x005DPH数据指针高位0x830x006P0端口00x800xFF7P1端口10x900xFF8P2端口20xA00xFF9P3端口30xB00xFF10IE中断使能寄存器0xA80x0011IP中断优先级寄存器0xB80x0012TCON定时器/计数器控制寄存器0x880x0013TMOD定时器/计数器模式寄存器0x890x0014TL0定时器0计数器低位0x8A0x0015TL1定时器1计数器低位0x8B0x0016TH0定时器0计数器高位0x8C0x0017TH1定时器1计数器高位0x8D0x0018T2CON定时器2控制寄存器0xC80x0019RCAP2L定时器2重载计数器低位0xCA0x0020RCAP2H定时器2重载计数器高位0xCB0x0021TL2定时器2计数器低位0xCC0x0022TH2定时器2计数器高位0xCD0x0023PSW程序状态字寄存器0xD00x0024EA中断允许位0xAF0x0025PCON电源控制寄存器0x870x0026SBUF串口数据寄存器0x990x0027SCON串口控制寄存器0x980x00 4.3.1 堆栈指针SP
堆栈指针Stack PointerSP是一个特殊功能寄存器用于管理程序中的堆栈。堆栈是一个用于存储临时数据和返回地址的区域它遵循后进先出的原则。
在大多数微控制器中堆栈可以使用内部RAM的一部分来实现。堆栈指针SP指示了当前堆栈顶部的位置即最新的数据所在的位置。每当一个数据被推入堆栈时堆栈指针将减小而每当一个数据被弹出堆栈时堆栈指针将增加。
堆栈指针SP的字节地址在不同的微控制器中可能会有所不同具体取决于芯片的架构和设计。你可以参考芯片的数据手册或技术规格来查找堆栈指针的字节地址。通常堆栈指针的字节地址是一个特定的SFR地址。
复位值表示在芯片复位时堆栈指针将被设置为一个默认的初始值。在AT89S51微控制器中堆栈指针SP的复位值为0x07。这意味着在复位时堆栈指针将指向内部RAM的地址0x07即堆栈的最底部位置。
通过操作堆栈指针SP你可以推入数据到堆栈将数据放入堆栈顶部从堆栈中弹出数据获取堆栈顶部的数据以及进行其他与堆栈相关的操作。堆栈指针用于管理函数调用、中断处理以及临时数据的存储。 4.3.2 寄存器B
在AT89S51微控制器中寄存器B是一个特殊功能寄存器用于存储8位数据。它是一个可读写的寄存器可以用于临时存储数据或作为一个通用寄存器使用。
寄存器B的字节地址为0x00也就是位于内部RAM的地址0x00。
在AT89S51微控制器的复位时寄存器B的复位值是未定义的。这意味着在复位时寄存器B的内容可能是任意的需要手动初始化。
你可以使用指令将数据加载到寄存器B中或者从寄存器B中将数据传输到其他寄存器或存储器位置。寄存器B在编写嵌入式程序时可以用于各种用途例如计算、数据传输和临时存储等。 4.3.3 AUXR 寄存器
AT89S51的AUXR寄存器是一个8位寄存器它的格式如下
位D7D6D5D4D3D2D1D0名称---WDIDLEDISRTO--DISALE
其中
DISALE位 (Bit 4) 是DISABLE ALE/PROG引脚的功能位。当DISALE位为1时ALE/PROG引脚被禁用不再产生ALE信号当DISALE位为0时ALE/PROG引脚正常工作并产生ALE信号。DISRTO位 (Bit 3) 是禁用复位时序的功能位。当DISRTO位为1时复位信号上升沿将不会引起复位时序而是直接复位当DISRTO位为0时复位信号上升沿会触发复位时序。WDIDLE位 (Bit 2) 是控制看门狗定时器是否在空闲状态工作的功能位。当WDIDLE位为1时看门狗定时器只在CPU空闲状态下计数当WDIDLE位为0时看门狗定时器在CPU任何状态下都会计数。
注意
AUXR寄存器的其他位没有特定功能应该保持为0。 4.3.4 数据指针 DPTR0 和 DPTR1
AT89S51微控制器具有2个数据指针寄存器分别为DPTR0和DPTR1。
DPTR0用于访问代码存储器的外部数据空间也可以用于访问内部数据存储器的第1半部分从00H到7FH。
DPTR1用于访问内部数据存储器的第2半部分从80H到FFH。
这两个数据指针寄存器都是16位的可以用于存储数据地址。通过将数据的高字节存储到DPH数据指针高字节寄存器中将数据的低字节存储到DPL数据指针低字节寄存器中来设置数据的地址。 4.3.5 看门狗定时器WDT
在AT89S51微控制器中看门狗定时器WDT是由AUXR寄存器的不同位字段来控制的。 DISALEAUXR.3 - 禁用外部中断1 设置DISALE位为1禁用外部中断1功能。当禁用时外部中断1引脚INT1将不会响应外部中断信号。 DISRTOAUXR.2 - 禁用复位超时功能 设置DISRTO位为1禁用复位超时功能。当禁用时复位超时功能将不会触发复位。 WDIDLEAUXR.1 - 看门狗定时器空闲模式 设置WDIDLE位为1使看门狗定时器在空闲模式下运行。在空闲模式下看门狗定时器将继续计数即使CPU处于空闲状态。如果WDIDLE位为0看门狗定时器将只在CPU执行指令时进行计数。 4.4 位地址空间
位地址空间是指一个计算机系统中的内存或存储器的总地址范围它由位(bit)的数量来衡量。位地址空间的大小取决于计算机体系结构的设计和处理器的位数。
在AT89S51单片机中位地址空间为8位即有2^8256个不同的地址。这意味着该单片机可以寻址256个不同的内存位置。该内存地址空间包括RAM随机存储器、ROM只读存储器和特殊功能寄存器SFR等。
对于片内程序存储器FlashAT89S51单片机提供了8KB的存储容量它占据了地址空间的一部分。其余的地址空间可以用于访问片外存储器、外设等。在片外存储器的情况下可以通过特定的存储器接口或总线进行访问。