资源描述:
《开发板学习PPT课件》由会员上传分享,免费在线阅读,更多相关内容在行业资料-天天文库。
一、单片机概论8位单片机占整个单片机市场的60%以上,8位单片机的旧的机种正在被淘汰,新的机型不断涌现.8位单片机以其功能强,品种多,正广泛应用于各个领域,是单片机的主流机种.随着集成电路工艺的不断改进,8位单片机的价格也在不断降低.单片机的发展趋势是:增加存储器容量,片内EPROM转变为FLASH,存储器编程可不同级别加密,片内I/O管脚多功能化.
1单片机的应用领域工业方面:电机控制,工业机器人,过程控制,数字控制仪器仪表方面:智能仪器,医疗器械,色谱仪,示波器民用方面:电子玩具,高级电视游戏机,录像机,激光盘驱动电讯方面:调制解调器,智能线路运行控制.导航与控制:导弹控制,智能武器装置数据处理:图形终端,磁带机,打印机汽车方面:点火控制,变速器控制,排气控制
2第一章89S52单片机的结构一、内部结构和主要功能二、引脚功能说明三、时钟、复位电路四、I/O端口五、存储器配置六、最小系统七、CPU时序
389S52结构示意图
4主要性能:片内存储器包含8KB的FLASH,可在线编程,檫写次数不少于1000次256字节片内数据RAM32根可编程I/0口线8个中断源、6个中断矢量、两个优先权的中断结构1个可编程全双工串行接口3个可编程定时/计数器两种低功耗模式分别是空闲模式和掉电模式具有3级程序锁定位含有一个看门狗定时器具有断电标志POF全静态工作频率0~33MHz完全兼容MCS-51产品
589S52引脚功能介绍VCC+5VGND地ALE地址锁存允许/PSEN程序存储器允许EA/VPP为0-访问外部程序存储器为1-访问内部程序存储器RST复位信号输入XTAL1、XTAL2外部晶振P0.0~P0.7I/O端口(P0口)P1.0~P1.7I/O端口(P1口)P2.0~P2.7I/O端口(P2口)P3.0~P3.7I/O端口(P3口)
689S52引脚图
7时钟、复位电路时钟电路:复位电路:
8I/O端口-P0口1.P0端口总线I/O端口,双向,开漏,数据地址分时复用,该端口除用于数据的输入/输出外,在89S52单片机外接程序存储器时,还分时地输出/输入地址/指令。由P0端口输出的信号无锁存,输入的信息有读端口引脚和读端口锁存器之分
9P0端口结构
10P1端口结构
11P2端口结构
12I/O端口-P3口(双功能口)P3.0-RXD串行接口P3.1-TXDP3.2-/INT0外部中断输入P3.3-/INT1P3.4-T0定时/计数器输入P3.5-T1P3.6-/WR外部数据读、写P3.7-/RD
13I/O端口-P3口(双功能口)
14P3端口结构
15SFR寄存器(1)特殊功能功能名称地址复位后寄存器的状态B*通用寄存器F0H00HA*累加器E0H00HPSW*程序状态寄存器D0H00HIP*中断优先寄存器B8H00HP3*P3口数据寄存器B0HFFHIE*中断允许寄存器A8H00HP2*P2口数据寄存器A0HFFHSBUF串行口发送/接收缓冲器99H不定SCON*串行口控制寄存器98H00HP1*P1口数据寄存器90HFFH
16SFR寄存器(2)特殊功能功能名称地址复位后寄存器的状态TH1T1计数器高8位8DH00HTH0T0计数器高8位8CH00HTL1T1计数器低8位8BH00HTL0T0计数器低8位8AH00HTMOD定时/计数器方式字寄存器89H00HTCON*定时控制寄存器88H00HPCON波特率选择寄存器87H00HDPH地址寄存器高8位83H00HDPL地址寄存器低8位82H00HSP堆栈指示器81H07HP0*P0口数据寄存器80HFFH
17CPU时序-外部程序存储器读
18CPU时序-外部数据存储器读写
19第二章89S52单片机开发入门一、开发流程二、开发工具三、集成开发环境四、举例
20KeilC51开发流程根据任务选择MC型号设置工程参数,如频率,优化级别等加入适当的包含文件#include“reg51.h”编写源代码调试与仿真生成HEX文件烧写
21二、开发工具89S52开发板集成开发环境下载线软件常用仪器(万用表,示波器等)
22下载线软件
23编程软件
24三、集成开发环境KeilSoftwareInc.的uVision2,集成开发环境或者WAVE编译环境集成C和汇编语言源代码编写.编译连接,模拟仿真,输出hex文件.支持连接仿真器进行在线仿真.标准C语言支持.支持多级优化支持数百种器件.
25KeilC51uVision2
26第三章指令系统及汇编语言一、指令系统概述二、51单片机指令系统三、汇编语言程序设计举例四、C51程序设计举例
27一、指令系统概述MCS-51系列单片机共有111条指令按功能可分成5类指令:数据传送指令(29条)算术运算指令(24条)逻辑运算指令(24条)控制转移指令(17条)位操作类指令(17条)
281.指令执行时间快单周期指令65条(1us,12MHz晶振)双周期指令44条(2us,12MHz晶振)四周期指令2条(4us,12MHz晶振)2.指令短单字节指令49条双字节指令46条三字节指令16条3.单指令实现字节相乘或相除运算4.具有丰富的位操作类指令1、AT89系列指令系统特点
292、寻址方式7种寻址方式:立即寻址直接寻址寄存器寻址寄存器间接寻址相对寻址变址寻址位寻址
30二、51单片机指令系统1、指令中常用符号说明2、数据传送指令3、算术运算指令4、逻辑运算指令5、控制转移指令6、位操作类指令
311、指令中常用符号说明Rn当前寄存器区的Ro~R7(其中n=0~7)Ri当前寄存器区中的R0和R1(其中i=0,1)direct8位直接字节地址(片内RAM和SFR空间)#data8位立即数。#data1616位立即数。addr1616位地址值。Addr1111位地址值。rel8位带符号地址偏移量(-128~+127)bit片内RAM和SFR中的可直接寻址位@间接寻址寄存器或基址寄存器的前缀()表示括号中的内容(())表示间址寻址的内容
322、数据传送指令(1)MOVA,RnMOVA,directMOVA,@RiMOVA,#dataMOVRn,AMOVRn,directMOVRn,#dataMOVdirect,AMOVdirect,RnMOVdirect,directMOVdirect,@RiMOVdirect,#dataMOV@Ri,AMOV@Ri,direct
33数据传送指令(2)MOVDPTR,#data16MOVCA,@A+DPTRMOVCA,@A+PCMOVXA,@RiMOVXA,@DPTRMOVX@Ri,AMOVX@DPTR,APUSHdirectPOPdirectXCHA,RnXCHA,directXCHA,@RiXCHDA,@RiSWAPA
343、算术运算指令(1)ADDA,RnADDA,directADDA,@RiADDA,#dataADDCA,RnADDCA,directADDCA,@RiADDCA,#dataSUBBA,RnSUBBA,directSUBBA,@RiSUBBA,#data
35算术运算指令(2)INCAINCRnINC@RiDECADECRnDECdirectDEC@RiINCDPTRMULABDIVABDAA
364、逻辑运算指令(1)ANLA,RnANLA,directANLA,@RiANLA,#dataANLdirect,AANLdirect,#dataORLA,RnORLA,directORLA,@RiORLA,#dataORLdirect,AORLdirect,#data
37逻辑运算指令(2)XRLA,RnXRLA,@RiXRLA,#dataXRLdirect,AXRLdirect,#dataCLRACPLARLARLCARRARRCA
385、控制转移指令ACALLaddr11LCALLaddr16RETRETIAJMPaddr11LJMPaddr16SJMPrelJMP@A+DPTRJZrelJNZrelCJNEA,direct,relCJNEA,#data,relCJNE@Ri,#data,relDJNZRn,relDJNZdirect,relNOP
396、位操作类指令CLRCCLRbitSETBCSETBbitCPLCCPLbitANLC,bitANLC,/bitORLC,bitORLC,/bitMOVC,bitMOVbit,CJCrelJNCrelJBbit,relJNBbit,relJBCbit,rel
40三、汇编语言程序设计应用举例举例:设计一个指示器,要求当指示按键按下后,指示灯发光。设P1.0口驱动指示灯,P1.1口作为指示按键输入。电路设计见图
41ORG00LJMPSTARTORG0100HSTART:JBP1.1,$JNBP1.1,$SETBP1.0SJMPLOOP1SOUND:MOVR7,#5SETBP1.0MOVR0,#10LCALLDELAYCLRP1.0MOVR0,#20LCALLDELAYDJNZR7,SOUND1RET
42THANKYOUSUCCESS2022/10/1943可编辑
43DELAY:MOVR1,#100;100msDELAY1:MOVR2,#200;1msDELAY2:NOPNOPNOPDJNZR2,DELAY2DJNZR1,DELAY1DJNZR0,DELAYRET
44#include“reg51.h”#defineucharunsignedcharsbitpinSW=P1^2;sbitpinBell=P1^0;sbitpinLed=P1^1;voidDelay_1ms(uintS_DelayTime){ucharS_j;while(S_DelayTime!=0){S_DelayTime--;for(S_j=0;S_j<115;S_j++){}}}voidmain(void){intDelay=0;pinLed=1;pinBell=1;while(1){if(!pinSW){Delay_1ms(2);
45
46第四章51单片机的功能单元介绍一、定时/计数器二、串行接口三、中断系统
47一、定时/计数器定时器/计数器简称定时器,其作用主要包括产生各种时标间隔、记录外部事件的数量等,是微机中最常用、最基本的部件之一。803l单片机有2个16位的定时器/计数器:定时器0(T0)和定时器1(T1)。T0由2个定时寄存器TH0和TL0构成,T1则由TH1和TL1构成,它们都分别映射在特殊功能寄存器中,从而可以通过对特殊功能寄存器中这些寄存器的读写来实现对这两个定时器的操作。用于定时器工作时,每一个机器周期定时寄存器自动加l,所以定时器也可看作是计量机器周期的计数器。由于每个机器周期为12个时钟振荡周期,所以定时的分辨率是时钟振荡频率的1/12。用于计数器工作时,只要在单片机外部引脚T0(或T1)有从1到0电平的负跳变,计数器就自动加1。计数的最高频率一般为振荡频率的l/24
481、控制字TF中断请求标志(T0、T1),高电平有效M0M1C/TGATEM0M1C/TGATET1T0GATE1-打开0-关闭C/T1-计数状态0-定时状态M1、M0工作方式设置00-方式001-方式110-方式211-方式3IT0IE0IT1IE1TR0TF0TR1TF1TCON控制字TR定时/计数器(T0、T1)运行控制位,高电平有效IT外部中断(INT0、INT1)触发方式1-下降沿引起0-低电平引起IE外部中断请求标志(INT0、INT1),高电平有效TMOD控制字
492、方式013位方式,由TL1的低5位和TH1的8位构成13位计数器(TL1的高3位无效)
503、方式116位方式,由TL1的8位和TH1的8位构成16位计数器
514、方式28位自动装入时间常数方式。由TL1构成8位计数器,THl仅用来存放时间常数。启动T1前,TL1和TH1装入相同的时间常数,当TL1计满后,除定时器回零标志TF1置位,具有向CPU请求中断的条件外,TH1中的时间常数还会自动地装入TL1,并重新开始定时或计数
525、方式32个8位方式。工作方式3只适用于定时器0。如果使定时器1为工作方式3,则定时器1将处于关闭状态。
536、汇编编程举例利用定时器/计数器每隔1ms控制产生宽度为2个机器周期的负脉冲,由P1.0送出,设时钟频率为12MHzORG0000HAJMPMAINORG000BHAJMPT0INTORG100HMAIN:MOVTH0,#0DDHMOVTL0,#18HSETBTROLOOP:SJMPLOOPORG200HT0INT:CLRP1.0SETBP1.0MOVTH0,#0DDHMOVTL0,#18HRETI
547、C51编程举例#includesbitpinPulse=P1^0;voidT0Int(void);voidT0Int(void)interrupt1{pinPulse=0;pinPulse=1;TH0=0xdd;TL0=0x18;}voidmain(void){TH0=0xdd;TL0=0x18;ET0=1;EA=1;TR0=1;while(1);}
55二、串行接口MCS—51单片机具有一个采用通用异步接收器/发送器(UART)工作方式的全双工串行通信接口,可以同时发送、接收数据。它具有两个相互独立的接收、发送缓冲器,两个缓冲器共用一个地址(99H),发送缓冲器只能写入,不能读出,接收缓冲器只能读出,不能写入。同时,该串行接口也可作为同步移位寄存器使用,其中帧格式可有8位、10位和11位,并能置成多种波特率。
561、异步通信格式波特率(BaudRate)波特率,即数据传送速率,表示每秒钟传送二进制代码的位数,它的单位是位/秒。举例:数据传送的速率每秒为120个字符,每个字符包含10个代码位(一个起始位、一个停止位、8个数据位),这时,传送的波特率为:10×120位/秒=1200波特(bps)
57RITIRB8TB8RENSM2SM1SM0D7D6D5D4D3D2D1D0SM0SM1工作方式说明波特率000同步移位寄存器fosc/1201110位异步收发可变10211位异步收发fosc/32或fosc/6411310位异步收发可变.REN:允许接收控制位,用软件置1或清0TI:发送中断标志位,软件清0RI:接收中断标志位,软件清0TB8:准备发送的第9位数据位,软件置1或0RB8:接收到的第9位数据SM2:用于主—从式多机通信的控制位。若SM2=1,则允许多机通信2、串行口控制寄存器SCON(98H)
584、关于多机通信SM2:在工作方式2和工作方式3中,用于主—从式多机通信的控制位。若SM2=1,则允许多机通信。多机通信规定,第9位数据(D8)为l,说明本帧为地址;若第9位数据为0,则本帧为数据,当一个MCS—51(主机)与多个MCS—51(从机)通信时,所有从机的SM2都置为1。主机首先发送一帧地址,即某从机地址编号,其中第9位为1,被寻址的某个从机收到地址信息后,将其中的第9位装入RB8。从机依据RB8的值来决定从机是否再接收主机的信息。若RB8=0,说明是数据帧,则使接收中断标志位RI=0,信息丢失;若RB8=1,说明是地址帧,数据装入接收/发送缓冲器,并置中断标志RI=1,中断所有从机,被寻址的目标从机使SM2=0,以接收主机发来的一帧数据,其它从机仍然保持SM2=1。若SM2=0,则不属于多机通信情况,接收到一帧数据后,无论第9位是0还是1,都置中断标志RI=1,接收到的数据装入接收/发送缓冲器中。工作方式1时,若SM2=1,则只有接收到有效停止位时,中断标志RI才置1,以便接收下一帧数据。在工作方式0时,SM2应为0。
59三、中断系统1、中断结构图2、中断控制寄存器3、中断响应条件4、中断响应过程5、中断响应示意图6、汇编编程举例7、C51编程举例
601、中断结构图
612、中断控制寄存器同级内部优先级外部中断0最高定时器0外部中断1定时器1串行口最低
62
633、中断的响应条件中断源有请求,CPU允许所有中断源请求(EA=1),中断允许寄存器IE相应位置1。这样,在每个机器周期内,单片机对所有中断源都进行顺序检测,并可在任一个周期的S6期间,找到所有有效的中断请求,并对其优先级排队,只要满足下列条件:1.无同级或高级中断正在服务;2.现行指令执行到最后一个机器周期且已结束;3.若现行指令为RETI或需访问特殊功能寄存器IE或IP的指令时,执行完该指令且紧随其后的另一条指令也已执行完。单片机便在紧接着的下一个机器周期S1期间响应中断,否则将丢弃中断查询的结果。
644、中断响应过程单片机一旦响应中断,首先置位响应的优先级有效触发器,然后执行一个硬件子程序调用,把断点地址压入堆栈保护,然后将对应的中断入口地址值装入程序计数器PC,使程序转向该中断人口地址,以执行中断服务程序。单片机响应中断后,只保护断点而不保护现场(如累加器A、程序状态字寄存器PSW的内容),且不能清除串行口中断标志TI和RI,也无法清除外部中断请求信号INT0和INT1。故用户在编制程序时应予以考虑。
655、中断响应示意图特定程序入口地址:0000H复位中断向量地址中断源0003H外部中断0000BH定时器00013H外部中断1001BH定时器10023H串行口
666、汇编编程举例利用定时器T0定时,在P1.0端口输出周期性的方波信号,方波周期为2ms,已知晶振频率为6MHz。ORG0000HLJMPSTARTORG000BHLJMPCTC0ORG0100HSTART:MOVTMOD,#01HMOVTL0,#18HMOVTH0,#0FCHSETBEASETBET0HERE:SJMPHERECTC0:MOVTL0,#18HMOVTH0,#0FCHCPLP1.0RETI
677、C51编程举例#includesbitpinPulse=P1^0voidT0Int(void)interrupt1{TL0=0x18;TH0=0xfc;pinPulse=~pinPulse;}voidmain(void){TMOD=0x01;TL0=0x18;TH0=0xfc;EA=1;ET0=1;while(1);}
68第五章51单片机的扩展应用一、并行扩展设计二、串行扩展设计三、键盘及显示接口设计四、A/D、D/A接口设计五、LED、LCD接口设计
69一、串行扩展I/O口举例
70三、键盘及显示接口设计1、键盘接口电路举例2、LED显示接口电路举例3、LCD显示接口电路举例
711、键盘接口电路举例(2)矩阵式键盘(1)独立式键盘
72(1)独立式键盘
73(2)矩阵式键盘
74LED数码管
758×8点阵模块(1)
768×8点阵模块(2)
77点阵的基本连接方式
78显示图像的基本原理如下图所示,假设显示数字“0”12345678●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●●00003E4141413E00因此,形成的列代码为00H,00H,3EH,41H,41H,3EH,00H,00H;只要把这些代码分别送到相应的列线上面,即可实现“0”的数字显示。
79LCD显示接口电路举例
80基本特性1602的屏一般为标准屏,接口定义基本一样,但由于厂家的差异,默认对比度不完全相同,请读者在对比度调节端子自行加装电位器调节。内侧16引脚的座子为1602的插座。下图是1602液晶屏的实物图片,货物以实物为准。屏的引脚处标有引脚数。部分屏标有定义(视厂家而定)。本款配屏的引脚定义如下:
81数据端口GND(地)VCC(电源正极5V)V0(对比度调节端,通常直接接地)RS(读控制)RW(写控制)E(使能端)
82数据端口DB0(数据端口最低端)DB1DB2DB3DB4DB5DB6DB7(数据端口最高端)BLA(背光正极)BLK(背光负极)
83ADC0809的原理ADC0809是带有8位A/D转换器、8路多路开关以及微处理机兼容的控制逻辑的CMOS组件。它是逐次逼近式A/D转换器,可以和单片机直接接口。
84ADC0809原理图
85THANKYOUSUCCESS2022/10/1986可编辑