单片机实训教案 下载本文

单片机基础知识

1.1 单片机芯片的内部结构及原理

一.单片机的概念

单片机即单片微型计算机,就是将CPU、RAM、ROM、定时/计数器和多种I/O接口电路都集成在一块芯片上的微型计算机。

二.单片机的类型

MCS-51系列单片机包括许多类型,常用的有80C51子系列、80C52子系列,其配置如表1.1所示。MCS-51系列单片机与AT89C51和87C51芯片内部结构及原理兼容。

表1.1 MCS-51系列单片机配置一览表

片内存储器/KB 系列 无ROM 片内ROM 8051 4 KB 80C51 4 KB 8052 8 KB 80C252 8 KB 片内 EPROM 8751 4 KB 87C51 4 KB 8752 8 KB 87C252 8 KB 片内 片内 定时器/计数器 并行I/O 串行I/O 中断源 制造工艺 FEPROM RAM 8031 MCS-51 子系列 80C31 128 B 2×16位 2×8位 1 5 HMOS 89C51 128 B 2×16位 2×8位 1 5 CHMOS MCS-52 子系列 8032 80C232 89C52 256 B 3×16位 2×8位 256 B 3×16位 2×8位 1 1 6 6 HMOS CHMOS 三.MCS-51系列单片机的内部结构

MCS-51单片机结构框图如图1.1所示,各功能部件由内部总线连接在一起。 MCS-51单片机芯片内部集成包括下列部件: (1) 一个8位微处理器CPU。 (2) 256 B数据存储器RAM和特殊功能寄存器SFR。 (3) 4 KB内部程序存储器ROM。

(4) 两个定时/计数器,用以对外部事件进行计数,也可用作定时器。

(5) 四个8位可编程的I/O(输入/输出)并行端口,每个端口既可做输入,也可做输出。 (6) 一个串行端口,用于数据的串行通信。 (7) 具有五个中断源、两个优先级的中断结构。 (8) 内部有一个振荡器和时钟电路。 (9) 有一个可编程全双工的串行口。

(10) 可寻址64 KB的外部数据存储空间和64 KB的外部程序存储器的控制电路。

T0时钟电路T1ROMRAM定时/计数器CPU并行接口串行接口中断系统P0P1P2P3TXDRXDINT0INT1图1.1 MCS-51单片机结构框图

四.MCS-51系列单片机的引脚功能

MCS-51系列单片机引脚如图1.2所示。 P0.0 ~ P0.7: P0口8位双向口线。

P1.0 ~ P1.7 :P1口8位双向口线。 P2.0 ~ P2.7 :P2口8位双向口线。 P3.0 ~ P3.7 :P3口8位双向口线。

ALE:地址锁存控制信号。在系统扩展时,ALE用于控制把P0口输出 的低8位地址锁存起来,以实现低位地址和数据的隔离。此外,由于ALE 是以晶振1/6的固定频率输出的正脉冲,因此,可作为外部时钟或外部定时 脉冲使用。

PSEN:外部程序存储器读选通信号。在读外部ROM时,PSEN有效 (低电平),以实现外部ROM单元的读操作。

EA:访问程序存储控制信号。当信号为低电平时,对ROM的读操作 限定在外部程序存储器;当信号为高电平时,对ROM的读操作是从 内部程序存储器开始,并可延至外部程序存储器。

图1.2MCS-51系列单片机引脚如图 RST:复位信号。当输入的复位信号延续两个机器周期以上的高电平

时即为有效,用以完成单片机的复位初始化操作。

XTAL1和XTAL2:外接晶体引线端。当使用芯片内部时钟时,此二 引线端用于外接石英晶体和微调电容;当使用外部时钟时,用于接外 部时钟脉冲信号。 VSS:地线。

VCC:+5 V电源。

以上是MCS-51单片机芯片40条引脚的定义及简单功能说明,读者可以对照实训电路找到相应引脚,在电路中查看每个引脚的连接使用。

P3口线的第二功能。P3的8条口线都定义有第二功能

