资源预览内容
第1页 / 共210页
第2页 / 共210页
第3页 / 共210页
第4页 / 共210页
第5页 / 共210页
第6页 / 共210页
第7页 / 共210页
第8页 / 共210页
第9页 / 共210页
第10页 / 共210页
亲,该文档总共210页,到这儿已超出免费预览范围,如果喜欢就下载吧!
资源描述
十天学会单片机 完整版十天学会单片机 完整版第一讲学单片机需要什么基础?什么是单片机、单片机能做什么、怎么开始学习单片机。学单片机需要的一些预备知识C51基础知识。了解TX-1C单片机学习板系统结构如何用TX-1C单片机学习板在短时间内掌握51单片机和C语言编程。KEIL工程建立详细介绍及KEIL软件使用方法从点亮实验板上的一个发光二极管开始学单片机需要什么基础?1.与以前所学的知识关联很少;与以前所学的知识关联很少;2.只需要掌握很基本的数电模电知识,如只需要掌握很基本的数电模电知识,如二进制、十进制、十六进制之间的转换,二进制、十进制、十六进制之间的转换,与、或、非逻辑关系等;与、或、非逻辑关系等;3.对各种器件的概念基本上是从对各种器件的概念基本上是从0开始;开始;4.如果要用如果要用C语言编程,需具备简单的语言编程,需具备简单的C语语言基础;言基础;5.所有人都站在了同一起跑线上所有人都站在了同一起跑线上; 什么是单片机?什么是单片机?单板机单板机 将将CPU芯片、芯片、存储器存储器芯片、芯片、I/O接口接口芯片和芯片和简单的简单的I/O设备设备(小键盘、(小键盘、LED显示器)等装配显示器)等装配在一块印刷电路板上,再配上在一块印刷电路板上,再配上监控程序监控程序(固化(固化在在ROM中),就构成了一台单板微型计算机中),就构成了一台单板微型计算机(简称单板机)。(简称单板机)。单板机板机单单板板机机的的I/O设设备备简简单单,软软件件资资源源少少,使使用用不不方方便便。早早期期主主要要用用于于微微型型计计算算机机原原理理的的教教学学及及简简单单的测控系统的测控系统,现在已很少使用。,现在已很少使用。 单片机单片机 在一片集成电路芯片上集成微处理器、在一片集成电路芯片上集成微处理器、存储器、存储器、I/O接口电路,从而构成了接口电路,从而构成了单芯片单芯片微型计算机,即单片机微型计算机,即单片机。 Intel公司推出了公司推出了MCS-51系列单片机:系列单片机:集成集成 8位位CPU、4K字字节节ROM、128字节字节RAM、4个个8位并口、位并口、1个个全双工串行口、全双工串行口、2个个16位定时位定时/计数器。寻址计数器。寻址范围范围64K,并有控制功能较强的布尔处理器。,并有控制功能较强的布尔处理器。单板机板机单片机片机单片机能做什么实物展示用到单片机的项目经验介绍1. 手持粮库温度寻检设备2.毕设答辩打分器3.电话台灯4.自动感应水龙头凡是与控制或简单计算有关的电子设备都可以用单片机来实现,再根据具体实际情况选择不同性能的单片机,如:atmel,stc,pic,avr,凌阳,80C51,arm等工业自动化:数据采集、测控技术。智能仪器仪表:数字示波器、数字信号源、数字万用表、感应电流表等。消费类电子产品:洗衣机、电冰箱、空调机、电视机、微波炉、手机、IC卡、汽车电子设备等。通讯方面:调制解调器、程控交换技术、手机、小灵通等。武器装备:飞机、军舰、坦克、导弹、航天飞机、鱼雷制导、智能武器等。等等.怎么开始学习?实践第一。补充必要的理论知识,即缺什么补什么。做工程项目积累经验。(可在网络上搜集题目,也可自己有什么想法大胆的去试验)预备知识电平特性电平特性2进制与进制与16进制的表示及转换进制的表示及转换二进制数的逻辑运算二进制数的逻辑运算8051单片机介绍单片机介绍C51基础知识基础知识关于电平特性数字电路中只有两种电平:高和低(本课程中)定义单片机为TTL电平: 高 +5V 低 0VRS232电平:计算机的串口 高 -12V 低+12V 所以计算机与单片机之间通讯时需要加电平转换芯片max232(实验板上左下角)。二进制数字电路中的两种电平特性决定了它0 0 6 1101 171112 10810003 11910014 1001010105 10111 1011十六进制是二进制的简短表示形式。 十进制中的0-15分别表示为十六进制的0、1、2、3、4、5、6、7、8、9、A、B、C、D、E、F熟练掌握二进制与十六进制之间的转换。 规律:一般把四个二进制数放在一起转换成一个十六进制数,转换时先把二进制数转换成十进制数,再把十进制数转换成十六进制数。如:0001B - 1 - 1H B表示为二进制,H为十六进制 1001B - 9 - 9H 1010B - 10 - AH 0010 1100 - 44 - 2CH 各种进位制的对应关系 十进制十进制二进制二进制十六进制十六进制十进制十进制二进制二进制十六进制十六进制000910019111101010A2102111011B3113121100C41004131101D51015141110E61106151111F71117161000010810008二进制数的逻辑运算二进制数的逻辑运算1.“与与”运算运算 “与”运算是实现“必须都有,否则就没有”这种逻辑关系的一种运算。 运算符为“ ”, 其运算规则如下:00=0, 01=10=0, 11=1 2.“或或”运算运算 “或”运算是实现“只要其中之一有,就有”这种逻辑关系的一种运算, 其运算符为“+”。 “或”运算规则如下:0+0=0, 0+1=1+0=1, 1+1=13.“非非”运算运算 “非”运算是实现“求反”这种逻辑的一种运算,如变量A的“非”运算记作 。 其运算规则如下: A4.“异或异或”运算运算 “异或”运算是实现“必须不同, 否则就没有”这种逻辑的一种运算, 运算符为“”。其运算规则是: 80C51 80C51系列介绍系列介绍 Intel的的:80C31、80C51、87C51,80C32、80C52、87C52等;等; ATMEL的:的:89C51、89C52、89C2051等;等; Philips、华邦、邦、Dallas 、STC Siemens(Infineon)等公司的等公司的许多多产品品 。补充:关于型号的介充:关于型号的介绍 80C51是是MCS-51系系列列中中的的一一个个典典型型品品种种;其其它它厂厂商商以以8051为基基核核开开发出出的的CMOS工工艺单片片机机产品品统称称为80C51系系列列。当当前前常常用用的的80C51系列系列单片机主要片机主要产品有:品有:80C5180C51的引脚封装的引脚封装总线型总线型非总线型非总线型P3P3P3P3第二功能各引脚功能定义:P3.0:RXD串行口输入P3.1:TXD串行口输出P3.2:INT0外部中断0输入P3.3:INT1外部中断1输入P3.4:T0定时器0外部输入P3.5:T1定时器1外部输入P3.6:WR外部写控制P3.7:RD外部读控制 总线(BUS)是计算机各部件之间传送信息的公共通道。微机中有内部总线和外部总线两类。内部总线是CPU内部之间的连线。外部总线是指CPU与其它部件之间的连线。 外部总线有三种: 数据总线DB(Data Bus), 地址总线 AB(Address Bus)和控制总线 CBControl Bus)。CPU:由运算和控制逻辑组成,同时还包括:由运算和控制逻辑组成,同时还包括中断系统和部分外部特殊功能寄存器;中断系统和部分外部特殊功能寄存器;RAM:用以存放可以读写的数据,如运算的:用以存放可以读写的数据,如运算的中间结果、最终结果以及欲显示的数据;中间结果、最终结果以及欲显示的数据;ROM:用以存放程序、一些原始数据和表格;:用以存放程序、一些原始数据和表格;I/O口:四个口:四个8位并行位并行I/O口,既可用作输入,口,既可用作输入,也可用作输出;也可用作输出;T/C:两个定时:两个定时/记数器,既可以工作在定时记数器,既可以工作在定时模式,也可以工作在记数模式;模式,也可以工作在记数模式;五个中断源的中断控制系统;五个中断源的中断控制系统;一个全双工一个全双工UART(通用异步接收发送器)(通用异步接收发送器)的串行的串行I/O口,用于实现单片机之间或单片机口,用于实现单片机之间或单片机与微机之间的串行通信;与微机之间的串行通信;片内振荡器和时钟产生电路,石英晶体和微片内振荡器和时钟产生电路,石英晶体和微调电容需要外接。最高振荡频率取决于单片调电容需要外接。最高振荡频率取决于单片机型号及性能。机型号及性能。C51知识C语言是一种编译型程序设计语言,它兼顾了多种高级语言的特点,并具备汇编语言的功能。目前,使用C语言进行程序设计已经成为软件开发的一个主流。用C语言开发系统可以大大缩短开发周期,明显增强程序的可读性,便于改进、扩充和移植。而针对8051的C语言日趋成熟,成为了专业化的实用高级语言。C C语言作为一种非常方便的语言而得到广泛语言作为一种非常方便的语言而得到广泛的支持,很多硬件开发都用的支持,很多硬件开发都用C C语言编程,如:语言编程,如:各种单片机、各种单片机、DSPDSP、ARMARM等等. .C C语言程序本身不依赖于机器硬件系统,基语言程序本身不依赖于机器硬件系统,基本上不作修改就可将程序从不同的单片机中本上不作修改就可将程序从不同的单片机中移植过来。移植过来。C C提供了很多数学函数并支持浮点运算,开提供了很多数学函数并支持浮点运算,开发效率高,故可缩短开发时间,增加程序可发效率高,故可缩短开发时间,增加程序可读性和可维护性。读性和可维护性。 C-51C-51的特点的特点C-51C-51与与ASM-51ASM-51相比,有如下优点:相比,有如下优点:1.1.对单片机的指令系统不要求了解,仅对单片机的指令系统不要求了解,仅要求对要求对8051 8051 的存贮器结构有初步了解;的存贮器结构有初步了解;2.2.寄存器分配、不同存贮器的寻址及数寄存器分配、不同存贮器的寻址及数据类型等细节可由编译器管理;据类型等细节可由编译器管理;3.3.程序有规范的结构,可分成不同的函程序有规范的结构,可分成不同的函数,这种方式可使程序结构化;数,这种方式可使程序结构化;4.4.提供的库包含许多标准子程序,具有提供的库包含许多标准子程序,具有较强的数据处理能力;较强的数据处理能力;5.5.由于具有方便的模块化编程技术,使由于具有方便的模块化编程技术,使已编好程序可容易地移植;已编好程序可容易地移植;C C5151的数据类型的数据类型基本数据类型基本数据类型类型类型符号符号关键字关键字数的表示范围数的表示范围所占位数所占位数整整型型字字符符型型实实型型有有无无(signed) int16-3276832767(signed) short16-3276832767(signed) long32-2147483648214748364716unsigned int0655353204294967295unsigned long intunsigned short int16065535有有float323.4e-383.4e38有有double641.7e-3081.7e308有有char8-128127无无unsigned char80255C C语言中的基本数据类型语言中的基本数据类型类型类型符号符号关键字关键字数的表示范围数的表示范围所占位数所占位数整整型型字字符符型型实实型型有有无无(signed) int16-3276832767(signed) short16-3276832767(signed) long32-2147483648214748364716unsigned int0655353204294967295unsigned long intunsigned short int16065535有有float323.4e-383.4e38有有double641.7e-3081.7e308有有char8-128127无无unsigned char80255C C5151的数据类型扩充定义的数据类型扩充定义sfr:sfr:特殊功能寄存器声明特殊功能寄存器声明sfr16:sfrsfr16:sfr的的1616位数据声明位数据声明sbit:sbit:特殊功能位声明特殊功能位声明bitbit: :位变量声明位变量声明例:例:sfr SCON = 0X98;sfr SCON = 0X98; sfr16 T2 = 0xCC; sfr16 T2 = 0xCC; sbit OV = PSW2; sbit OV = PSW2;例:例:数据类型数据类型 变量名变量名char var1;char var1;bit flags;bit flags;unsigned char vextor10;unsigned char vextor10;int wwww;int wwww;注意:变量名不能用注意:变量名不能用C C语言中的关语言中的关键字表示。键字表示。C-51C-51数据的存储类型数据的存储类型C-51C-51的包含的头文件的包含的头文件通常有通常有: :reg51.h reg52.h math.h ctype.h reg51.h reg52.h math.h ctype.h stdio.h stdlib.h absacc.hstdio.h stdlib.h absacc.h常用有常用有: :reg51.h reg52.hreg51.h reg52.h (定义特殊功能寄存器和位寄存器);(定义特殊功能寄存器和位寄存器); math.h math.h (定义常用数学运算);(定义常用数学运算); C-51C-51的运算符的运算符与与C C语言基本相同:语言基本相同:+ - * /+ - * / (加(加 减减 乘乘 除)除) = = (位右移(位右移 位左移)位左移)& |& | ( (按位与按位与 按位或按位或) ) ( (按位异或按位异或 按位取反按位取反) ) C-51C-51的基本语句的基本语句 与标准与标准C C语言基本相同:语言基本相同: if if 选择语言选择语言 while while 循环语言循环语言 for for 循环语言循环语言 switch/case switch/case 多分支选择语言多分支选择语言 do-while do-while 循环语言循环语言 中断服务程序中断服务程序函数名()函数名()interrupt interrupt n n using using m m 函数内部实现函数内部实现 . . I/OI/O口定义口定义sbit beep=P23;sbit beep=P23;单片机主要掌握以下几点最小系统能够运行起来的必要条件。 1.电源 2.晶振3.复位电路对单片机任意IO口的随意操作 1.输出控制电平高低2.输出检测电平高低。定时器:重点掌握最常用的方式2中断:外部中断、定时器中断、串口中断串口通信:单片机之间、单片机与计算机间KEIL的使用掌握KEIL工程的建立和软件的开发;掌握KEIL中软件仿真的基本应用;掌握用KEIL直接硬件仿真TX-1C单片机学习板的方法Main 函数格式:void main()特点:无返回值,无参。任何一个C程序有且仅有一个main函数,它是整个程序开始执行的入口。例:void main() 总程序从这里开始执行; 其他语句; 课后练习对照TX-1C单片机学习板原理图写程序用位操作和总线操作两种方法完成以下题目1.熟练建立KEIL工程2.点亮第一个发光管.3.点亮最后一个发光管4.点亮1、3、5、75.点亮二、四、五、六6.尝试让第一个发光管闪烁7.尝试设计出流水灯程序自己动手实践需要硬件材料DIP40脚座一个。杜邦线,单头带冒,40根。单排针 两排。小电路板一块。DS12C887 一片(旧10元,新22元)。焊锡、单片机工作的基本时序单片机工作的基本时序 机器周期和指令周期机器周期和指令周期 (1) 振荡周期振荡周期: 也称时钟周期也称时钟周期, 是指为单片机提是指为单片机提供时钟脉冲信号的振荡源的周期,供时钟脉冲信号的振荡源的周期,TX实验板上为实验板上为11.0592MHZ。 (2) 状态周期状态周期: 每个状态周期为时钟周期的每个状态周期为时钟周期的 2 倍倍, 是振荡周期经二分频后得到的。是振荡周期经二分频后得到的。 (3) 机器周期机器周期: 一个机器周期一个机器周期包含包含 6 个状态周个状态周期期S1S6, 也就是也就是 12 个时钟周期个时钟周期。 在一个机器周期在一个机器周期内内, CPU可以完成一个独立的操作。可以完成一个独立的操作。 (4) 指令周期指令周期: 它是指它是指CPU完成一条操作所需完成一条操作所需的全部时间。的全部时间。 每条指令执行时间都是有一个或几个每条指令执行时间都是有一个或几个机器周期组成。机器周期组成。MCS - 51 系统中系统中, 有单周期指令、有单周期指令、双周期指令和四周期指令。双周期指令和四周期指令。 第二讲 如何申请免费样片简单延时程序子程序调用带参数子程序设计C51库函数的方便调用如何驱动蜂鸣器如何驱动继电器集电极开路的概念及应用。 While (表达式)语句(内部也可为空)特点:先判断表达式,后执行语句。原则:若表达式不是0,即为真,那么执行语句。否则跳出while 语句。For (表达式1;表达式2;表达式3) 语句(内部可为空)执行过程:1.求解一次表达式1.2.求解表达式2,若其值为真(非0 即为真),则执行for中语句。然后执行第3步。否则结束for 语句,直接跳出,不再执行第3步。3.求解表达式3.4.跳到第2步重复执行。集电极开路典型图课后练习1.第一个发光管以间隔第一个发光管以间隔200ms闪烁闪烁2.8个发光管由上至下间隔个发光管由上至下间隔1s流动,其中每个管亮流动,其中每个管亮500ms,灭灭500ms,亮时蜂鸣器响,灭时关闭蜂鸣器,一直重复下去。亮时蜂鸣器响,灭时关闭蜂鸣器,一直重复下去。3.8个发光管来回流动,第个管亮个发光管来回流动,第个管亮100ms,流动时让蜂鸣器发出流动时让蜂鸣器发出“滴滴滴滴”声。声。4.用用8个发光管演示出个发光管演示出8位二进制数累加过程。位二进制数累加过程。5.8个发光管间隔个发光管间隔200ms由上至下,再由下至上,再重复一次,由上至下,再由下至上,再重复一次,然后全部熄灭再以然后全部熄灭再以300ms间隔全部闪烁间隔全部闪烁5次。重复此过程。次。重复此过程。6.间隔间隔300ms第一次一个管亮流动一次,第二次两个管亮流动,第一次一个管亮流动一次,第二次两个管亮流动,依次到依次到8个管亮,然后重复整个过程。个管亮,然后重复整个过程。7.间隔间隔300ms先奇数亮再偶数亮,循环三次;一个灯上下循环先奇数亮再偶数亮,循环三次;一个灯上下循环三次;两个分别从两边往中间流动三次;再从中间往两边流三次;两个分别从两边往中间流动三次;再从中间往两边流动三次;动三次;8个全部闪烁个全部闪烁3次;关闭发光管,程序停止。次;关闭发光管,程序停止。第三讲数码管是如何显示出字符的数码管静态显示与动态显示原理中断概念单片机的定时器应用显示器及其接口显示器及其接口单片机系统中常用的显示器有: 发光二极管LED(Light Emitting Diode)显示器、液晶LCD(Liquid Crystal Display)显示器、CRT显示器等。LED、LCD显示器有两种显示结构:段显示(7段、米字型等)和点阵显示(58、88点阵等)。 使用LED显示器时,要注意区分这两种不同的接法。为了显示数字或字符,必须对数字或字符进行编码。七段数码管加上一个小数点,共计8段。因此为LED显示器提供的编码正好是一个字节。TX实验板用共阴LED显示器,根据电路连接图显示16进制数的编码已列在下表。共阴极共阳极共阴数码管码表 0x3f , 0x06 , 0x5b , 0x4f , 0x66 , 0x6d , 0 1 2 3 4 5 0x7d , 0x07 , 0x7f , 0x6f , 0x77 , 0x7c , 6 7 8 9 A B 0x39 , 0x5e , 0x79 , 0x71 , 0x00 C D E F 无显示 LED数码显示方式及电路数码显示方式及电路 静态显示方式静态显示方式LED显示器工作方式有两种:静态显示方式和动态显示方式。静态显示的特点是每个数码管的段选必须接一个8位数据线来保持显示的字形码。当送入一次字形码后,显示字形可一直保持,直到送入新字形码为止。这种方法的优点是占用CPU时间少,显示便于监测和控制。缺点是硬件电路比较复杂,成本较高。 动态显示 动态显示的特点是将所有位数码管的段选线并联在一起,由位选线控制是哪一位数码管有效。选亮数码管采用动态扫描显示。所谓动态扫描显示即轮流向各位数码管送出字形码和相应的位选,利用发光管的余辉和人眼视觉暂留作用,使人的感觉好像各位数码管同时都在显示。动态显示的亮度比静态显示要差一些,所以在选择限流电阻时应略小于静态显示电路中的。 中断系统中断系统3.1 80C51的中断系的中断系统 3.1.1 80C513.1.1 80C51的中断系的中断系统结构构一、中断的概念一、中断的概念 CPUCPU在在处理某一事件理某一事件A A时,发生了另一事件生了另一事件B B请求求CPUCPU迅速去迅速去处理(理(中断中断发生生);); CPUCPU暂时中断当前的工作,中断当前的工作,转去去处理事件理事件B B(中断响中断响应和中断服和中断服务);); 待待CPUCPU将事件将事件B B处理完理完毕后,再回到原来事后,再回到原来事件件A A被中断的地方被中断的地方继续处理事件理事件A A(中断返回中断返回),这一一过程称程称为中断中断 。MCS-51单片机的中断系统结构执行主程序主程序继续执行主程序断点中断请求中断响应执行中断处理程序中断返回引起引起CPU中断的根源,称为中断的根源,称为中断源中断源。中断源向。中断源向CPU提出的提出的中断请求。中断请求。CPU暂时中断原来的事务暂时中断原来的事务A,转去处理事件,转去处理事件B。对。对事件事件B处理完毕后,再回到原来被中断的地方(即处理完毕后,再回到原来被中断的地方(即断点断点),称),称为中断返回。实现上述中断功能的部件称为为中断返回。实现上述中断功能的部件称为中断系统中断系统(中断(中断机构)。机构)。 随着计算机技术的应用,人们发现中断技随着计算机技术的应用,人们发现中断技术不仅解决了快速主机与慢速术不仅解决了快速主机与慢速I/O设备的数据设备的数据传送问题,而且还具有如下优点:传送问题,而且还具有如下优点: 分时操作分时操作。CPU可以分时为多个可以分时为多个I/O设备服设备服务,提高了计算机的利用率;务,提高了计算机的利用率;实时响应实时响应。CPU能够及时处理应用系统的随能够及时处理应用系统的随机事件,系统的实时性大大增强;机事件,系统的实时性大大增强;可靠性高可靠性高。CPU具有处理设备故障及掉电等具有处理设备故障及掉电等突发性事件能力,从而使系统可靠性提高。突发性事件能力,从而使系统可靠性提高。80C51中断系统的结构中断系统的结构 80C51的中断系统有的中断系统有5个中断源个中断源(8052有 6个) ,2个优先级,可实现二级中断嵌套个优先级,可实现二级中断嵌套 。 1 1、(P3.2P3.2)可可由由IT0(TCON.0)IT0(TCON.0)选择其其为低低电平平有有效效还是是下下降降沿沿有有效效。当当CPUCPU检测到到P3.2P3.2引引脚脚上上出出现有有效效的的中中断断信信号号时,中中断断标志志IE0(TCON.1)IE0(TCON.1)置置1 1,向,向CPUCPU申申请中断。中断。 2 2、(P3.3(P3.3)可可由由IT1(TCON.2)IT1(TCON.2)选择其其为低低电平平有有效效还是是下下降降沿沿有有效效。当当CPUCPU检测到到P3.3P3.3引引脚脚上上出出现有有效效的的中中断断信信号号时,中中断断标志志IE1(TCON.3)IE1(TCON.3)置置1,1,向向CPUCPU申申请中断。中断。 3 3、TF0TF0(TCON.5TCON.5),片片内内定定时/ /计数数器器T0T0溢溢出出中中断断请求求标志志。当当定定时/ /计数数器器T0T0发生生溢出溢出时,置位,置位TF0TF0,并向,并向CPUCPU申申请中断。中断。 4 4、TF1TF1(TCON.7TCON.7),片内定),片内定时/ /计数器数器T1T1溢溢出中断出中断请求求标志。当定志。当定时/ /计数器数器T1T1发生溢生溢出出时,置位,置位TF1TF1,并向,并向CPUCPU申申请中断。中断。 5 5、RIRI(SCON.0SCON.0)或)或TITI(SCON.1SCON.1),串行口中),串行口中断断请求求标志。当串行口接收完一志。当串行口接收完一帧串行数据串行数据时置位置位RIRI或当串行口或当串行口发送完一送完一帧串行数据串行数据时置位置位TITI,向,向CPUCPU申申请中断。中断。 二、中断请求标志二、中断请求标志1、TCON的中断标志的中断标志IT0(TCON.0),外部中断),外部中断0触发方式控制位。触发方式控制位。当当IT0=0时,为电平触发方式。时,为电平触发方式。当当IT0=1时,为边沿触发方式(下降沿有效)。时,为边沿触发方式(下降沿有效)。IE0(TCON.1),外部中断),外部中断0中断请求标志位。中断请求标志位。IT1(TCON.2),外部中断),外部中断1触发方式控制位。触发方式控制位。IE1(TCON.3),外部中断),外部中断1中断请求标志位。中断请求标志位。TF0(TCON.5),定时),定时/计数器计数器T0溢出中断请求标志位。溢出中断请求标志位。TF1(TCON.7),定时),定时/计数器计数器T1溢出中断请求标志位。溢出中断请求标志位。 2、SCON的中断标志的中断标志RI(SCON.0),串行口接收中断标志位。当允),串行口接收中断标志位。当允许串行口接收数据时,每接收完一个串行帧,由许串行口接收数据时,每接收完一个串行帧,由硬件置位硬件置位RI。注意,。注意,RI必须由软件清除。必须由软件清除。TI(SCON.1),串行口发送中断标志位。当),串行口发送中断标志位。当CPU将一个发送数据写入串行口发送缓冲器时,将一个发送数据写入串行口发送缓冲器时,就启动了发送过程。每发送完一个串行帧,由硬就启动了发送过程。每发送完一个串行帧,由硬件置位件置位TI。CPU响应中断时,不能自动清除响应中断时,不能自动清除TI,TI必须由软件清除。必须由软件清除。 一、中断允许控制一、中断允许控制 CPU对中断系统所有中断以及某个中断源的开放和屏对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器蔽是由中断允许寄存器IE控制的。控制的。3.1.3 80C513.1.3 80C51中断的控制中断的控制 EX0(IE.0),外部中断,外部中断0允许位;允许位;ET0(IE.1),定时,定时/计数器计数器T0中断允许位;中断允许位; EX1(IE.2),外部中断,外部中断0允许位;允许位;ET1(IE.3),定时,定时/计数器计数器T1中断允许位;中断允许位;ES(IE.4),串行口中断允许位;,串行口中断允许位;EA (IE.7), CPU中断允许(总允许)位。中断允许(总允许)位。二、中断优先级控制二、中断优先级控制 80C51单片机有两个中断优先级,即可实现二级单片机有两个中断优先级,即可实现二级中断服务嵌套。每个中断源的中断优先级都是由中断中断服务嵌套。每个中断源的中断优先级都是由中断优先级寄存器优先级寄存器IP中的相应位的状态来规定的中的相应位的状态来规定的 。PX0(IP.0),外部中断),外部中断0优先级设定位;优先级设定位;PT0(IP.1),定时),定时/计数器计数器T0优先级设定位;优先级设定位;PX1(IP.2),外部中断),外部中断0优先级设定位;优先级设定位;PT1(IP.3),定时),定时/计数器计数器T1优先级设定位;优先级设定位;PS (IP.4),串行口优先级设定位;),串行口优先级设定位;PT2 (IP.5) ,定时,定时/计数器计数器T2优先级设定位。优先级设定位。PX0(IPH.0),外部中断),外部中断0优先级设定位;优先级设定位;PT0(IPH.1),定时),定时/计数器计数器T0优先级设定位;优先级设定位;PX1(IPH.2),外部中断),外部中断0优先级设定位;优先级设定位;PT1(IPH.3),定时),定时/计数器计数器T1优先级设定位;优先级设定位;PS (IPH.4),串行口优先级设定位;),串行口优先级设定位;PT2 (IPH.5) ,定时,定时/计数器计数器T2优先级设定位。优先级设定位。而而80C52单片机有四个中断优先级,即可实现四级单片机有四个中断优先级,即可实现四级中断服务嵌套。每个中断源的中断优先级由中断优中断服务嵌套。每个中断源的中断优先级由中断优先级寄存器先级寄存器IP和和IPH中的相应位的状态来规定的中的相应位的状态来规定的 。 同一优先级中的中断申请不止一个时,则有中同一优先级中的中断申请不止一个时,则有中断优先权排队问题。同一优先级的中断优先权排队,断优先权排队问题。同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列如由中断系统硬件确定的自然优先级形成,其排列如所示:所示:设置设置52单片机的单片机的4个中断源个中断源,使他们的优顺序使他们的优顺序为为T1,INT1,INT0,T0.IPH = 0X08;PT1 = 1;IP = 0X40;PX1 = 1;80C51单片机的中断优先级有三条原则:单片机的中断优先级有三条原则:CPU同时接收到几个中断时,同时接收到几个中断时,首先响应优先级别最首先响应优先级别最高的中断请求高的中断请求。正在进行的中断过程正在进行的中断过程不能被新的同级或低优先级的不能被新的同级或低优先级的中断请求所中断中断请求所中断。正在进行的低优先级中断服务,正在进行的低优先级中断服务,能被高优先级中断能被高优先级中断请求所中断请求所中断。 为了实现上述后两条原则,为了实现上述后两条原则,中断系统内部设有两中断系统内部设有两个用户不能寻址的优先级状态触发器。个用户不能寻址的优先级状态触发器。其中一个置其中一个置1,表示正在响应高优先级的中断,它将阻断后来所,表示正在响应高优先级的中断,它将阻断后来所有的中断请求;另一个置有的中断请求;另一个置1,表示正在响应低优先级,表示正在响应低优先级中断,它将阻断后来所有的低优先级中断请求。中断,它将阻断后来所有的低优先级中断请求。3.2 80C51单片机中断处理过程单片机中断处理过程 中断响应条件中断响应条件 中断源有中断请求;中断源有中断请求; 此中断源的中断允许位为此中断源的中断允许位为1; CPU开中断(即开中断(即EA=1)。)。以上三条同时满足时,以上三条同时满足时,CPU才有可能响应才有可能响应中断中断。3.2.1 3.2.1 中断响中断响应条件和条件和时间 3.3 80C51的定时的定时/计数器计数器 实现定时功能,实现定时功能,比较方便的办法是利用单比较方便的办法是利用单片机内部的定时片机内部的定时/计数器计数器。也可以采用下面三。也可以采用下面三种方法:种方法:软件定时软件定时:软件定时不占用硬件资源,但占用了:软件定时不占用硬件资源,但占用了CPU时间,降低了时间,降低了CPU的利用率。的利用率。采用时基电路定时采用时基电路定时:例如采用:例如采用555电路,外接必要电路,外接必要的元器件(电阻和电容),即可构成硬件定时电路。的元器件(电阻和电容),即可构成硬件定时电路。但在硬件连接好以后,定时值与定时范围不能由软但在硬件连接好以后,定时值与定时范围不能由软件进行控制和修改,即不可编程。件进行控制和修改,即不可编程。采用可编程芯片定时采用可编程芯片定时:这种定时芯片的定时值及定:这种定时芯片的定时值及定时范围很容易用软件来确定和修改,此种芯片定时时范围很容易用软件来确定和修改,此种芯片定时功能强,使用灵活。在单片机的定时功能强,使用灵活。在单片机的定时/计数器不够用计数器不够用时,可以考虑进行扩展。时,可以考虑进行扩展。3.3.1 3.3.1 定定时/ /计数器的数器的结构和工作原理构和工作原理 一、定时一、定时/计数器的结构计数器的结构 定时定时/计数器的实质是加计数器的实质是加1计数器(计数器(16位),由高位),由高8位和低位和低8位两个寄存器组成。位两个寄存器组成。TMOD是定时是定时/计数器的工作方式寄存计数器的工作方式寄存器,确定工作方式和功能;器,确定工作方式和功能;TCON是控制寄存器,控制是控制寄存器,控制T0、T1的启动和停止及设置溢出标志的启动和停止及设置溢出标志。 二、定时二、定时/计数器的工作原理计数器的工作原理 加加1计数器计数器输入的计数脉冲有两个来源输入的计数脉冲有两个来源,一个是由一个是由系统的时钟振荡器输出脉冲经系统的时钟振荡器输出脉冲经12分频后送来;一个分频后送来;一个是是T0或或T1引脚输入的外部脉冲源。每来一个脉冲计引脚输入的外部脉冲源。每来一个脉冲计数器加数器加1,当加到计数器为全,当加到计数器为全1时,再输入一个脉冲时,再输入一个脉冲就使计数器回零,且计数器的溢出使就使计数器回零,且计数器的溢出使TCON中中TF0或或TF1置置1,向,向CPU发出中断请求(定时发出中断请求(定时/计数器中计数器中断允许时)。如果定时断允许时)。如果定时/计数器工作于定时模式,则计数器工作于定时模式,则表示定时时间已到;如果工作于计数模式,则表示表示定时时间已到;如果工作于计数模式,则表示计数值已满。计数值已满。 可见,由溢出时计数器的值减去计数初值才是加可见,由溢出时计数器的值减去计数初值才是加1计数器的计数值计数器的计数值。 设置为定时器模式时设置为定时器模式时,加,加1计数器是对内部机器周期计数器是对内部机器周期计数(计数(1个机器周期等于个机器周期等于12个振荡周期,即计数频率个振荡周期,即计数频率为晶振频率的为晶振频率的1/12)。)。计数值计数值N乘以机器周期乘以机器周期Tcy就就是定时时间是定时时间t 。设置为设置为计数器模式时计数器模式时,外部事件计数脉冲由,外部事件计数脉冲由T0或或T1引脚输入到计数器。在每个机器周期的引脚输入到计数器。在每个机器周期的S5P2期间采期间采样样T0、T1引脚电平。当某周期采样到一高电平输入,引脚电平。当某周期采样到一高电平输入,而下一周期又采样到一低电平时,则计数器加而下一周期又采样到一低电平时,则计数器加1,更,更新的计数值在下一个机器周期的新的计数值在下一个机器周期的S3P1期间装入计数期间装入计数器。由于检测一个从器。由于检测一个从1到到0的下降沿需要的下降沿需要2个机器周期,个机器周期,因此要求被采样的电平至少要维持一个机器周期。当因此要求被采样的电平至少要维持一个机器周期。当晶振频率为晶振频率为12MHz时时,最高计数频率不超过,最高计数频率不超过1/2MHz,即计数脉冲的周期要大于,即计数脉冲的周期要大于2 s。 3.3.2 定时定时/计数器的控制计数器的控制 80C51单片机定时单片机定时/计数器的工作由两个特殊功计数器的工作由两个特殊功能寄存器控制。能寄存器控制。TMOD用于设置其工作方式;用于设置其工作方式;TCON用于控制其启动和中断申请。用于控制其启动和中断申请。一、工作方式寄存器一、工作方式寄存器TMOD 工作方式寄存器工作方式寄存器TMOD用于设置定时用于设置定时/计数器的计数器的工作方式,低四位用于工作方式,低四位用于T0,高四位用于,高四位用于T1。其格式。其格式如下:如下:GATE:门控位。:门控位。GATE0时,只要用软件使时,只要用软件使TCON中的中的TR0或或TR1为为1,就可以启动定时,就可以启动定时/计数器工作;计数器工作;GATA1时,时,要用软件使要用软件使TR0或或TR1为为1,同时外部中断引脚或也为高电,同时外部中断引脚或也为高电平时,才能启动定时平时,才能启动定时/计数器工作。即此时定时器的启动多计数器工作。即此时定时器的启动多了一条件。了一条件。 :定时定时/计数模式选择位。计数模式选择位。 0为定时模式;为定时模式; =1为计数模式。为计数模式。M1M0:工作方式设置位。定时:工作方式设置位。定时/计数器有四种工作方式,由计数器有四种工作方式,由M1M0进行设置。进行设置。 二、控制寄存器二、控制寄存器TCON TCON的低的低4位用于控制外部中断位用于控制外部中断,已在前面介绍。已在前面介绍。TCON的高的高4位用于控位用于控制定时制定时/计数器的启动和中断申请。其格式如下:计数器的启动和中断申请。其格式如下:TF1(TCON.7):):T1溢出中断请求标志位。溢出中断请求标志位。T1计数溢出时由硬件自计数溢出时由硬件自动置动置TF1为为1。CPU响应中断后响应中断后TF1由硬件自动清由硬件自动清0。T1工作时,工作时,CPU可随时查询可随时查询TF1的状态。所以,的状态。所以,TF1可用作查询测试的标志。可用作查询测试的标志。TF1也可也可以用软件置以用软件置1或清或清0,同硬件置,同硬件置1或清或清0的效果一样。的效果一样。TR1(TCON.6):):T1运行控制位。运行控制位。TR1置置1时,时,T1开始工作;开始工作;TR1置置0时,时,T1停止工作。停止工作。TR1由软件置由软件置1或清或清0。所以,用软件可控制定时。所以,用软件可控制定时/计计数器的启动与停止。数器的启动与停止。TF0(TCON.5):):T0溢出中断请求标志位,其功能与溢出中断请求标志位,其功能与TF1类同。类同。TR0(TCON.4):):T0运行控制位,其功能与运行控制位,其功能与TR1类同。类同。 3.3.3 定时定时/计数器的工作方式计数器的工作方式 一、方式一、方式0 方式方式0为为13位计数位计数,由,由TL0的低的低5位(高位(高3位未用)和位未用)和TH0的的8位组成。位组成。TL0的低的低5位溢出时向位溢出时向TH0进位,进位,TH0溢出时,溢出时,置位置位TCON中的中的TF0标志,向标志,向CPU发出中断请求。发出中断请求。定时器模式时定时器模式时有有:Nt/ Tcy 计数初值计算的公式为:计数初值计算的公式为:定时器的初值还可以采用计数个数直接取补法获得定时器的初值还可以采用计数个数直接取补法获得。计数模式时,计数脉冲是计数模式时,计数脉冲是T0引脚上的外部脉冲。引脚上的外部脉冲。门控位门控位GATE具有特殊的作用。当具有特殊的作用。当GATE=0时,经反相后使时,经反相后使或门输出为或门输出为1,此时仅由,此时仅由TR0控制与门的开启,与门输出控制与门的开启,与门输出1时,控制开关接通,计数开始;时,控制开关接通,计数开始;当当GATE=1时时,由外中断引,由外中断引脚信号控制或门的输出,此时控制脚信号控制或门的输出,此时控制与门的开启由外中断引脚与门的开启由外中断引脚信号和信号和TR0共同控制共同控制。当。当TR0=1时,外中断引脚信号引脚的时,外中断引脚信号引脚的高电平启动计数高电平启动计数,外中断引脚信号引脚的,外中断引脚信号引脚的低电平停止计数低电平停止计数。这种方式常用来测量外中断引脚上正脉冲的宽度。这种方式常用来测量外中断引脚上正脉冲的宽度。 二、方式二、方式1 方式方式1的计数位数是的计数位数是16位,由位,由TL0作为低作为低8位、位、TH0作为高作为高8位,组成了位,组成了16位加位加1计数器计数器 。计数个数与计数初值的关系为:计数个数与计数初值的关系为: 三、方式三、方式2 方式方式2为自动重装初值的为自动重装初值的8位计数方式。位计数方式。 工作方式2特别适合于用作较精确的脉冲信号发生器。 计数个数与计数初值的关系为计数个数与计数初值的关系为: 四、方式四、方式3 方式方式3只适用于定时只适用于定时/计数器计数器T0,定时器定时器T1处于方式处于方式3时相当时相当于于TR1=0,停止计数。,停止计数。 工作方式工作方式3将将T0分成为两个独立的分成为两个独立的8位计数器位计数器TL0和和TH0 。 3.3.4 定时定时/计数器应用举例计数器应用举例 初始化程序应完成如下工作:初始化程序应完成如下工作:对对TMOD赋值,以确定赋值,以确定T0和和T1的工作方式。的工作方式。计算初值计算初值,并将其写入并将其写入TH0、TL0或或TH1、TL1。中断方式时,则对中断方式时,则对IE赋值,开放中断。赋值,开放中断。使使TR0或或TR1置位,启动定时置位,启动定时/计数器定时或计数。计数器定时或计数。 例例 利用定时利用定时/计数器计数器T1的方式的方式1,产生,产生10ms的定时,的定时,并使并使P1.0引脚上输出周期为引脚上输出周期为20ms的方波,采用中的方波,采用中断方式,设系统时钟频率为断方式,设系统时钟频率为12 MHz。解:解:1、计算计数初值、计算计数初值X:由于晶振为由于晶振为12 MHz,所以机器周期,所以机器周期Tcy为为1 s。所以:所以:Nt/ Tcy 10000/110000X655361000055536D8F0H即应将即应将D8H送入送入TH0中,中,F0H送入送入TL0中中 2、求、求T1的方式控制字的方式控制字TMOD: M1M0=01,GATE=0,C/T=0,可取方式控制,可取方式控制字为字为01H;1、利用定时、利用定时/计数器计数器T0从从P1.0输出周期为输出周期为1s的方波,的方波,让发光二极管以让发光二极管以1HZ闪烁,设晶振频率为闪烁,设晶振频率为12MHz。2、利用定时、利用定时/计数器计数器T1产生定时时钟产生定时时钟,由由P1口控制口控制8个发光二极管个发光二极管,使使8个指示灯依次一个一个闪动,闪动个指示灯依次一个一个闪动,闪动频率为频率为10次次/秒秒(8个灯依次亮一遍为一个周期个灯依次亮一遍为一个周期),循环。,循环。3、同时用两个定时器控制蜂鸣器发声,定时器、同时用两个定时器控制蜂鸣器发声,定时器0控控制频率,定时器制频率,定时器1控制同个频率持续的时间,间隔控制同个频率持续的时间,间隔300ms依次输出依次输出1,10,50,100,200,400,800,1k(hz)的方波。)的方波。4、用定时器以间隔、用定时器以间隔500MS在在6位数码管上依次显示位数码管上依次显示0、1、2、3.C、D、E、F,重复。,重复。 动态显示 动态显示的特点是将所有位数码管的段选线并联在一起,由位选线控制是哪一位数码管有效。这样一来,就没有必要每一位数码管配一个锁存器,从而大大地简化了硬件电路。选亮数码管采用动态扫描显示。所谓动态扫描显示即轮流向各位数码管送出字形码和相应的位选,利用发光管的余辉和人眼视觉暂留作用,使人的感觉好像各位数码管同时都在显示。动态显示的亮度比静态显示要差一些,所以在选择限流电阻时应略小于静态显示电路中的。 MCS-51单片机的中断系统结构执行主程序主程序继续执行主程序断点中断请求中断响应执行中断处理程序中断返回一、中断允许控制一、中断允许控制 CPU对中断系统所有中断以及某个中断源的开放和屏对中断系统所有中断以及某个中断源的开放和屏蔽是由中断允许寄存器蔽是由中断允许寄存器IE控制的。控制的。4.1 80C514.1 80C51中断的控制中断的控制 EX0(IE.0),外部中断,外部中断0允许位;允许位;ET0(IE.1),定时,定时/计数器计数器T0中断允许位;中断允许位; EX1(IE.2),外部中断,外部中断0允许位;允许位;ET1(IE.3),定时,定时/计数器计数器T1中断允许位;中断允许位;ES(IE.4),串行口中断允许位;,串行口中断允许位;EA (IE.7), CPU中断允许(总允许)位。中断允许(总允许)位。 同一优先级中的中断申请不止一个时,则有中同一优先级中的中断申请不止一个时,则有中断优先权排队问题。同一优先级的中断优先权排队,断优先权排队问题。同一优先级的中断优先权排队,由中断系统硬件确定的自然优先级形成,其排列如由中断系统硬件确定的自然优先级形成,其排列如所示:所示:4.2 80C51单片机中断处理过程单片机中断处理过程 中断响应条件中断响应条件 中断源有中断请求;中断源有中断请求; 此中断源的中断允许位为此中断源的中断允许位为1; CPU开中断(即开中断(即EA=1)。)。以上三条同时满足时,以上三条同时满足时,CPU才有可能响应才有可能响应中断中断。4.2.1 4.2.1 中断响中断响应条件和条件和时间 定定时/ /计数器的数器的结构和工作原理构和工作原理 一、定时一、定时/计数器的结构计数器的结构 定时定时/计数器的实质是加计数器的实质是加1计数器(计数器(16位),由高位),由高8位和低位和低8位两个寄存器组成。位两个寄存器组成。TMOD是定时是定时/计数器的工作方式寄存计数器的工作方式寄存器,确定工作方式和功能;器,确定工作方式和功能;TCON是控制寄存器,控制是控制寄存器,控制T0、T1的启动和停止及设置溢出标志的启动和停止及设置溢出标志。 4.2.2 定时定时/计数器的控制计数器的控制 80C51单片机定时单片机定时/计数器的工作由两个特殊功计数器的工作由两个特殊功能寄存器控制。能寄存器控制。TMOD用于设置其工作方式;用于设置其工作方式;TCON用于控制其启动和中断申请。用于控制其启动和中断申请。一、工作方式寄存器一、工作方式寄存器TMOD 工作方式寄存器工作方式寄存器TMOD用于设置定时用于设置定时/计数器的计数器的工作方式,低四位用于工作方式,低四位用于T0,高四位用于,高四位用于T1。其格式。其格式如下:如下:GATE:门控位。:门控位。GATE0时,只要用软件使时,只要用软件使TCON中的中的TR0或或TR1为为1,就可以启动定时,就可以启动定时/计数器工作;计数器工作;GATA1时,时,要用软件使要用软件使TR0或或TR1为为1,同时外部中断引脚,同时外部中断引脚INT0/1也为也为高电平时,才能启动定时高电平时,才能启动定时/计数器工作。即此时定时器的启计数器工作。即此时定时器的启动条件,加上了动条件,加上了INT0/1引脚为高电平这一条件。引脚为高电平这一条件。 :定时定时/计数模式选择位。计数模式选择位。 0为定时模式;为定时模式; =1为计数模式。为计数模式。M1M0:工作方式设置位。定时:工作方式设置位。定时/计数器有四种工作方式,由计数器有四种工作方式,由M1M0进行设置。进行设置。 二、控制寄存器二、控制寄存器TCON TCON的低的低4位用于控制外部中断位用于控制外部中断,已在前面介绍。已在前面介绍。TCON的高的高4位用于控位用于控制定时制定时/计数器的启动和中断申请。其格式如下:计数器的启动和中断申请。其格式如下:TF1(TCON.7):):T1溢出中断请求标志位。溢出中断请求标志位。T1计数溢出时由硬件自计数溢出时由硬件自动置动置TF1为为1。CPU响应中断后响应中断后TF1由硬件自动清由硬件自动清0。T1工作时,工作时,CPU可随时查询可随时查询TF1的状态。所以,的状态。所以,TF1可用作查询测试的标志。可用作查询测试的标志。TF1也可也可以用软件置以用软件置1或清或清0,同硬件置,同硬件置1或清或清0的效果一样。的效果一样。TR1(TCON.6):):T1运行控制位。运行控制位。TR1置置1时,时,T1开始工作;开始工作;TR1置置0时,时,T1停止工作。停止工作。TR1由软件置由软件置1或清或清0。所以,用软件可控制定时。所以,用软件可控制定时/计计数器的启动与停止。数器的启动与停止。TF0(TCON.5):):T0溢出中断请求标志位,其功能与溢出中断请求标志位,其功能与TF1类同。类同。TR0(TCON.4):):T0运行控制位,其功能与运行控制位,其功能与TR1类同。类同。 定时定时/计数器的工作方式计数器的工作方式 一、方式一、方式0 方式方式0为为13位计数位计数,由,由TL0的低的低5位(高位(高3位未用)和位未用)和TH0的的8位组成。位组成。TL0的低的低5位溢出时向位溢出时向TH0进位,进位,TH0溢出时,溢出时,置位置位TCON中的中的TF0标志,向标志,向CPU发出中断请求。发出中断请求。 二、方式二、方式1 方式方式1的计数位数是的计数位数是16位,由位,由TL0作为低作为低8位、位、TH0作为高作为高8位,组成了位,组成了16位加位加1计数器计数器 。计数个数与计数初值的关系为:计数个数与计数初值的关系为: 第四课练习1.利用动态扫描方法在六位数码管上显示出稳定的654321.2.用动态扫描方法和定时器1在数码管的前三位显示出秒表,精确到1%秒,即后两位显示1%秒,一直循环下去。3.利用动态扫描和定时器1在数码管上显示出从765432开始以1/10秒的速度往下递减直至765398并保持显示此数,与此同时利用定时器0以500MS速度进行流水灯从上至下移动,当数码管上数减到停止时,实验板上流水灯也停止然后全部开始闪烁,3秒后(用T0定时)流水灯全部关闭、数码管上显示出“HELLO”。到此保持住。键盘的应用1、键盘的分类、键盘的分类 键盘分编码键盘和非编码键盘。键盘上闭键盘分编码键盘和非编码键盘。键盘上闭合键的识别由专用的硬件编码器实现,并产合键的识别由专用的硬件编码器实现,并产生键编码号或键值的称为编码键盘,如计算生键编码号或键值的称为编码键盘,如计算机键盘机键盘.而靠软件编程来识别的称为非编码键盘;而靠软件编程来识别的称为非编码键盘; 在单片机组成的各种系统中,用的最多的是在单片机组成的各种系统中,用的最多的是非编码键盘。也有用到编码键盘的。非编码键盘。也有用到编码键盘的。非编码键盘有分为:独立键盘和行列式(又称为矩阵式)键盘。按键在闭合和断开时,触点会存在抖动现象:按键在闭合和断开时,触点会存在抖动现象: 数码管前三位显示一个跑表,从000到999之间以1%秒速度运行,当按下一个独立键盘时跑表停止,松开手后跑表继续运行。(用定时器设计表)。在上题的基础上,用另外三个独立键盘实现按下第一个时计时停止,按下第二个时计时开始,按下第三个是计数值清零从头开始。按下16个矩阵键盘依次在数码管上显示1-16的平方。如按下第一个显示1,第二个显示4.第六讲D/A & A/D转换器及其与单片机接口转换器及其与单片机接口D/A6.1 D/A转换器及其与单片机接口转换器及其与单片机接口 6.1.1 D/A6.1.1 D/A转换器的原理及主要技器的原理及主要技术指指标一、一、D/AD/A转换器的基本原理及分器的基本原理及分类型型电阻网阻网络D/AD/A转换器器 :输出电压输出电压 的大小与数字量具有对应的关系的大小与数字量具有对应的关系。 二、二、D/AD/A转换器的主要性能指器的主要性能指标1 1、分辨率、分辨率分辨率分辨率是指是指输入数字量的最低有效位(入数字量的最低有效位(LSBLSB)发生生变化化时,所所对应的的输出模出模拟量(量(电压或或电流)的流)的变化量。它反映了化量。它反映了输出模出模拟量的最小量的最小变化化值。分辨率与分辨率与输入数字量的位数有确定的关系,可以表示成入数字量的位数有确定的关系,可以表示成FS FS / / 。FSFS表示表示满量程量程输入入值,n n为二二进制位数。制位数。对于于5V5V的的满量程,采用位的量程,采用位的DACDAC时,分辨率,分辨率为5V/2565V/25619.5mV19.5mV;当采用当采用1212位的位的DACDAC时,分辨率,分辨率则为5V/40965V/40961.22mV1.22mV。显然,然,位数越多分辨率就越高。位数越多分辨率就越高。2 2、线性度性度线性度(也称非性度(也称非线性性误差)差)是是实际转换特性曲特性曲线与理想与理想直直线特性之特性之间的最大偏差。常以相的最大偏差。常以相对于于满量程的百分数量程的百分数表示。如表示。如是指是指实际输出出值与理与理论值之差在之差在满刻度刻度的的以内。以内。3、绝对精度和相对精度、绝对精度和相对精度绝对精度(简称精度)绝对精度(简称精度)是指在整个刻度范围内,任是指在整个刻度范围内,任一输入数码所对应的模拟量实际输出值与理论值之一输入数码所对应的模拟量实际输出值与理论值之间的最大误差。绝对精度是由间的最大误差。绝对精度是由DAC的增益误差(当的增益误差(当输入数码为全输入数码为全1时,实际输出值与理想输出值之差)、时,实际输出值与理想输出值之差)、零点误差(数码输入为全时,零点误差(数码输入为全时,DAC的非零输出值)的非零输出值)、非线性误差和噪声等引起的。绝对精度(即最大、非线性误差和噪声等引起的。绝对精度(即最大误差)应小于误差)应小于1个个LSB。相对精度相对精度与绝对精度表示同一含义,用最大误差相与绝对精度表示同一含义,用最大误差相对于满刻度的百分比表示。对于满刻度的百分比表示。4、建立时间、建立时间建立时间建立时间是指输入的数字量发生满刻度变化时,是指输入的数字量发生满刻度变化时,输出模拟信号达到满刻度值的输出模拟信号达到满刻度值的1/2LSB所需的时间。所需的时间。是描述是描述D/A转换速率的一个动态指标。转换速率的一个动态指标。电流输出型电流输出型DAC的建立时间短的建立时间短。电压输出型电压输出型DAC的的建立时间主要决定于运算放大器的响应时间建立时间主要决定于运算放大器的响应时间。根据。根据建立时间的长短,可以将建立时间的长短,可以将DAC分成超高速(分成超高速(1S)、高速(高速(101S)、中速()、中速(10010S)、低速)、低速(100S)几档。)几档。 应当注意,精度和分辨率具有一定的联系,但应当注意,精度和分辨率具有一定的联系,但概念不同。概念不同。DAC的位数多时,分辨率会提高,对的位数多时,分辨率会提高,对应于影响精度的量化误差会减小。但其它误差应于影响精度的量化误差会减小。但其它误差(如温度漂移、线性不良等)的影响仍会使(如温度漂移、线性不良等)的影响仍会使DAC的精度变差。的精度变差。6.1.2 DAC08326.1.2 DAC0832芯片及其与芯片及其与单片机接口片机接口 DAC0832 DAC0832是使用非常普遍的位是使用非常普遍的位D/AD/A转换器,由于其片器,由于其片内有内有输入数据寄存器,故可以直接与入数据寄存器,故可以直接与单片机接口。片机接口。DAC0832DAC0832以以电流形式流形式输出,当需要出,当需要转换为电压输出出时,可,可外接运算放大器。属于外接运算放大器。属于该系列的芯片系列的芯片还有有DAC0830DAC0830、DAC0831DAC0831,它,它们可以相互代可以相互代换。DAC0832DAC0832主要特性主要特性:分辨率位;分辨率位;电流建立流建立时间SS;数据数据输入可采用双入可采用双缓冲、冲、单缓冲或直通方式;冲或直通方式;输出出电流流线性度可在性度可在满量程下量程下调节;逻辑电平平输入与入与TTLTTL电平兼容;平兼容;单一一电源供源供电(5V5V15V15V););低功耗,低功耗,20m20m。 一、一、DAC0832内部结构及引脚内部结构及引脚二、二、DAC0832与与80C51单片机的接口单片机的接口、单缓冲工作方式、单缓冲工作方式 此方式适用于只有一路模拟量输出,或有几路模拟量输出适用于只有一路模拟量输出,或有几路模拟量输出但并不要求同步的系统但并不要求同步的系统。 双极性模拟输出电压双极性模拟输出电压 : 双极性输出时的分辨率比单极性输出时降低双极性输出时的分辨率比单极性输出时降低1/2,这是由于对双极性输出而言,最高位作为,这是由于对双极性输出而言,最高位作为符号位,只有符号位,只有7位数值位。位数值位。2、双缓冲工作方式、双缓冲工作方式 多路多路D/A转换输出,如果要求同步进行,就应该转换输出,如果要求同步进行,就应该采用双缓冲器同步方式采用双缓冲器同步方式 。3、直通工作方式、直通工作方式当当DAC0832芯片的片选信号、写信号、芯片的片选信号、写信号、及传送控制信号的引脚全部接地,允许输及传送控制信号的引脚全部接地,允许输入锁存信号入锁存信号ILE引脚接引脚接5V时,时,DAC0832芯片就处于直通工作方式,数字量一旦输芯片就处于直通工作方式,数字量一旦输入,就直接进入入,就直接进入DAC寄存器,进行寄存器,进行D/A转转换。换。http:/www.Alldatasheet.com/6.2 /转换器及其与单片机接口转换器及其与单片机接口6.2.1 6.2.1 转换器的原理及主要技术指标转换器的原理及主要技术指标一、逐次逼近式一、逐次逼近式ADC的转换原理的转换原理二、双积分式二、双积分式ADC的转换原理的转换原理三、三、A/D转换器的主要技术指标转换器的主要技术指标1、分辨率、分辨率ADC的分辨率的分辨率是指使输出数字量变化一个相是指使输出数字量变化一个相邻数码所需输入模拟电压的变化量。常用二邻数码所需输入模拟电压的变化量。常用二进制的位数表示。例如进制的位数表示。例如12位位ADC的分辨率就的分辨率就是是12位,或者说分辨率为满刻度位,或者说分辨率为满刻度FS的的1/ 。一个。一个10V满刻度的满刻度的12位位ADC能分辨输入电能分辨输入电压变化最小值是压变化最小值是10V1/ =2.4mV。2、量化误差、量化误差ADC把模拟量变为数字量,用数字量近似表示模拟量,这个把模拟量变为数字量,用数字量近似表示模拟量,这个过程称为量化。过程称为量化。量化误差是量化误差是ADC的有限位数对模拟量进行量的有限位数对模拟量进行量化而引起的误差化而引起的误差。实际上,要准确表示模拟量,。实际上,要准确表示模拟量,ADC的位数的位数需很大甚至无穷大。一个分辨率有限的需很大甚至无穷大。一个分辨率有限的ADC的阶梯状转换特的阶梯状转换特性曲线与具有无限分辨率的性曲线与具有无限分辨率的ADC转换特性曲线(直线)之间转换特性曲线(直线)之间的最大偏差即是量化误差。的最大偏差即是量化误差。 3、偏移误差、偏移误差偏移误差偏移误差是指输入信号为零时,输出信号不为零的是指输入信号为零时,输出信号不为零的值,所以有时又称为零值误差。假定值,所以有时又称为零值误差。假定ADC没有非线没有非线性误差,则其转换特性曲线各阶梯中点的连线必定性误差,则其转换特性曲线各阶梯中点的连线必定是直线,这条直线与横轴相交点所对应的输入电压是直线,这条直线与横轴相交点所对应的输入电压值就是偏移误差。值就是偏移误差。、满刻度误差、满刻度误差满刻度误差满刻度误差又称为增益误差。又称为增益误差。ADC的满刻度的满刻度误差是指满刻度输出数码所对应的实际输入电误差是指满刻度输出数码所对应的实际输入电压与理想输入电压之差。压与理想输入电压之差。5、线性度线性度线性度线性度有时又称为非线性度,它是指转换器实际的有时又称为非线性度,它是指转换器实际的转换特性与理想直线的最大偏差。转换特性与理想直线的最大偏差。6、绝对精度、绝对精度在一个转换器中,任何数码所对应的实际模拟量输在一个转换器中,任何数码所对应的实际模拟量输入与理论模拟输入之差的最大值,称为入与理论模拟输入之差的最大值,称为绝对精度绝对精度。对。对于于ADC而言,可以在每一个阶梯的水平中点进行测量,而言,可以在每一个阶梯的水平中点进行测量,它包括了所有的误差。它包括了所有的误差。7、转换速率、转换速率ADC的的转换速率转换速率是能够重复进行数据转换的速度,是能够重复进行数据转换的速度,即每秒转换的次数。而完成一次即每秒转换的次数。而完成一次A/D转换所需的时间转换所需的时间(包括稳定时间),则是转换速率的倒数。(包括稳定时间),则是转换速率的倒数。第七讲7.2 80C51的串行口的串行口7.1 计算机串行通信基础计算机串行通信基础7.3 单片机串行口编程应用单片机串行口编程应用举例举例7.1 计算机串行通信基算机串行通信基础 随着多微机系统的广泛应用和计算机网络技随着多微机系统的广泛应用和计算机网络技术的普及,计算机的通信功能愈来愈显得重要。术的普及,计算机的通信功能愈来愈显得重要。计算机通信计算机通信是指计算机与外部设备或计算机与是指计算机与外部设备或计算机与计算机之间的信息交换计算机之间的信息交换。通信有通信有并行通信并行通信和和串行通信串行通信两种方式。在多两种方式。在多微机系统以及现代测控系统中信息的交换多采微机系统以及现代测控系统中信息的交换多采用串行通信方式。用串行通信方式。计算机通信计算机通信是将计算机技术和通信技术的相结合,是将计算机技术和通信技术的相结合,完成计算机与外部设备或计算机与计算机之间的信完成计算机与外部设备或计算机与计算机之间的信息交换息交换 。可以。可以分为两大类:并行通信与串行通信。分为两大类:并行通信与串行通信。并行通信并行通信通常是将数据字节的各位用多条数据线同通常是将数据字节的各位用多条数据线同时进行传送时进行传送 。并行通信并行通信控制简单、传输速度快;由于传输线较多,长距离控制简单、传输速度快;由于传输线较多,长距离传送时成本高且接收方的各位同时接收存在困难。传送时成本高且接收方的各位同时接收存在困难。 串行通信串行通信是将数据字节分成一位一位的形式在一条传输线上逐个地传送。串行通信的特点串行通信的特点:传输线少,长距离传送时:传输线少,长距离传送时成本低,且可以利用电话网等现成的设备,成本低,且可以利用电话网等现成的设备,但数据的传送控制比并行通信复杂。但数据的传送控制比并行通信复杂。 7.1.1 7.1.1 串行通信的基本概念串行通信的基本概念 一、异步通信与同步通信一、异步通信与同步通信1、异步通信、异步通信 异步通信异步通信是指通信的是指通信的发送与接收送与接收设备使用各自的使用各自的时钟控控制数据的制数据的发送和接收送和接收过程。程。为使双方的收使双方的收发协调,要求,要求发送和接收送和接收设备的的时钟尽可能一致。尽可能一致。 异步通信是异步通信是以字符(构成的帧)为以字符(构成的帧)为单位进行传输单位进行传输,字符与字符之间的间,字符与字符之间的间隙(时间间隔)是任意的,但每个字隙(时间间隔)是任意的,但每个字符中的各位是以固定的时间传送的,符中的各位是以固定的时间传送的,即字符之间不一定有即字符之间不一定有“位间隔位间隔”的整数的整数倍的关系,但倍的关系,但同一字符内的同一字符内的各位之间各位之间的距离均为的距离均为“位间隔位间隔”的整数倍。的整数倍。异步通信的数据格式异步通信的数据格式 :异步通信的特点异步通信的特点:不要求收发双方时钟的:不要求收发双方时钟的严格一致,实现容易,设备开销较小,但严格一致,实现容易,设备开销较小,但每个字符要附加每个字符要附加23位用于起止位,各帧位用于起止位,各帧之间还有间隔,因此传输效率不高。之间还有间隔,因此传输效率不高。2、同步通信、同步通信同步通信时要建立发送方时钟对接收方时钟的直接控制,使同步通信时要建立发送方时钟对接收方时钟的直接控制,使双方达到完全同步。此时,传输数据的位之间的距离均为双方达到完全同步。此时,传输数据的位之间的距离均为“位间隔位间隔”的整数倍,同时传送的字符间不留间隙,即的整数倍,同时传送的字符间不留间隙,即保持位保持位同步同步关系,关系,也保持字符同步也保持字符同步关系。发送方对接收方的同步可关系。发送方对接收方的同步可以通过两种方法实现。以通过两种方法实现。 外同步外同步 自同步自同步面向字符的同步格式面向字符的同步格式 : 此时,传送的数据和控制信息都必须由规定的字符集此时,传送的数据和控制信息都必须由规定的字符集(如(如ASCII码)中的字符所组成。图中码)中的字符所组成。图中帧头为帧头为1个或个或2个同个同步字符步字符SYN(ASCII码为码为16H)。)。SOH为序始为序始字符字符(ASCII码为码为01H),表示标题的开始,),表示标题的开始,标题标题中包含源地中包含源地址、目标地址和路由指示等信息。址、目标地址和路由指示等信息。STX为文始为文始字符字符(ASCII码为码为02H),表示传送的数据块开始。),表示传送的数据块开始。数据块数据块是是传送的正文内容,由多个字符组成。数据块后面是传送的正文内容,由多个字符组成。数据块后面是组终组终字符字符ETB(ASCII码为码为17H)或)或文终字符文终字符ETX(ASCII码码为为03H)。然后是)。然后是校验码校验码。典型的面向字符的同步规程如典型的面向字符的同步规程如IBM的二进制同步规程的二进制同步规程BSC。 面向位的同步格式面向位的同步格式 : 此时,将数据块看作数据流,并用序列此时,将数据块看作数据流,并用序列01111110作为开始作为开始和结束标志。为了避免在数据流中出现序列和结束标志。为了避免在数据流中出现序列01111110时引起时引起的混乱,发送方总是在其发送的数据流中每出现的混乱,发送方总是在其发送的数据流中每出现5个连续的个连续的1就插入一个附加的就插入一个附加的0;接收方则每检测到;接收方则每检测到5个连续的个连续的1并且其后并且其后有一个有一个0时,就删除该时,就删除该0。 典型的面向位的同步协议如典型的面向位的同步协议如ISO的高级数据链路控制规程的高级数据链路控制规程HDLC和和IBM的同步数据链路控制规程的同步数据链路控制规程SDLC。 同步通信的特点同步通信的特点是以特定的位组合是以特定的位组合“01111110”作为帧的作为帧的开始和结束标志,所传输的一帧数据可以是任意位。所以传开始和结束标志,所传输的一帧数据可以是任意位。所以传输的效率较高,但实现的硬件设备比异步通信复杂。输的效率较高,但实现的硬件设备比异步通信复杂。 二、串行通信的传输方向二、串行通信的传输方向1、单工、单工单工单工是指数据传输仅能沿是指数据传输仅能沿一个方向一个方向,不能实现反向传输。,不能实现反向传输。2、半双工、半双工半双工半双工是指数据传输可以沿是指数据传输可以沿两个方向两个方向,但需要分时进行。,但需要分时进行。3、全双工、全双工全双工全双工是指数据可以是指数据可以同时进行双向同时进行双向传输。传输。 单工 半双工半双工 全双工全双工三、信号的调制与解调三、信号的调制与解调 利用调制器(利用调制器(Modulator)把数字信号转换成把数字信号转换成模拟信号模拟信号,然后送到通信线路上去,再由解调器,然后送到通信线路上去,再由解调器(Demodulator)把从通信线路上收到的)把从通信线路上收到的模拟信模拟信号转换成数字信号号转换成数字信号。由于通信是双向的,调制器。由于通信是双向的,调制器和解调器合并在一个装置中,这就是调制解调器和解调器合并在一个装置中,这就是调制解调器MODEM。四、串行通信的错误校验四、串行通信的错误校验 1、奇偶校验奇偶校验在发送数据时,数据位尾随的在发送数据时,数据位尾随的1位为奇偶校验位(位为奇偶校验位(1或或0)。奇)。奇校验时,数据中校验时,数据中“1”的个数与校验位的个数与校验位“1”的个数之和应为奇数;的个数之和应为奇数;偶校验时,数据中偶校验时,数据中“1”的个数与校验位的个数与校验位“1”的个数之和应为偶的个数之和应为偶数。接收字符时,对数。接收字符时,对“1”的个数进行校验,若发现不一致,则的个数进行校验,若发现不一致,则说明传输数据过程中出现了差错。说明传输数据过程中出现了差错。3、循环冗余校验循环冗余校验这种校验是通过某种数学运算实现有效信息与校验位之间的这种校验是通过某种数学运算实现有效信息与校验位之间的循环校验,常用于对磁盘信息的传输、存储区的完整性校验循环校验,常用于对磁盘信息的传输、存储区的完整性校验等。这种校验方法纠错能力强,广泛应用于同步通信中。等。这种校验方法纠错能力强,广泛应用于同步通信中。2、代码和校验代码和校验代码和校验是发送方将所发数据块求和(或各字节异或),代码和校验是发送方将所发数据块求和(或各字节异或),产生一个字节的校验字符(校验和)附加到数据块末尾。接产生一个字节的校验字符(校验和)附加到数据块末尾。接收方接收数据同时对数据块(除校验字节外)求和(或各字收方接收数据同时对数据块(除校验字节外)求和(或各字节异或),将所得的结果与发送方的节异或),将所得的结果与发送方的“校验和校验和”进行比较,进行比较,相符则无差错,否则即认为传送过程中出现了差错。相符则无差错,否则即认为传送过程中出现了差错。五、传输速率与传输距离五、传输速率与传输距离 1、传输速率、传输速率比特率比特率是是每秒钟传输二进制代码的位数每秒钟传输二进制代码的位数,单位,单位是:位秒(是:位秒(bps)。如每秒钟传送)。如每秒钟传送240个字个字符,而每个字符格式包含符,而每个字符格式包含10位位(1个起始位、个起始位、1个停止位、个停止位、8个数据位个数据位),这时的比特率为:,这时的比特率为: 10位位240个个/秒秒 = 2400 bps2、传输距离与传输速率的关系、传输距离与传输速率的关系 串行接口或终端直接传送串行信息位流的串行接口或终端直接传送串行信息位流的最大距离与传输速率及传输线的电气特性有最大距离与传输速率及传输线的电气特性有关。当传输线使用每关。当传输线使用每0.3m(约(约1英尺)有英尺)有50PF电容的非平衡屏蔽双绞线时,传输距离电容的非平衡屏蔽双绞线时,传输距离随传输速率的增加而减小。当比特率超过随传输速率的增加而减小。当比特率超过1000 bps 时,最大传输距离迅速下降,如时,最大传输距离迅速下降,如9600 bps 时最大距离下降到只有时最大距离下降到只有76m(约(约250英尺)。英尺)。7.1.2 7.1.2 串行通信接口串行通信接口标准准 一、一、RS-232CRS-232C接口接口 RS-232C是是EIA(美国(美国电子工子工业协会)会)1969年修年修订RS-232C标准。准。RS-232C定定义了数据了数据终端端设备(DTE)与数据)与数据通信通信设备(DCE)之)之间的物理接口的物理接口标准。准。1、机械特性、机械特性RS-232C接口接口规定使用定使用25针连接器,接器,连接器的尺寸及每个插接器的尺寸及每个插针的排列位置都有明确的定的排列位置都有明确的定义。(阳。(阳头)2、功能特性、功能特性4、过程特性、过程特性 过程特性规定了信号之间的时序关系,以便正过程特性规定了信号之间的时序关系,以便正确地接收和发送数据确地接收和发送数据 。远程通信连接远程通信连接 近程通信连接近程通信连接 5、RS-232C电平与电平与TTL电平转换驱动电路电平转换驱动电路6、采用、采用RS-232C接口存在的问题接口存在的问题1、传输距离短,传输速率低传输距离短,传输速率低 RS-232C总线标准受电容允许值的约束,使用时传输距离一总线标准受电容允许值的约束,使用时传输距离一般不要超过般不要超过15米(线路条件好时也不超过几十米)。最高传送米(线路条件好时也不超过几十米)。最高传送速率为速率为20Kbps。2、有电平偏移有电平偏移 RS-232C总线标准要求收发双方共地。通信距离较大时,总线标准要求收发双方共地。通信距离较大时,收发双方的地电位差别较大,在信号地上将有比较大的地电流收发双方的地电位差别较大,在信号地上将有比较大的地电流并产生压降。并产生压降。3、抗干扰能力差抗干扰能力差 RS-232C在电平转换时采用单端输入输出,在传输过程中在电平转换时采用单端输入输出,在传输过程中当干扰和噪声混在正常的信号中。为了提高信噪比,当干扰和噪声混在正常的信号中。为了提高信噪比,RS-232C总线标准不得不采用比较大的电压摆幅。总线标准不得不采用比较大的电压摆幅。二、二、RS-422A接口接口 RS-422A输出驱动器为双端平衡驱动器输出驱动器为双端平衡驱动器。如果其中一条。如果其中一条线为逻辑线为逻辑“1”状态,另一条线就为逻辑状态,另一条线就为逻辑“0”,比采用单端,比采用单端不平衡驱动对电压的放大倍数大一倍。不平衡驱动对电压的放大倍数大一倍。差分电路差分电路能从地线干能从地线干扰中拾取有效信号,差分接收器可以分辨扰中拾取有效信号,差分接收器可以分辨200mV以上电位差。以上电位差。若传输过程中混入了干扰和噪声,由于差分放大器的作用,若传输过程中混入了干扰和噪声,由于差分放大器的作用,可使干扰和噪声相互抵消。因此可以避免或大大减弱地线干可使干扰和噪声相互抵消。因此可以避免或大大减弱地线干扰和电磁干扰的影响。扰和电磁干扰的影响。RS-422A传输速率(传输速率(90Kbps)时,)时,传输距离可达传输距离可达1200米。米。 三、三、RS-485接口接口 RS-485是是RS-422A的变型:的变型:RS-422A用于全双工,而用于全双工,而RS-485则用于半双工。则用于半双工。RS-485是一种是一种多发送器多发送器标准,在通信标准,在通信线路上最多可以使用线路上最多可以使用32 对差分驱动器对差分驱动器/接收器。如果在一个网接收器。如果在一个网络中连接的设备超过络中连接的设备超过32个,还可以使用中继器。个,还可以使用中继器。 RS-485的信号传输采用两线间的电压来表示逻辑的信号传输采用两线间的电压来表示逻辑1和逻辑和逻辑0。由于发送方需要。由于发送方需要两根传输线两根传输线,接收方也需要两根传输线。,接收方也需要两根传输线。传输线采用差动信道,所以它的干扰抑制性极好,又因为它传输线采用差动信道,所以它的干扰抑制性极好,又因为它的阻抗低,无接地问题,所以的阻抗低,无接地问题,所以传输距离可达传输距离可达1200米米,传输速,传输速率可达率可达1Mbps。 RS-485是一点对多点的通信接口,一般是一点对多点的通信接口,一般采用采用双绞线双绞线的结构。普通的的结构。普通的PC机一般不带机一般不带RS485接口,因此要使用接口,因此要使用RS-232C/RS-485转转换器。对于单片机可以通过芯片换器。对于单片机可以通过芯片MAX485来完来完成成TTL/RS-485的电平转换。在计算机和单片的电平转换。在计算机和单片机组成的机组成的RS-485通信系统中,下位机由单片通信系统中,下位机由单片机系统组成,上位机为普通的机系统组成,上位机为普通的PC机,负责监机,负责监视下位机的运行状态,并对其状态信息进行视下位机的运行状态,并对其状态信息进行集中处理,以图文方式显示下位机的工作状集中处理,以图文方式显示下位机的工作状态以及工业现场被控设备的工作状况。系统态以及工业现场被控设备的工作状况。系统中各节点(包括上位机)的识别是通过设置中各节点(包括上位机)的识别是通过设置不同的站地址来实现的。不同的站地址来实现的。7.2 80C51的串行口的串行口 有两个物理上独立的接收、发送缓冲器有两个物理上独立的接收、发送缓冲器SBUF,它们占用,它们占用同一地址同一地址99H ;接收器是双缓冲结构;接收器是双缓冲结构 ;发送缓冲器,因为;发送缓冲器,因为发送时发送时CPU是主动的,不会产生重叠错误。是主动的,不会产生重叠错误。 7.2.1 7.2.1 80C51串行口的结构串行口的结构 SCON 是一个特殊功能寄存器,用以设定串行口的工是一个特殊功能寄存器,用以设定串行口的工作方式、接收作方式、接收/发送控制以及设置状态标志:发送控制以及设置状态标志: 7.2.2 7.2.2 80C51串行口的控制寄存器串行口的控制寄存器 SM0和和SM1为工作方式选择位,可选择四种工作方式:为工作方式选择位,可选择四种工作方式: SM2,多机通信控制位,多机通信控制位,主要用于方式,主要用于方式2和方式和方式3。当当接收机的接收机的SM2=1时可以利用收到的时可以利用收到的RB8来控制是否来控制是否激活激活RI(RB80时不激活时不激活RI,收到的信息丢弃;,收到的信息丢弃;RB81时收到的数据进入时收到的数据进入SBUF,并激活,并激活RI,进而在中断,进而在中断服务中将数据从服务中将数据从SBUF读走)。读走)。当当SM2=0时,不论收时,不论收到的到的RB8为为0和和1,均可以使收到的数据进入,均可以使收到的数据进入SBUF,并激活并激活RI(即此时(即此时RB8不具有控制不具有控制RI激活的功能)。激活的功能)。通过控制通过控制SM2,可以实现多机通信。,可以实现多机通信。在方式在方式0时,时,SM2必须是必须是0。在方式。在方式1时,若时,若SM2=1,则只有接收到有效停止位时,则只有接收到有效停止位时,RI才置才置1。REN,允许串行接收位,允许串行接收位。由软件置。由软件置REN=1,则启动,则启动串行口接收数据;若软件置串行口接收数据;若软件置REN=0,则禁止接收。,则禁止接收。TB8,在方式,在方式2或方式或方式3中,是发送数据的中,是发送数据的第九位第九位,可以用软件规定其作用。可以用作,可以用软件规定其作用。可以用作数据的奇偶校验位,或在多机通信中,作为数据的奇偶校验位,或在多机通信中,作为地址帧地址帧/数据帧的标志位。数据帧的标志位。在方式在方式0和方式和方式1中,该位未用。中,该位未用。RB8,在方式,在方式2或方式或方式3中,是接收到数据中,是接收到数据的第九位的第九位,作为奇偶校验位或地址帧,作为奇偶校验位或地址帧/数据帧数据帧的标志位。在方式的标志位。在方式1时,若时,若SM2=0,则,则RB8是接收到的停止位。是接收到的停止位。TI,发送中断标志位,发送中断标志位。在方式。在方式0时,当串行时,当串行发送第发送第8位数据结束时,或在其它方式,串行位数据结束时,或在其它方式,串行发送停止位的开始时,由内部硬件使发送停止位的开始时,由内部硬件使TI置置1,向向CPU发中断申请。在中断服务程序中,必发中断申请。在中断服务程序中,必须用软件将其清须用软件将其清0,取消此中断申请。,取消此中断申请。RI,接收中断标志位,接收中断标志位。在方式。在方式0时,当串行时,当串行接收第接收第8位数据结束时,或在其它方式,串行位数据结束时,或在其它方式,串行接收停止位的中间时,由内部硬件使接收停止位的中间时,由内部硬件使RI置置1,向向CPU发中断申请。也必须在中断服务程序发中断申请。也必须在中断服务程序中,用软件将其清中,用软件将其清0,取消此中断申请。,取消此中断申请。PCON中只有一位中只有一位SMOD与串行口工作有关与串行口工作有关 : SMOD(PCON.7) 波特率倍增位。在串行口方式波特率倍增位。在串行口方式1、方式方式2、方式、方式3时,波特率与时,波特率与SMOD有关,当有关,当SMOD=1时,时,波特率提高一倍。复位时,波特率提高一倍。复位时,SMOD=0。 7.2.3 7.2.3 80C51串行口的工作方式串行口的工作方式 一、方式一、方式0 方式方式0时,串行口为同步移位寄存器的输入输出方式。主时,串行口为同步移位寄存器的输入输出方式。主要用于扩展并行输入或输出口。数据由要用于扩展并行输入或输出口。数据由RXD(P3.0)引脚)引脚输入或输出,同步移位脉冲由输入或输出,同步移位脉冲由TXD(P3.1)引脚输出。发)引脚输出。发送和接收均为送和接收均为8位数据,低位在先,高位在后。波特率固定位数据,低位在先,高位在后。波特率固定为为fosc/12。 1、方式、方式0输出输出 2、方式、方式0输入输入 方式方式0接收和发送电路接收和发送电路 二、方式二、方式1 方式方式1是是10位数据的异步通信口。位数据的异步通信口。TXD为数据发送引脚,为数据发送引脚,RXD为数据接收引脚,传送一帧数据的格式如图所示。其中为数据接收引脚,传送一帧数据的格式如图所示。其中1位起始位,位起始位,8位数据位,位数据位,1位停止位。位停止位。 1、方式、方式1输出输出 2、方式、方式1输入输入 用软件置用软件置REN为为1时,接收器以所选择波特率的时,接收器以所选择波特率的16倍速率采倍速率采样样RXD引脚电平,检测到引脚电平,检测到RXD引脚输入电平发生负跳变时,则引脚输入电平发生负跳变时,则说明起始位有效,将其移入输入移位寄存器,并开始接收这一说明起始位有效,将其移入输入移位寄存器,并开始接收这一帧信息的其余位。接收过程中,数据从输入移位寄存器右边移帧信息的其余位。接收过程中,数据从输入移位寄存器右边移入,起始位移至输入移位寄存器最左边时,控制电路进行最后入,起始位移至输入移位寄存器最左边时,控制电路进行最后一次移位。当一次移位。当RI=0,且,且SM2=0(或接收到的停止位为(或接收到的停止位为1)时,)时,将接收到的将接收到的9位数据的前位数据的前8位数据装入接收位数据装入接收SBUF,第,第9位(停止位(停止位)进入位)进入RB8,并置,并置RI=1,向,向CPU请求中断。请求中断。 三、方式三、方式2和方式和方式3 方式方式2或方式或方式3时为时为11位数据的异步通信口。位数据的异步通信口。TXD为数据发为数据发送引脚,送引脚,RXD为数据接收引脚为数据接收引脚 。 方式方式2和方式和方式3时起始位时起始位1位,数据位,数据9位(含位(含1位附加的第位附加的第9位,位,发送时为发送时为SCON中的中的TB8,接收时为,接收时为RB8),停止位),停止位1位,一位,一帧数据为帧数据为11位。方式位。方式2的波特率固定为晶振频率的的波特率固定为晶振频率的1/64或或1/32,方式,方式3的波特率由定时器的波特率由定时器T1的溢出率决定。的溢出率决定。 1、方式、方式2和方式和方式3输出输出 发送开始时,先把起始位发送开始时,先把起始位0输出到输出到TXD引脚,然后发送移引脚,然后发送移位寄存器的输出位(位寄存器的输出位(D0)到)到TXD引脚。每一个移位脉冲都使引脚。每一个移位脉冲都使输出移位寄存器的各位右移一位,并由输出移位寄存器的各位右移一位,并由TXD引脚输出。引脚输出。 第一次移位时,停止位第一次移位时,停止位“1”移入输出移位寄存器的第移入输出移位寄存器的第9位上位上 ,以后每次移位,左边都移入,以后每次移位,左边都移入0。当停止位移至输出位。当停止位移至输出位时,左边其余位全为时,左边其余位全为0,检测电路检测到这一条件时,使控,检测电路检测到这一条件时,使控制电路进行最后一次移位,并置制电路进行最后一次移位,并置TI=1,向,向CPU请求中断。请求中断。 2、方式、方式2和方式和方式3输入输入 接收时,数据从右边移入输入移位寄存器,在起始接收时,数据从右边移入输入移位寄存器,在起始位位0移到最左边时,控制电路进行最后一次移位。当移到最左边时,控制电路进行最后一次移位。当RI=0,且,且SM2=0(或接收到的第(或接收到的第9位数据为位数据为1)时,)时,接收到的数据装入接收缓冲器接收到的数据装入接收缓冲器SBUF和和RB8(接收数(接收数据的第据的第9位),置位),置RI=1,向,向CPU请求中断。如果条件请求中断。如果条件不满足,则数据丢失,且不置位不满足,则数据丢失,且不置位RI,继续搜索,继续搜索RXD引引脚的负跳变。脚的负跳变。四、波特率的计算四、波特率的计算 在串行通信中,收发双方对发送或接收数据的速在串行通信中,收发双方对发送或接收数据的速率要有约定。通过软件可对单片机串行口编程为四率要有约定。通过软件可对单片机串行口编程为四种工作方式,其中方式种工作方式,其中方式0和方式和方式2的波特率是固定的,的波特率是固定的,而方式而方式1和方式和方式3的波特率是可变的,由定时器的波特率是可变的,由定时器T1的溢出率来决定。的溢出率来决定。 串行口的四种工作方式对应串行口的四种工作方式对应三种波特率三种波特率。由于输。由于输入的移位时钟的来源不同,所以,各种方式的波特入的移位时钟的来源不同,所以,各种方式的波特率计算公式也不相同。率计算公式也不相同。方式方式0的波特率的波特率 = fosc/12方式方式2的波特率的波特率 =(2SMOD/64) fosc 方式方式1的波特率的波特率 =(2SMOD/32)(T1溢出率)溢出率)方式方式3的波特率的波特率 =(2SMOD/32)(T1溢出率)溢出率) 当当T1作为波特率发生器时,最典型的用法是使作为波特率发生器时,最典型的用法是使T1工作在自动再装入工作在自动再装入的的8位定时器方式(即方式位定时器方式(即方式2,且,且TCON的的TR1=1,以启动定时器)。这,以启动定时器)。这时溢出率取决于时溢出率取决于TH1中的计数值。中的计数值。 T1 溢出率溢出率 = fosc /12256 (TH1) 在单片机的应用中,常用的晶振频率为:在单片机的应用中,常用的晶振频率为:12MHz和和11.0592MHz。所。所以,选用的波特率也相对固定。常用的串行口波特率以及各参数的关系以,选用的波特率也相对固定。常用的串行口波特率以及各参数的关系如表所示。如表所示。 串行口工作之前,应对其进行初始化,主串行口工作之前,应对其进行初始化,主要是设置产生波特率的定时器要是设置产生波特率的定时器1、串行口控、串行口控制和中断控制。具体步骤如下:制和中断控制。具体步骤如下:确定确定T1的工作方式的工作方式(编程(编程TMOD寄存器);寄存器);计算计算T1的初值的初值,装载,装载TH1、TL1;启动启动T1(编程(编程TCON中的中的TR1位);位);确定确定串行口控制串行口控制(编程(编程SCON寄存器);寄存器);串行口在中断方式工作时,要进行中断设置串行口在中断方式工作时,要进行中断设置(编程(编程IE、IP寄存器)。寄存器)。7.3 单片机串行口片机串行口应用用举例例 在计算机组成的测控系统中,经常要利用在计算机组成的测控系统中,经常要利用串行通信方式进行数据传输。串行通信方式进行数据传输。80C51单片机的单片机的串行口为计算机间的通信提供了极为便利的条串行口为计算机间的通信提供了极为便利的条件。利用单片机的串行口还可以方便地扩展键件。利用单片机的串行口还可以方便地扩展键盘和显示器,对于简单的应用非常便利。这里盘和显示器,对于简单的应用非常便利。这里仅介绍单片机串行口在通信方面的应用。仅介绍单片机串行口在通信方面的应用。7.3.1 7.3.1 单片机与单片机的通信单片机与单片机的通信 一、点对点的通信一、点对点的通信 1、硬件连接、硬件连接 二、多机通信二、多机通信 1、硬件连接、硬件连接 单片机构成的多机系统常采用总线型主从式结构。所谓主从单片机构成的多机系统常采用总线型主从式结构。所谓主从式,即在数个单片机中,有一个是主机,其余的是从机,从机式,即在数个单片机中,有一个是主机,其余的是从机,从机要服从主机的调度、支配。要服从主机的调度、支配。80C51单片机的串行口方式单片机的串行口方式2和方和方式式3适于这种主从式的通信结构。当然采用不同的通信标准时,适于这种主从式的通信结构。当然采用不同的通信标准时,还需进行相应的电平转换,有时还要对信号进行光电隔离。在还需进行相应的电平转换,有时还要对信号进行光电隔离。在实际的多机应用系统中,常采用实际的多机应用系统中,常采用RS-485串行标准总线进行数串行标准总线进行数据传输。据传输。2、通信协议、通信协议所有从机的所有从机的SM2位置位置1,处于接收地址帧状态。,处于接收地址帧状态。主机发送一地址帧,其中主机发送一地址帧,其中8位是地址,第位是地址,第9位为地址位为地址/数据的区分标志,该位置数据的区分标志,该位置1表示该帧为地址帧。表示该帧为地址帧。 所有从机收到地址帧后,都将接收的地址与本机的所有从机收到地址帧后,都将接收的地址与本机的地址比较。对于地址相符的从机,使自己的地址比较。对于地址相符的从机,使自己的SM2位置位置0(以接收主机随后发来的数据帧),并把本站地址(以接收主机随后发来的数据帧),并把本站地址发回主机作为应答;对于地址不符的从机,仍保持发回主机作为应答;对于地址不符的从机,仍保持SM2=1,对主机随后发来的数据帧不予理睬。,对主机随后发来的数据帧不予理睬。从机发送数据结束后,要发送一帧校验和,并置第从机发送数据结束后,要发送一帧校验和,并置第9位(位(TB8)为)为1,作为从机数据传送结束的标志。,作为从机数据传送结束的标志。主机接收数据时先判断数据接收标志(主机接收数据时先判断数据接收标志(RB8),若),若RB8=1,表示数据传送结束,并比较此帧校验和,若,表示数据传送结束,并比较此帧校验和,若正确则回送正确信号正确则回送正确信号00H,此信号命令该从机复位,此信号命令该从机复位(即重新等待地址帧);若校验和出错,则发送(即重新等待地址帧);若校验和出错,则发送0FFH,命令该从机重发数据。若接收帧的,命令该从机重发数据。若接收帧的RB8=0,则存数据到缓冲区,并准备接收下帧信息。则存数据到缓冲区,并准备接收下帧信息。主机收到从机应答地址后,确认地址是否相符,如主机收到从机应答地址后,确认地址是否相符,如果地址不符,发复位信号(数据帧中果地址不符,发复位信号(数据帧中TB8=1);如果);如果地址相符,则清地址相符,则清TB8,开始发送数据。,开始发送数据。从机收到复位命令后回到监听地址状态(从机收到复位命令后回到监听地址状态(SM2=1)。)。否则开始接收数据和命令。否则开始接收数据和命令。3、应用程序、应用程序主机发送的地址联络信号为:主机发送的地址联络信号为:00H,01H,02H , (即从机设备地址)(即从机设备地址),地址,地址FFH为命令各从机复位,即恢复为命令各从机复位,即恢复SM2=1。主机命令编码为:主机命令编码为:01H,主机命令从机接收数据;,主机命令从机接收数据;02H,主机命令从机发,主机命令从机发送数据。其它都按送数据。其它都按02H对待。对待。RRDY=1:表示从机准备好接收。:表示从机准备好接收。TRDY=1:表示从机准备好发送。:表示从机准备好发送。ERR=1: 表示从机接收的命令是非法的。表示从机接收的命令是非法的。 程序分为主机程序和从机程序。约定一次传递数据为程序分为主机程序和从机程序。约定一次传递数据为16个字节,以个字节,以01H地址的从机为例地址的从机为例。 1.由上位机发送1给单片机时,蜂鸣器以400ms频率发声,发2时以200ms频率发声,发3时以100ms频率发声,发4时关闲蜂鸣器。1.以2400bps从计算机发送任一字节数据,当单片机收到该数据后,在此数据前加上一序号然后连同此数据一起发送至计算机,当序号超过255时归零。2.以16进制发送一个0-65536之间的任一数,当单片机收到后在数码管上动态显示出来,波特率自定。3. 用AD以1HZ的频率采集模拟信号,然后转换成数字量,再将其以1200bps发送到计算机,在计算机上显示。4.按下矩阵键盘第一行时以1200bps发送,1,2,3,4,第二行时以2400bps发送5,6,7,8,第三行以4800bps发送,9,10,11,12,第四行以9600pbs 发送,13,14,15,16.I2C串行总线的组成及工作原理串行总线的组成及工作原理8.1 I2C串行总线的组成及工作原理串行总线的组成及工作原理采用串行总线技术可以使系统的硬件设计大大简化、采用串行总线技术可以使系统的硬件设计大大简化、系统的体积减小、可靠性提高。同时,系统的更改和系统的体积减小、可靠性提高。同时,系统的更改和扩充极为容易。扩充极为容易。常用的串行扩展总线有:常用的串行扩展总线有: I2C (Inter IC BUS)总线、)总线、单总线单总线(1WIRE BUS)、)、SPI(Serial Peripheral Interface)总线及)总线及Microwire/PLUS等。等。 本课仅讨论本课仅讨论I2C串行总线。串行总线。8.1.1 8.1.1 I2C串行总线概述串行总线概述 I2C总线是总线是PHLIPS公司推出的一种串行总线,是具备多公司推出的一种串行总线,是具备多主机系统所需的包括总线裁决和高低速器件同步功能的高主机系统所需的包括总线裁决和高低速器件同步功能的高性能串行总线。性能串行总线。 I2C总线只有两根双向信号线。一根是数据线总线只有两根双向信号线。一根是数据线SDA,另,另一根是时钟线一根是时钟线SCL。 I2C总线通过上拉电阻接正电源。当总线空闲时,两根线均总线通过上拉电阻接正电源。当总线空闲时,两根线均为高电平。连到总线上的任一器件输出的低电平,都将使总线为高电平。连到总线上的任一器件输出的低电平,都将使总线的信号变低,即各器件的的信号变低,即各器件的SDA及及SCL都是线都是线“与与”关系关系。 每个接到每个接到I2C总线上的器件都有唯一的地总线上的器件都有唯一的地址。主机与其它器件间的数据传送可以是址。主机与其它器件间的数据传送可以是由主机发送数据到其它器件,这时主机即由主机发送数据到其它器件,这时主机即为发送器。由总线上接收数据的器件则为为发送器。由总线上接收数据的器件则为接收器接收器。 在多主机系统中,可能同时有几个主机企图启在多主机系统中,可能同时有几个主机企图启动总线传送数据。为了避免混乱,动总线传送数据。为了避免混乱, I2C总线要通总线要通过总线仲裁,以决定由哪一台主机控制总线。过总线仲裁,以决定由哪一台主机控制总线。 在在80C51单片机应用系统的串行总线扩展中,单片机应用系统的串行总线扩展中,我们经常遇到的是以我们经常遇到的是以80C51单片机为主机,其它单片机为主机,其它接口器件为从机的单主机情况。接口器件为从机的单主机情况。 一、数据位的有效性规定一、数据位的有效性规定 I2C总线进行数据传送时,总线进行数据传送时,时钟信号为高电平期间时钟信号为高电平期间,数据,数据线上的数据必须保持稳定,只有在线上的数据必须保持稳定,只有在时钟线上的信号为低电平时钟线上的信号为低电平期间期间,数据线上的高电平或低电平状态才允许变化。,数据线上的高电平或低电平状态才允许变化。8.1.2 8.1.2 I2C总线的数据传送总线的数据传送二、起始和终止信号二、起始和终止信号 SCL线为高电平期间,线为高电平期间,SDA线由高电平向低电线由高电平向低电平的变化表示起始信号;平的变化表示起始信号;SCL线为高电平期间,线为高电平期间,SDA线由低电平向高电平的变化表示终止信号。线由低电平向高电平的变化表示终止信号。 起始和终止信号都是由主机发出的,在起始信号产生起始和终止信号都是由主机发出的,在起始信号产生后,总线就处于被占用的状态;在终止信号产生后,总线后,总线就处于被占用的状态;在终止信号产生后,总线就处于空闲状态。就处于空闲状态。 连接到连接到I2C总线上的器件,若具有总线上的器件,若具有I2C总线的硬件接口,则总线的硬件接口,则很容易检测到起始和终止信号。很容易检测到起始和终止信号。 接收器件收到一个完整的数据字节后,有可能需要完成接收器件收到一个完整的数据字节后,有可能需要完成一些其它工作,如处理内部中断服务等,可能无法立刻接收一些其它工作,如处理内部中断服务等,可能无法立刻接收下一个字节,这时接收器件可以将下一个字节,这时接收器件可以将SCL线拉成低电平,从而线拉成低电平,从而使主机处于等待状态。直到接收器件准备好接收下一个字节使主机处于等待状态。直到接收器件准备好接收下一个字节时,再释放时,再释放SCL线使之为高电平,从而使数据传送可以继续线使之为高电平,从而使数据传送可以继续进行。进行。 三、数据传送格式三、数据传送格式(1)字节传送与应答)字节传送与应答 每一个字节必须保证是每一个字节必须保证是8位长度。数据传送时,先传位长度。数据传送时,先传送最高位(送最高位(MSB),每一个被传送的字节后面都必须跟),每一个被传送的字节后面都必须跟随一位应答位(即一帧共有随一位应答位(即一帧共有9位)。位)。 由于某种原因从机不对主机寻址信号应答时(如从机由于某种原因从机不对主机寻址信号应答时(如从机正在进行实时性的处理工作而无法接收总线上的数据),正在进行实时性的处理工作而无法接收总线上的数据),它必须将数据线置于高电平,而由主机产生一个终止信号它必须将数据线置于高电平,而由主机产生一个终止信号以结束总线的数据传送。以结束总线的数据传送。 如果从机对主机进行了应答,但在数据传送一段时间后如果从机对主机进行了应答,但在数据传送一段时间后无法继续接收更多的数据时,从机可以通过对无法接收的无法继续接收更多的数据时,从机可以通过对无法接收的第一个数据字节的第一个数据字节的“非应答非应答”通知主机,主机则应发出终通知主机,主机则应发出终止信号以结束数据的继续传送。止信号以结束数据的继续传送。 当主机接收数据时,它收到最后一个数据字节后,必须当主机接收数据时,它收到最后一个数据字节后,必须向从机发出一个结束传送的信号。这个信号是由对从机的向从机发出一个结束传送的信号。这个信号是由对从机的“非应答非应答”来实现的。然后,从机释放来实现的。然后,从机释放SDA线,以允许主线,以允许主机产生终止信号。机产生终止信号。(2)数据帧格式)数据帧格式 I2C总线上传送的数据信号是广义的,既包括地址总线上传送的数据信号是广义的,既包括地址信号,又包括真正的数据信号。信号,又包括真正的数据信号。 在总线的一次数据传送过程中,可以有以下几种在总线的一次数据传送过程中,可以有以下几种组合方式:组合方式: 在起始信号后必须传送一个从机的地址(在起始信号后必须传送一个从机的地址(7位),位),第第8位是数据的传送方向位(位是数据的传送方向位(R/T),用),用“0”表示主表示主机发送数据(机发送数据(T),),“1”表示主机接收数据(表示主机接收数据(R)。)。每次数据传送总是由主机产生的终止信号结束。但每次数据传送总是由主机产生的终止信号结束。但是,若主机希望继续占用总线进行新的数据传送,是,若主机希望继续占用总线进行新的数据传送,则可以不产生终止信号,马上再次发出起始信号对则可以不产生终止信号,马上再次发出起始信号对另一从机进行寻址。另一从机进行寻址。 a、主机向从机发送数据,数据传送方向在整、主机向从机发送数据,数据传送方向在整个传送过程中不变:个传送过程中不变:注:有阴影部分表示数据由主机向从机传送,无阴影部分则注:有阴影部分表示数据由主机向从机传送,无阴影部分则表示数据由从机向主机传送。表示数据由从机向主机传送。 A表示应答,表示应答, A非表示非应答(高电平)。非表示非应答(高电平)。S表示起始信号,表示起始信号,P表示终止信号。表示终止信号。b、主机在第一个字节后,立即从从机读数据、主机在第一个字节后,立即从从机读数据c、在传送过程中,当需要改变传送方向时,、在传送过程中,当需要改变传送方向时,起始信号和从机地址都被重复产生一次,但起始信号和从机地址都被重复产生一次,但两次读两次读/写方向位正好反相。写方向位正好反相。四、总线的寻址四、总线的寻址 I2C总线协议有明确的规定:采用总线协议有明确的规定:采用7位的寻址字节位的寻址字节(寻址字节是起始信号后的第一个字节)。(寻址字节是起始信号后的第一个字节)。 (1)寻址字节的位定义)寻址字节的位定义 D7D1位组成从机的地址。位组成从机的地址。D0位是数据位是数据传送方向位,为传送方向位,为“0”时表示主机向从机写数时表示主机向从机写数据,为据,为“1”时表示主机由从机读数据。时表示主机由从机读数据。主机发送地址主机发送地址时,总线上的每个从机都将这时,总线上的每个从机都将这7位地址码与自己的地址进行比较,如果相同,位地址码与自己的地址进行比较,如果相同,则认为自己正被主机寻址,根据则认为自己正被主机寻址,根据R/T位将自己位将自己确定为发送器或接收器确定为发送器或接收器。从机的地址从机的地址由固定部分和可编程部分组成。由固定部分和可编程部分组成。在一个系统中可能希望接入多个相同的从机,在一个系统中可能希望接入多个相同的从机,从机地址中可编程部分决定了可接入总线该类从机地址中可编程部分决定了可接入总线该类器件的最大数目。如一个从机的器件的最大数目。如一个从机的7位寻址位有位寻址位有4位是固定位,位是固定位,3位是可编程位,这时仅能寻址位是可编程位,这时仅能寻址8个同样的器件,即可以有个同样的器件,即可以有8个同样的器件接入个同样的器件接入到该到该I2C总线系统中总线系统中。8.2 80C51单片机片机I2C串行总线器件的接口串行总线器件的接口一、典型信号模拟一、典型信号模拟 为了保证数据传送的可靠性,标准的为了保证数据传送的可靠性,标准的I2C总线的数总线的数据传送有严格的时序要求。据传送有严格的时序要求。I2C总线的起始信号、终总线的起始信号、终止信号、发送止信号、发送“0”及发送及发送“1”的模拟时序的模拟时序 : 8.2.1 8.2.1 总线数据传送的模拟总线数据传送的模拟 主机可以采用不带主机可以采用不带I2C总线接口的单片机,如总线接口的单片机,如80C51、AT89C2051等单片机,利用软件实现等单片机,利用软件实现I2C总线的数据传送,即软件与硬件结合的信号模拟。总线的数据传送,即软件与硬件结合的信号模拟。 二、典型信号模拟子程序二、典型信号模拟子程序(1)起始信号)起始信号Void T2CStart(void) SDA = 1;SomeNop( );SCL = 1;SomeNop( );SDA = 0;SomeNop( );(2)终止信号)终止信号void I2cStop(void)SDA = 0;SomeNop( );SCL = 1;SomeNop( );SDA = 1;SomeNop( ); 8.2.2 8.2.2 I2C总线器件的扩展总线器件的扩展一、一、扩展电路扩展电路 二、串行二、串行E2PROM的扩展的扩展 (1)串行)串行E2PROM典型产品典型产品 AT24C01:128字节(1288位); AT24C02:256字节(2568位);AT24C04:512字节(5128位)AT24C08:1K字节(1K8位);AT24C16:2K字节(2K8位); ATMEL公司的公司的AT24C系列:系列: (2)写入过程)写入过程 AT24C系列系列E2PROM芯片地址的固定部分为芯片地址的固定部分为1010,A2、A1、A0引脚接高、低电平后得到确定引脚接高、低电平后得到确定的的3位编码。形成的位编码。形成的7位编码即为该器件的地址码。位编码即为该器件的地址码。 单片机进行写操作时,首先发送该器件的单片机进行写操作时,首先发送该器件的7位地位地址码和写方向位址码和写方向位“0”(共(共8位,即一个字节),发位,即一个字节),发送完后释放送完后释放SDA线并在线并在SCL线上产生第线上产生第9个时钟信个时钟信号。被选中的存储器器件在确认是自己的地址后,号。被选中的存储器器件在确认是自己的地址后,在在SDA线上产生一个应答信号作为相应,单片机收线上产生一个应答信号作为相应,单片机收到应答后就可以传送数据了。到应答后就可以传送数据了。 传送数据时,单片机首先发送一个字节的被写入器件的存传送数据时,单片机首先发送一个字节的被写入器件的存储区的首地址,收到存储器器件的应答后,单片机就逐个发储区的首地址,收到存储器器件的应答后,单片机就逐个发送各数据字节,但每发送一个字节后都要等待应答。送各数据字节,但每发送一个字节后都要等待应答。 AT24C系列器件片内地址在接收到每一个数据字节地址后系列器件片内地址在接收到每一个数据字节地址后自动加自动加1,在芯片的,在芯片的“一次装载字节数一次装载字节数”(不同芯片字节数不(不同芯片字节数不同)限度内,只需输入首地址。装载字节数超过芯片的同)限度内,只需输入首地址。装载字节数超过芯片的“一一次装载字节数次装载字节数”时,数据地址将时,数据地址将“上卷上卷”,前面的数据将被,前面的数据将被覆盖。覆盖。 当要写入的数据传送完后,单片机应发出终止信号以结束当要写入的数据传送完后,单片机应发出终止信号以结束写入操作。写入写入操作。写入n个字节的数据格式个字节的数据格式 : (3)读出过程)读出过程 单片机先发送该器件的单片机先发送该器件的7位地址码和写方向位位地址码和写方向位“0”(“伪伪写写”),发送完后释放),发送完后释放SDA线并在线并在SCL线上产生第线上产生第9个时钟信个时钟信号。被选中的存储器器件在确认是自己的地址后,在号。被选中的存储器器件在确认是自己的地址后,在SDA线线上产生一个应答信号作为回应。上产生一个应答信号作为回应。 然后,再发一个字节的要读出器件的存储区的首地址,收然后,再发一个字节的要读出器件的存储区的首地址,收到应答后,单片机要重复一次起始信号并发出器件地址和读到应答后,单片机要重复一次起始信号并发出器件地址和读方向位(方向位(“1”),收到器件应答后就可以读出数据字节,每),收到器件应答后就可以读出数据字节,每读出一个字节,单片机都要回复应答信号。当最后一个字节读出一个字节,单片机都要回复应答信号。当最后一个字节数据读完后,单片机应返回以数据读完后,单片机应返回以“非应答非应答”(高电平),并发(高电平),并发出终止信号以结束读出操作。出终止信号以结束读出操作。 移位操作左移时最低位补0,最高位移入PSW的CY位右移时最高位保持原数,最低位移除。
网站客服QQ:2055934822
金锄头文库版权所有
经营许可证:蜀ICP备13022795号 | 川公网安备 51140202000112号