1、 单片机课程设计 (跑马灯设计) 专业:电气自动化 1 摘摘 要要 AT89C51 是一种带是一种带 4K字节闪存可编程可擦除字节闪存可编程可擦除只读存储器只读存储器 (FPEROMFlash Programmable and Erasable Read Only Memory) 的低电压、高性能的低电压、高性能 CMOS 8 位微处理器,位微处理器,即单片机即单片机。AT89C2051 是一是一 种带种带 2K字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除字节闪存可编程可擦除只读存储器的单片机。单片机的可擦除 只读存储器可以反复擦除只读存储器可以反复擦除 1000 次。该器件采用次。
2、该器件采用 ATMEL 高密度非易失高密度非易失 存储器制造技术制造, 与工业标准的存储器制造技术制造, 与工业标准的 MCS-51 指令集和输出管脚相兼容。指令集和输出管脚相兼容。 该设计使用 AT89C51 芯片作为控制芯片,利用 P1 口连接 8 个发光 二极管,通过 I/O 的值控制“跑马灯”的亮灭,以达到显示效果。开始时 所有灯全亮,按下按键 S 时开始跑马灯,再按下按键 S 时停止,再按下 S 时继续,并要求有多种亮暗组合。 关键词:关键词:AT89C51 单片机 跑马灯 按键 2 目录 摘 要 . I 第一章 芯片分析和设计概述 3 第一节 AT89C51 芯片分析 3 第二节
3、设计概述 . 8 第二章 硬件电路设计 9 第三章 程序部分设计 10 参考文献 18 3 第一章 芯片分析和设计概述 第一节 AT89C51 芯片分析 ATMEL 的 AT89S51 是一种高效微控制器,将多功能 8 位 CPU 和闪烁 存储器组合在单个芯片中,为很多嵌入式控制系统提供了一种灵活性高 且价廉的方案。AT89C51 的芯片引脚图如下: 图 1.1 AT89C51 引脚图 各引脚的说明和功能分析如下: VCC:供电电压。 4 GND:接地。 P0 口:P0 口为一个 8 位漏级开路双向 I/O 口,每脚可吸收 8TTL 门 电流。当 P1 口的管脚第一次写 1 时,被定义为高阻输
4、入。P0 能够用于 外部程序数据存储器,它可以被定义为数据/地址的第八位。在 FIASH 编程时,P0 口作为原码输入口,当 FIASH 进行校验时,P0 输出原码, 此时 P0 外部必须被拉高。 P1 口:P1 口是一个内部提供上拉电阻的 8 位双向 I/O 口,P1 口缓 冲器能接收输出 4TTL 门电流。P1 口管脚写入 1 后,被内部上拉为高, 可用作输入,P1 口被外部下拉为低电平时,将输出电流,这是由于内部 上拉的缘故。在 FLASH 编程和校验时,P1 口作为第八位地址接收。 P2 口:P2 口为一个内部上拉电阻的 8 位双向 I/O 口,P2 口缓冲器可接 收,输出 4 个 T
5、TL 门电流,当 P2 口被写“1”时,其管脚被内部上拉电 阻拉高,且作为输入。并因此作为输入时,P2 口的管脚被外部拉低,将 输出电流。 这是由于内部上拉的缘故。 P2 口当用于外部程序存储器或 16 位地址外部数据存储器进行存取时,P2 口输出地址的高八位。在给出地 址“1”时, 它利用内部上拉优势, 当对外部八位地址数据存储器进行读 写时, P2 口输出其特殊功能寄存器的内容。 P2 口在 FLASH 编程和校验时 接收高八位地址信号和控制信号。 5 P3 口: P3 口管脚是 8 个带内部上拉电阻的双向 I/O 口, 可接收输出 4 个 TTL 门电流。当 P3 口写入“1”后,它们被
6、内部上拉为高电平,并 用作输入。作为输入,由于外部下拉为低电平,P3 口将输出电流(ILL) 这是由于上拉的缘故。 RST:复位输入。当振荡器复位器件时,要保持 RST 脚两个机器周期 的高电平时当 8051 通电,时钟电路开始工作,在 RESET 引脚上出现 24 个时钟周期以上的高电平,系统即初始复位。初始化后,程序计数器 PC 指向 0000H,P0-P3 输出口全部为高电平,堆栈指钟写入 07H,其它专用 寄存器被清“0”。RESET 由高电平下降为低电平后,系统即从 0000H 地 址开始执行程序。然而,初始复位不改变 RAM(包括工作寄存器 R0-R7) 的状态, 特殊功能寄存 器 初始态 特殊功能寄存 器 初始态 ACC 00H B 00H PSW 00H SP 07H DPH 00H TH0 00H DPL 00H TL0 00H 6 IP xxx00000 B TH1 00H IE 0xx00000 B TL1 00H TMOD 00H TCON 00H SCON xxxxxxxx B SBUF 00H P0-P