1234567891011121314151617181920P1.0P1.1P1.2P1.3P1.4P1.5P1.6P1.7RST/VPDRXD P3.0TXD P3.1INT0 P3.2INT1 P3.3T0 P3.4T1 P3.5WR P3.6RD P3.7XTAL2XTAL1VSSVCCP0.0P0.1P0.2P0.3P0.4P0.5P0.6P0.7EA/VPPALE/PROGPSENP2.7P2.6P2.5P2.4P2.3P2.2P2.1P2.04039383736353433323130292827262524232221五、MCS-51系列单片机存储器结构

1. 程序存储器

对于80C51来说,程序存储器(ROM)的内部地址为0000H~0FFFH,共4 KB;外部地址为1000H~

8031 8051 8751FFFFH,共60 KB。程序存储器的结构如图1.3所示。当 =1,程序计数器由内部0FFFH执行到外部1000H时,会自动跳转;当=0时,只执行外部程序。对于87C51来说,内部有4 KB的EPROM,将它作为内部程序存储器;80C31内部无程序存储器,必须外接程序存储器。 FFH F0H 特FFFFH 特 FFFFH E0H 殊 功D0H 殊

B8H 能外 部 外部 B0H 寄功 A8H 存RAM ROM 能 A0H 器 98H 寄 (I/O口 90H 中位 存 地址) 88H 寻80H 80H 址器 7FH

通用

30H RAM区 1000H 2FH 位寻址区 20H 0FFFH 内部 0FFFH 外部

1FH ROM ROM

工作寄(EA=1) 0000H (EA=0) 0000H 0000H 存器区 00H

程序存储器 外部数据存储器 内部数据存储器

(a)

(b) 图1.2MCS-51系列单片机引脚如

(c)

图1.3单片机存储器结构

80C31最多可外扩64 KB程序存储器,其中6个单元地址具有特殊用途,保留给系统使用,如表1.2所示。其中,0000H是系统的启动地址,一般在该单元中存放一条绝对跳转指令;另外0003H、000BH、0013H、001BH和0023H对应5个中断源的中断服务入口地址。 表1.2 MCS-51单片机复位、中断入口地址

操 作 入口地址

复位 0000H 外部中断INT0 0003H 定时器/计数器0溢出 000BH 外部中断INT1 0013H

定时器/计数器1溢出 001BH

子系列) 定时器/计数器2溢出或T2EX端负跳变(MCS-52

串行口中断 0023H 002BH 2. 内部数据存储器

MCS-51单片机片内RAM的配置如图1.3(b)所示。片内RAM为256字节,地址范围为00H~FFH,分为两大部分:低128字节(00H~7FH)为真正的RAM区;高128字节 (80H~FFH)为特殊功能寄存器区SFR。

在低128字节RAM中,00H~1FH共32单元是4个通用工作寄存器区。每一个区有8个通用寄存器

R0~R7。寄存器和RAM地址对应关系如表1.3所示。RAM中的位寻址区地址表如表1.4所示,SFR特殊功能寄存器地址表如表1.5所示。

表1.3 寄存器和RAM地址对照表

地 址 寄存器 R0 R1 R2 R3 R4 R5 R6 R7 RAM地址 20H 21H 22H 23H 24H 25H 26H 27H 28H 29H 2AH 2BH 2CH 2DH 2EH 2FH 10H 01H 09H 11H 02H 0AH 12H 03H 0BH 13H 04H 0CH 14H 05H 0DH 15H 06H 0EH 16H 07H 0FH 17H 表1.4 RAM中的位寻址区地址表 D4 D7 D6 D5 D3 04 07 06 05 03 0C 0F 0E 0D 0B 14 17 16 15 13 1C 1F 1E 1D 1B 24 27 26 25 23 2C 2F 2E 2D 2B 34 37 36 35 33 3C 3F 3E 3D 3B 44 47 46 45 43 4C 4F 4E 4D 4B 54 57 56 55 53 5C 5F 5E 5D 5B 64 67 66 65 63 6C 6F 6E 6D 6B 74 77 76 75 73 7C 7F 7E 7D 7B 00H 08H 0区 1区 2区 3区 18H 19H 1AH 1BH 1CH 1DH 1EH 1FH D2 02 0A 12 1A 22 2A 32 3A 42 4A 52 5A 62 6A 72 7A D1 01 09 11 19 21 29 31 39 41 49 51 59 61 69 71 79 D0 00 08 10 18 20 28 30 38 40 48 50 58 60 68 70 78