资源描述
单击此处编辑母版标题样式,*,*,单击此处编辑母版文本样式,第二级,第三级,第四级,第五级,PIC单片机原理及应用,1,第1章微型计算机概论,微型计算机是一种既有快速运算能力,又有极强逻辑判断能力和大容量存储功能的电子设备,它是20世纪人类最卓越的科学创造之一。,本章介绍微型计算机的根底知识,主要内容有微型计算机的开展历史及应用领域、计算机硬件、软件系统的根本组成。,2,1.1 微型计算机的开展历史及应用,我们今天所说的计算机,是指利用电子技术实现计算并具有逻辑判断和程序存储功能的设备。,3,1.1.1 微型计算机的开展历史,从计算机开展的历史看,微型计算机已属于第四代计算机,而微型计算机的开展又已经历了四代。,4,1.1.2 微型计算机的应用,科学计算,数据处理,过程控制,计算机辅助设计/辅助制造 (,CAD/CAM),计算机网络,5,1.1.3 微型计算机系统主要技术指标,字长 :计算机的字长取8的整数倍数,,如8位、16位、32位、64位等,速度 :计算机的速度指标可用主频及运算,速度来评价 G、万次/秒,存储系统容量 :内存和外存MG,6,1.2 微型计算机系统的组成,计算机的硬件通常包括运算器、存储器、控制器、输入设备及输出设备等五个局部,7,1.2.2,软件系统,软件系统是一台计算机中的系统软件、应用软件、程序设计语言和支持软件及各种文档的总称。,系统软件:包括操作系统、效劳程序、汇编程序、解释程序和编译程序等。,应用软件:是用汇编语言或高级语言为解决某种实际问题而编写的程序。,程序设计语言:通常分为面向机器的汇编语言和面向用户的高级语言。,8,1.3 微控制器系统,在计算机的开展历史上,特别是在第一台小型控制器件形成以后,沿着两条完全不同的用途、不同的价格、和不同的技术内涵,而被充实于我们的日常生活中。,9,1.3.1 单片机系统,单片机的开展过程和性能的日益完善,实际上是对传统控制技术的一场革命,开创了微控技术的新天地。,现代控制系统的核心内涵就是嵌入式计算机应用系统MCU,而单片机就是最典型、最广泛、最普及的嵌入式计算机应用系统。,10,单片机的降临,主要也是源于其性能价格比。一般单片机用于控制的目的,而对于其承担的计算功能却要求不高,只要能按照一定的程式进行在线检测和即时控制工作。,目前,各个单片机生产厂家还是立足于8位单片机的竞争,因为从其降临以来,一直成为应用最广泛的器件。2002年美国MICROCHIP和MOTOROLA两家公司,已占据着世界8位单片机产量最高的前两个芯片制造商。,11,一般的单片机的结构可以用图1.2所示的方块图描述,用三大总线DB、AB、CB实现模块之间的信息传递。,单片机内部结构,12,单片机的主要应用,人有所思,单片机就可为。单片机的应用必将随着社会的开展和技术的进步,而获得更广阔应用。系列化的单片机 ?,电信,家用电器,工业控制,仪器仪表,汽车,玩具,13,单片机有哪些特点,单片机具备体积小、价格低、性能强、速度快、用途广、可靠性高、灵活性强等优点,它与通用的计算机相比,还具有以下一些特点:,存储器,ROM,和,RAM,的相互独立,采用面向控制的指令系统,输入/输出端口的强大功能,14,1.3.2,PIC,系列单片机,PIC,系列单片机,可以满足用户的各种需要。从中档产品,PIC16F877,作为切入点,提供非常完备、易学易用的,MPLAB-ICD,集成开发环境。,特别是对于单片机的新手,仿佛从茫然迷惑的大海搭上一艘便捷平稳的小船,感到非常轻松自如。,15,第2章,PIC,单片微机的组成,PICPeriphery Interface Chip单片微机是美国Microchip公司生产的PIC系列单片机。,PIC系列单片机的硬件系统设计简洁,指令系统设计精炼。在所有的单片机品种中,PIC具有性能完善、功能强大、学习容易、开发应用方便、人机界面友好等突出优点。,16,2.1,PIC,系列单片机概述,Microchip公司是一家专门致力于单片机开发、研制和生产的制造商,其产品设计起点高,技术领先,性能优越。,它不是在一般微型计算机CPU的根底上加以改造,而是独树一帜,采用全新的流水线结构、单字节指令体系、嵌入闪存以及10位A/D转换器,使之具有卓越的性能,代表着单片机开展的新方向。,PIC系列单片机,具有高、中、低三个档次,可以满足不同用户开发的需要,适合在各个领域中的应用。,它具有如下特点:,2.1.1,PIC,系列单片机特点,17,单片机总线结构,单片微型计算机通常采用两种体系结构:一种是普林斯顿体系结构;另一种是哈佛体系结构。,在普林斯顿体系结构中,其程序存储器和数据存储器统一编址,也就是说两种存储器位于同一逻辑空间,。,这种单片机的取指令和存取数据必须分时地进行,影响了执行指令的速度。,哈佛体系结构的程序存储器和数据存储器独立编址,也就是说两种存储器有不同的逻辑空间,。,18,PIC系列单片机采用哈佛总线结构,在芯片内部数据总线和指令总线别离,容许采用不同的字节宽度。这样,就为实现指令提取和执行的“流水作业提供结构保证,即在执行一条指令的同时对下一条指令进行取指操作。,两总线的别离,也为PIC实现全部指令的单字节化和单周期化创造条件,从而大大提高CPU执行指令的速度和工作效率。,1. 哈佛总线结构,19,单片机总线结构比较,从同一存储器空间取指令和取操作数据,。,限制了数据流量。,从两个独立的存储空间分别取指令和存取操作数,。,数据流量增加。,针对程序区和数据区可以设计不同的数据线宽度。,程序和,数据,存储器,冯-纽曼结构,8-位,CPU,程序,存储器,数据,存储器,8-位,12/14/16-位,哈佛结构,CPU,20,PIC,系列单片机的指令系统,由于采用,RISC,技术,,和一般单片机指令系统通常有上百条指令相比要少得多。,2,RISC,技术,21,PIC系列单片机只有4种寻址方式:存放器间接寻址、立即数寻址、直接寻址和位寻址,比较容易掌握。,PIC系列单片机的程序、数据、堆栈三者各自采用互相独立的地址空间,前两者的地址访问需要用户特别注意四个分区的范围,而堆栈过程用户不必参与和操心。,代码压缩率,就是指相同程序存储器空间所能容纳有效指令的数量。,3指令特色,22,由于,PIC,系列单片机采用,CMOS,结构,使其功率消耗极低,是目前世界上最低功耗的单片机品种之一。,其中有些型号,在4,MHz,时钟下工作时耗电不超过2,mA,,而在睡眠模式下耗电可低到1,A,以下。 因此,,PIC,系列单片机,尤其适用于野外移动仪表的控制以及户外免维护的控制系统。,5功耗低,23,I/0端口驱动负载的能力较强,每个输出引脚可以驱动多达20-25mA的负载,既能够高电平直接驱动发光二极管LED、光电藕合器、小型继电器等,也可以低电平直接驱动,这样可大大简化控制电路。,不过,请读者注意,每个引脚的驱动能力并不表示端口引脚同时都具有这样的成效。一般端口驱动能力约60-70mA,而所有输入输出驱动小于200mA,详细数据可参考有关数据手册。,6驱动能力强,24,PIC,主要是采用哈佛总线结构,可以同时进行指令读取和指令执行的流水线作业方式。,如:,MCS-51 12M,,指令执行时间为1,s4,s,PIC 12M,时钟周期,指令执行时间为0.30.6,s,7运行速度高,25,PIC系列单片机的一些型号具有同步串行口,可以满足I2C主控/从动和SPI主控总线要求。I2C和SPISerial Peripheral Interface分别是PHILIPS公司和MOTOROLA公司研制的两种广泛流行的串行总线标准,是一种在芯片之间实现同步串行数据传输的技术。,利用单片机串行总线端口可以方便而灵活地扩展外围器件,目前已在许多电子产品中得到广泛应用。,8同步串行数据传送方式,26,2.1.2,PIC16F877,的结构,从其执行功能考虑,可以将单片机分成两大组件,即根本功能模块和专用功能模块。,27,28,PICl6F87X系列单片机有双列直插式28引脚和40引脚及外表贴装式44引脚等几种封装形式。,多数I/O引脚都设计有第2功能,甚至第3功能。采用引脚复用技术,以便使单片机增加功能而又不增大体积和引脚数量。,2.1.3,PIC16F877,的引脚,29,30,F877,单片机内部配置了较完善的多个存储器,可分为数据存储器和程序存储器两种,为一般用户提供很大的方便。,但它们在形式上,具有很丰富的内涵,。,2.2 存储器概述,31,F877单片机内部配置了8K l4位的闪烁FLASH程序存储器,可以很方便进行在线擦除和烧写,寿命可达1000次以上。,在PIC系列单片机教学实验和科研开发中,显示出无穷的魅力和宽广的应用前景。,相应的地址编码范围为0000HlFFFH。,2.2.1 程序存储器,32,程序存储器结构,33,F877单片机内部配置两类数据存储器,普通RAM数据存储器和EEPROM失电保持数据存储器。,RAM总的地址空间为512个单元,其中包括局部无效单元,但每一个有效单位均可以象存放器一样进行移位、置位、复位和位测试等操作。,PIC单片机的数据存储器和其他单片机一样,在配置结构上可分为通用存放器和特殊功能存放器两大类,前者给用户使用,而后者通常定义给某些功能模块,是一种具有特殊目的的功能存放器。,2.2.2 数据存储器,34,同时在,PIC16F877,片内又配置另一种可掉电保护的数据存储器,EEPROM,,共有2568位宽的存储单元,可以长期存放用户或系统的重要参数:如时间、配置及数据表格等,是一种非常重要的硬件资源。,35,数据存储器单元功能分配,体BANK0 体BANK1 体BANK2 体BANK3,36,存储器是单片机中一个非常重要的部件,专门用于存放指令、数据和运算结果。,分析,F877,单片机存储器构架,可以从其配置的三大模块着手进行,它们是:,8,K l4,位,FLASH,程序存储器,5128位数据存储器,RAM,2568位可掉电保护数据的,EEPROM,存储器模块。,第3章,PIC,存储器,37,存储器从使用功能上来分,可分为随机存储器RAMRandom Access Memory和只读存储器ROMRead Only Memory两类。,3.1 存储器分类,38,F877,程序存储器具有13位宽的程序计数器,PC。PC,指针所产生的13位地址最大可寻址的程序存储器空间为8,K,,相应的地址编码范围为0000,H,lFFFH。,F877,归属于中档单片机,其指令字节宽度为14位,内部构架配置了8,K l4,位的闪烁,FLASH,程序存储器。,3.2 程序存储器构架,39,一般将整个程序存储器以2KB为单位进行分页PAGE,如图3-1所示F877单片机,8KB程序存储器共分作4页,分别称为“页0、“页l、“页2和“页3。 程序计数器高8位PCLATH的Bit4-Bit3位构成程序存储器分页的选择位,对应的地址空间如下:,PCLATH Bit4:Bit3:,0 0 页0:0000H 07FFH,0 1 页l:0800H 0FFFH,1 0 页2:1000H 17FFH,1 1 页3:1800H 1FFFH,40,41,42,PIC16F877,单片机架构程序存储器,最大8,K,字(13 位) 程序存储空间,程序空间按页面划分,每页2,K,字 (11 位);最多四页。,页面选择,PCLATH,复位向量地址 0000,h,中断向量地址 0004,h,Page 0,0000,h,0004,h,07,FFh,Interrupt,Reset,Page 1,0800,h,0,FFFh,Page 2,1000,h,17,FFh,Page 3,1800,h,1,FFFh,PCLATH = 00,PCLATH = 01,PCLATH = 10,PCLATH = 11,43,程序存储器中有2个单元地址比较特殊,除了具备同其他单元地址一样的普通用途外,还具有专门用途:,0000H:用作单片机系统的复位矢量;,0004H:用作系统特殊模块的中断矢量。,复位矢量中断矢量,44,F877用于存储数据的RAM单元比一般单片机RAM的功能要强大得多,它除了具备普通RAM的功能之外,每一个单元都能实现移位、置位、复位和位测试等通常由存放器才能完成的功能操作。,3.3 数据存储器构架,45,RAM数据存储器和FLASH程序存储器一样在空间构架上,进行类似方式进行分区。按横向排列,分为4个“体BANK,从左到右分别记为“体0、“体1、“体2和“体3,每个体为128个8位宽的存储器单元。,RP1:RP0 体域 存放器地址,0 0 体0: 000H 07FH,0 1 体1: 080H 0FFH,1 0 体2: 100H l7FH,1 1 体3: 180H lFFH,数据存储器分区,46,数据存储器,四个存储体每个 128 字节,特殊功能存放器,存储体选择通过 Status中的 RP0,1 和 IRP,512单元,368有效GPR,GPRs,SFRs,Bank0,000,h,01,Fh,020,h,07,Fh,GPRs,SFRs,Bank1,080,h,09,Fh,0,A0h,0,FFh,0,F0h,GPRs,SFRs,Bank2,100,h,11,Fh,120,h,17,Fh,170,h,GPRs,SFRs,Bank3,180,h,19,Fh,1,A0h,1,FFh,1,F0h,RP RP RP RP,= 00 = 01 = 10 = 11,47,48,有些存放器单元在4个体上是互相映射的,如状态存放器STATUS、间接寻址存放器INDF、程序计数器低8位PCL、文件选择存放器FSR、程序计数器高8位PCLATH和中断控制存放器INTCON。,所谓互为映射就是说,在4个体内的相同位置,物理上对应同一个存放器单元,所以该单元具备4个不同的地址。,互相映射,49,F877单片机的通用存放器GPRGeneral Purpose Registers,可由用户自行支配存放随机数据。,地址区域:F0HFFH、170Hl7FH和1F0H1FFH,都可以索引或映射到体0的16个RAM单元。,这样安排是为了便于中断效劳程序的设计和数据处理,就可以在程序设计中能够有效突破体的限制而定义通用的变量函数,3.3.1 通用存放器,50,特殊功能存放器SFRSpecial Function Registers是用于专用目的的存放器,每个存放器单元,甚至其中的每一位,都有它自己特定的名称和用途。,主要涉及PIC内核结构、外围功能模块的配置和数据通信方式的定义,是单片机赖于正常运行的工作平台。所以,特殊功能存放器又称为专用存放器。,可以依据它们不同的用途分为两类:一类是与CPU内核相关的存放器;另一类是与外围模块相关的存放器。,3.3.2 特殊功能存放器,51,状态存放器的内容用来记录算术逻辑单元ALU的运算结果状态、CPU的特殊运行状态以及RAM数据存储器体间选择等信息。,1状态存放器STATUS,52,Bit0C:进位/借位标志,被动参数。,0:执行加法或减法指令时,如果最高位无进位或有借位; 1:执行加法或减法指令时,如果最高位有进位或无借位。,Bit1DC:辅助进位/借位标志,被动参数。,0:执行加法或减法指令时,如果低4位向高4位无进位或有借位;,1:执行加法或减法指令时,如果低4位向高4位有进位或无借位。,Bit2Z:零标志,被动参数。,0:算术或逻辑运算结果不为0;,1:算术或逻辑运算结果为全0。,状态标志位,53,Bit6-Bit5RP1-RP0:RAM数据存储器体选位,仅用于直接寻址。,两位复合选择RAM数据存储器4个体,具体关系如下:,RP1、RP0 = 0 0 选中体0,RP1、RP0 = 0 1 选中体1,RP1、RP0 = 1 0 选中体2,RP1、RP0 = 1 1 选中体3,Bit7IRP:RAM数据存储器体选位,仅用于间接寻址。,0:选择数据存储器低位体:,即体0FSR的Bit7=0或体1FSR的Bit7=1;,1: 选择数据存储器高位体:,即体2FSR的Bit7=0或体3FSR的Bit7=1。,数据存储器体选位,54,在RAM数据存储器中,有一个非常特别的存放器INDF它的专有功能是与FSR存放器配合,实现间接寻址。,当访问地址INDF时,实际上是访问以FSR内容为地址的数据存储器RAM单元。,2间接寻址的存放器INDF和FSR,55,在直接寻址中,体选码来自状态存放器STATUS的RP1和RPO位,体内的单元地址直接来自指令机器码。而在间接寻址中,体选码由STATUS的IRP位和FSR存放器的BIT7组成,直接寻址/间接寻址方式的示意图,56,程序计数器PC指针宽13位,它的内容指向CPU将要执行的下一条指令所在程序存储器单元的地址。,低8位PCL有自己的地址,可读可写;而高5位PCH和其它单片机不一样,即没有自己的地址,不能用软件访问,也就不能直接写人,只能用存放器PCLATH装载的方式进行间接写人。,3与PC相关的存放器PCL和PCLATH,57,两种情况下,PC,值的装入过程,PCLATH,对于高5位,PCH,的装载分两种情况:,一种情况是当执行以,PCL,为目标的写操作指令时,,PC,的低8位来自算术逻辑单元,ALU,PC,的高5位来自,PCLATH,的低5位;,另一种情况是当执行跳转指令,GOTO,或调用子程序指令,CALL,时,,PC,的低11位来自指令码中直接携带的11位地址,高2位由,PCLATH,3-4,提供。,58,程序存储器:,PC,绝对寻址,OP CODE,k,k,k,k,14-位,call,和,goto,指令,k,k,k,k,k,k,k,通过,CALL,和,GOTO,修改,PC (,程序指针),k,k,k,k,k,k,k,k,k,x,x,x,k,k,x,x,x,PCLATH存放器,有效的 13-位程序存储器地址,11-位 来自指令,2-位,来自,PCLATH,k,k,k,k,59,PCH ,PCL ,13-位程序指针,PCLATH ,内部数据总线 ,5,5,8,movlwHIGH Delay,movwfPCLATH,movlwLOW Delay,movwfPCL,*对于读,PC,值时:,仅从,PCL,读低8位值,,PCH,不会被载入到,PCLATH,程序存储器:,PC,相对寻址,60,主要用于设置定时/计数器,TMR0、,前后分频器、外部,INT,中断以及,B,端口的弱上拉功能等各种控制位。,4选项存放器OPTION_REG,61,Bit2-Bit0PS2-PS0:,分频器倍率选择位,62,Bit3PSA:前后分频器分配位,主动参数。,0: 分配给TMR0,作为TMR0的前分频器;,1: 分配给WDT,作为WDT的后分频器。,Bit4T0SE:TMR0用于计数器,计数脉冲信号边沿选择位,主动参数。,0: RA4/T0CKI引脚上的上升沿增量;,1: RA4/T0CKI引脚上的下降沿增量。,Bit5T0CS:定时/计数器TMR0时钟源选择位,主动参数。,0: 用内部指令周期时钟CLKOUT作为TMR0的触发脉冲;,1: 用T0CKI引脚上的外部时钟作为TMR0的触发脉冲。,Bit6INTEDG:INT中断信号触发边沿选择位,主动参数。,0: BR0/INT引脚上的上升沿触发;,1: BR0/INT引脚上的下降沿触发。,Bit7RBPU:B端口弱上拉使能位,主动参数。,0: RB0-RB7引脚弱上拉使能;,1: RB0-RB7引脚弱上拉不使能。,63,主要用于中断控制,方式的,设置,。,5中断控制存放器INTCON,64,端口存放器PORTA,BCDE,端口I/O定义存放器TRISA,BCDE,Di = 0 定义为输出状态,Di = 1 定义为输入状态,6端口存放器,65,指令是单片机的领导核心,就是指挥,CPU,按要求进行一系列操作的命令。一般来说,单片机都具有自己特有的指令系统,相互之间大都互不兼容。,PIC,单片机系列按照不同用户的要求分成三个不同的应用档次,。,第4章,PIC,指令系统,66,指令的执行时间总是分解成两局部:取指过程和执行过程,取指的快慢直接与指令的字节数有关,而指令的执行快慢与时钟的振荡频率有关。,在以往的单片机结构中,程序存储器和数据存储器的地址空间和数据传输通道都相互并用,必须采用分时操作顺序执行。,而PIC单片机指令的执行过程是遵循着一种全新哈佛总线体系结构的原那么,充分利用计算机系统在程序存储器和数据存储器之间地址空间的相互独立性,取指过程和执行程序可以流水线操作同时进行。,4.1 指令流水线操作原那么,67,Flush Fetch,4,Fetch SUB_1,Tcy0 Tcy1 Tcy2 Tcy3 Tcy4,PIC,单片机指令流水线示意,Execute 1,Fetch 3,1.,MOVLW 55h,Fetch 1,Execute 3,Fetch 2,Execute 2,Fetch 4,2.,MOVWF PORTB,3.,CALL SUB_1,4.,BSF PORTA, BIT3,68,在这种寻址方式中,操作数或其中之一另一个是W是立即数, 随指令码携带,而无需再到其他地方去寻找。,指令中的操作数为8-位常数.,使用立即数寻址方式的指令有:,movlw, addlw, retlw, etc.,如: ADDLW16H,指令寻址方式说明,1.存放器立即寻址,14-位 立即寻址指令,OP CODE,k,k,k,k,k,k,k,k,69,2.存放器直接寻址,7-位 直接从指令中获取,2-位从STATUS 存放器中获取,如:IORWF26H,0,9-,位 有效寄存器地址,IRP,RP1,RP0,OP CODE,TO,PD,Z,DC,C,STATUS,寄存器,14-位指令,f,f,f,f,f,f,f,RP1,RP0,f,f,f,f,f,f,f,7-位来自指令字,2-位来自,STATUS,寄存器,70,3.存放器间接寻址,8-位 间接地址来自 FSR (选择存放器).,1-位 来自 STATUS 存放器.,例如:MOVWF INDF,IRP,f,f,f,f,f,f,f,f,f,IRP,RP1,RP0,TO,PD,Z,DC,C,f,f,f,f,f,f,f,STATUS,寄存器,8-位,FSR,寄存器,有效的 9-位寄存器地址,8-位来自,FSR,1-位来自,STATUS,寄存器,这是一种比较特别的寻址方式,是通过两个存放器INDF和FSR的组合而实现功能的。操作数是FSR存放器内容位指针,所指向存放器单元的内容。,71,间接寻址实例,运行机制:,a 清从0x20 to 0x7F所有的RAM区域,b间接地址载入FSR,c 每一次对INDF运行,由FSR指向的存放器被使用,例子:,movlw0x20,movwfFSR,LOOPclrfINDF,incfFSR,F,btfssFSR,7,gotoLOOP,0000 0000,0000 0000,FSR = 20h,INDF,00,h,04,h,20,h,7,Fh,数据记忆区,72,这是PIC单片机的特色之一,它可以对所有的RAM数据存储器进行位寻址,即置位和清零等。,如:BSF 26H,4;26H原为26H,4.位寻址,73,每条指令的字节长度为14位,主要由说明指令功能的操作码和参与指令处理的操作数组成。,操作码局部,简称助记符,如表4-2核心助记符,是借用英语单词来间接表达和定义其操作功能。,操作数局部,是按照操作码的操作功能,对操作数进行处理。,根据操作数的源地址和目标地址的访问性质,可以有多种表现形式:主要有直接寻址、间接寻址、立即寻址和位寻址四类。,4.2 指令集说明,74,核心助记符,75,指令系统补充字符说明,76,数据传送类指令共有4条指令,主要功能是将数据从源地址或立即数传送至目标地址中。,4.2.1 数据传送类指令,77,【例题4-1】 请利用数据传送类指令编写一段子程序,将立即数20H传送到通用存放器20H中。,【例题4-2】 请利用数据传送类指令编写一段子程序,将通用存放器20H和30H中的内容进行交换。,78,算术运算类指令是PIC单片机指令系统中,承担运算功能的重要局部,共有6条指令。主要有加减指令、增量和减量指令,4.2.2 算术运算类指令,79,【例题4-3】 请将通用存放器20H、30H构成的16位数据与通用存放器40H、50H构成的16位数据相加后放入40H、50H 中,其和不会超出65535。,80,逻辑运算类指令是一组比较复杂的指令,形式较多,可以对位和字节进行逻辑操作。主要有与、或、异或、清零、置位、取反和左右移位等14条指令,4.2.3 逻辑运算类指令,81,【例题4-4】 请将数据存储器20,H,和30,H,中的数据分别与立即数20,H、30H,相与和相或后相加,结果放入40,H,存储器中,请编写相应,的程序。,【,例题4-5,】 请编写一个完整的程序,将数据存储器20,H,低4位和30,H,高4位组合成一个八位二进制数据,并从,RC,端口输出。,82,控制转移类指令,是在指令系统中形式灵活、功能较强的一组指令,共11条。它们是构成程序循环和跳转的关键要素,一般可以分为有条件跳转和无条件跳转两大类,。,4.2.4 控制转移类指令,83,这是一种比较特殊的转移形式,根据位测试或加减1后的内容判断条件的成立与否,而决定程序继续执行还是间跳执行指令。,当前判断语句A,下一条语句B,再下一条语句C,1.相对转移间跳,84,PIC指令系统的绝对转移,主要由CALL和GOTO语句引出。在指令机器码内部本身并没有携带完整的转移目标地址,只包含低11位地址,而高2位将由PCLATH存放器给出。,【例题4-6】 请将通用存放器单元20H-2FH,分别对应赋值20H-2FH,请编写相应的软件程序。,2.绝对转移和调用,85,【,例题,4-7】,请分析以下程序片段,并指出当程序执行完后,涉及,到的所有存储器单元的结果。,MOVLW22H,MOVWF22H,MOVWFFSR,ADDWFINDF,F,INCFINDF,SWAPF22H,W,RLF22H,W,DECFFSR,F,MOVWFINDF,BSFINDF,7,【,例题4-6】编写散转指令程序,86,Microchip公司为PIC系列单片机配备了功能强大、基于Windows、易学易用的软件集成开发环境MPLAB。,该开发环境可以使人们在自己的微机系统上,对PIC系列单片机进行程序的创立、录入、编辑以及汇编,还能方便而灵活地实现程序的模拟运行和动态调试,可以对实际应用系统进行在线仿真和功能模块开发。,第5章,PIC,集成开发系统,87,PIC,单片机指令系统和其它单片机一样,是较为低级的语言系统,是一套控制和指挥,CPU,工作的编码,即机器语言。,单片机只能识别和执行由二进制数组成的机器语言,然而,这样一种二进制代码的机器语言是很难为人们直接理解和分析。,为了能较好表达人们的设计思路,便于记忆和使用,人们在低级语言之上设计出一种新的符号语言,即汇编语言。,第6章 汇编语言程序设计,88,PIC,单片机指令系统和其它单片机一样,是较为低级的语言系统,是一套控制和指挥,CPU,工作的编码,即机器语言。,为了能较好表达人们的设计思路,便于记忆和使用,人们在低级语言之上设计出一种新的符号语言,即汇编语言。,6.1 汇编语言指令格式,89,根据指令的功能和作用,只有操作码是必须存在的,它主要决定了指令的操作性质,而其它局部是指令语句的重要补充和说明,有时可以缺省。,90,标号位于指令助记符前面,它一般是用于表示指令所在的地址,例如表示主程序或子程序的起始地址、转移语句的入口地址等。,1.标号,91,标号并不是指令的必须局部,只有那些欲被其他语句引用的指令之前,才必须附加标号。标号不一定和语句同行,可以单独在语句上方作为一行使用。,标号最多可以由32个字母、数字和其它一些字符组成,但第一个字符必须是字母或下划线。标号不能用系统保存字,即系统禁用指令助记符、存放器名、标志符等作为标号,如:ADD、PCLATH等。,一个标号只能表示一个地址,不允许多个地址用一个标号重复定义。,标号的定义和引用必须一致,其中的大小写可以混写但必须相同。,标号必须顶格书写,结束不用冒号。,使用标号的要点是:,92,操作码决定着指令的操作类型和操作性质,是汇编语言语句中的核心要素,每一条汇编指令都不可缺少,而其它三局部有些指令可以缺省。,2. 操作码,93,操作码所对应的指令助记符,其中的符号大小写可以混写,而不会影响操作码的含意,这一点和标号、操作数符号变量的表达方式是有本质区别。,指令助记符不能顶格书写,当前面没有标号时,必须至少保存一个空格。,操作码核心助记符局部比较简单,初学者必须熟悉复合助记符局部的功能。,有关操作码指令助记符的要点是:,94,在,PIC,汇编语言语句中,操作数的形式和内容最为丰富,它是,指令助记符操作的对象,一般以数据或地址的形式出现,也可以用符号变量所表示的数据或地址。,3.操作数,95,使用操作数的要点是:,假设操作数有二项,中间应该用逗号半角分开。,以A、B、C、D、E、F开头的数,前面应加0作为引导。,MPASM编辑环境默认进制为十六进制,也可按用户需要进行重新设置。,操作数局部的符号变量必须区分大小写。,重视d参数的应用,目标地址为: Fd=1;Wd=0。,96,各种进制168的表示形式,97,注释内容用分号引出,是汇编语言语句功能的一种补充说明,主要是便于人们阅读、分析、修改和程序的调试。,4. 注释,98,用半角分号引出注释内容,可以紧跟指令之后,也可以独立一行或多行书写,但每一行均需由分号引出。,注释内容可以英文书写,也能用中文书写来源于文本编辑内容。,使用注释的要点是:,99,各种单片机的汇编程序除了指令系统语句以外,一般都还定义许多非正式指令的语句,即伪指令。大多数伪指令汇编时并不产生机器码,仅为源程序提供汇编控制信息。,6.2 系统伪指令,100,格式:,ORG nnnn,说明:,ORG,伪指令指出紧跟在该伪指令后的机器码指令的汇编地址,即经汇编后生成的机器码目标程序或数据块在单片机程序存储器中的起始存放地址。,1.定位伪指令:ORGOrigin,101,格式:符号名 EQU nn,说明:EQU伪指令几乎每一个程序中都用到,其操作含意是使EQU两端的值相等。一般在PIC的程序设计中,原那么上每次遇到新的符号参数,都必须在前面补充定义符号名的初始数值或存储器地址。,符号名一旦被EQU赋值,其值便不能被再重新定义。这里的符号名,既可以是PIC中的特殊功能存放器、一个常数,或者是表示一个通用数据存储器地址。,2.赋值伪指令:EQUEquate,102,实际上对于伪指令:,ABC EQU20H,,其中,ABC,既可以认为是符号变量,因为,ABC,代表20,H,地址;又可以认为是符号常量,因为,ABC,可以代表符号常量20,H。,所以对于一个定义的符号量,应结合引用的指令进行分析才能真正确定符号量的类型。,分析,ABC EQU20H,103,【,例题,6-2】正确区别符号变量和符号常量之间的关系,ABCEQU 20H;,定义符号量,ABC,ORG 0000H,NOP,MOVLW 77H,MOVWF 20H,MOVLW 88H,MOVF ABC,0;ABC,为数据存储器地址20,H,MOVLW ABC ;ABC,为常量20,H,NOP,END,104,在符号名定义和引用过程中,必须保证大小写属性的一致性,注意不能混合使用以及所代表角色功能。,如果有定义:,ABCEQU20H,在引用符号名,ABC,时,不能改变其大小写的属性,即,Abc、aBC,或,ABc,与,ABC,是不一样的,在汇编时均会发生出错信息。,105,格式:END,说明:END伪指令表示汇编语言源程序*.ASM的结束,MPASM汇编器汇编时遇到END就认为程序已结束,对其后的程序段不再进行汇编。,3.程序结束伪指令:,END,106,格式:LIST 可选项,可选项,,说明:LIST伪指令用于设置各种汇编参数,以便控制整个汇编过程或对打印输出的列表文件进行格式化。,1P,例如:P16F877,2R,例如:RDEC十进制;,RHEX十六进制;,RBIN二进制;,默认为十六进制。,4.列表选项伪指令:,LIST,107,格式:INCLUDE “文件名,说明:INCLUDE伪指令的主要功能是将外部预先编写好的指定文件纳入根源程序的汇编内容,这样可以减少重复劳动,提高编程效率。,如:P16F877.INC为F877单片机的复位矢量、专用存放器的地址及其控制位和状态位的位地址的原始定义,有些参考书把P16F877.INC称为F877的头文件。,5.外调程序伪指令:,INCLUDE,108,格式:,RADIX,说明:,RADIX,伪指令用于设置在,MPLAB-ICD,集成开发环境中采用的进制方式,如定义十进制、八进制和十六进制等参数,,MPLAB-ICD,集成开发系统缺省为十六进制。,例如:,RADIX DEC ;,定义为十进制,RADIX HEX ;,定义为十六进制,RADIX OCT ;,定义为八进制,6.进制定义伪指令:,RADIX,109,在PIC单片机中,有两个概念是令初学者感到头痛的事情,也是本课程的难点和重点,对于正确进行程序设计至关重要。,一个是数据存储器四体的体选方式,需要时刻考虑每一个访问的特殊功能存放器和通用数据存储器的体位;另一个是程序存储器四页的页选方式,特别是在发生转移或跳转时,须密切注意是否会发生页面转换。,6.3 存储器选择方式,110,F877,单片机的数据存储器是一个具有空间为512字节的存储器,其中只有19个字节是无效存储单元。为了能完全选择512字节内的数据,需要9根地址线。,而根据9根地址线的组合方式不同,形成两种迥然不同的寻址方式:即直接寻址和间接寻址。,6.3.1 数据存储器体选方式,111,根据直接寻址和间接寻址操作码携带址址信息情况,一般把512字节包括无效地址的数据存储器分成4个区域,在PIC中被称为“体BANK。,体0000H07FH,体1080H1FFH,体2100H17FH,体3180H1FFH,数据存储器体域,112,在指令机器码中操作数所携带的寻址信息是低7位地址,这不是一个完备的数据信息,每一个体中均会有一个相关的地址与之对应。要惟一确定地址单元,还必须依托其它的数据线进行复合选择。,利用状态标志,STATUS,位中的,RP1,和,RP0,,与直接寻址机器码中低7位地址共同选择相应数据存储器的内容参与操作。,1.直接寻址访问数据存储器,113,在指令机器码中真正携带的寻址信息是低8位地址,这也不是一个完备的数据信息,在整个数据存储器中有二个相关的地址与之对应。,要惟一确定地址单元,也必须依托另一根数据线进行复合选择。主要是依托状态标志位的,IRP,,才能准确选择相应数据存储器的内容参与操作。,2.间接寻址访问数据存储器,114,F877单片机的程序存储器FLASH是一个具有空间为8K14位的存储器,其中14位为单元字节长度。为了能完全选择8K的程序存储器,需要合成13根地址选择线。,6.3.2 程序存储器页选方式,115,复位地址0000H,直接给出13根地址选择线;,中断地址0004H,直接给出13根地址选择线;,指令存放器,是在每一个指令的执行周期自动加1而形成当前程序的执行方向;,执行以PCL为目标地址的算术逻辑类指令;,调用子程序方式,即CALL语句以及相应的返回语句RETRUN、RETFIE、RETLW。,转移指令方式,即GOTO语句;,程序存储器指令语句的选择,主要有以下几种途径:,116,执行以PCL为目标地址的算术逻辑类指令,执行跳转指令call、goto、retrun、retfie、retlw,两类指令的执行过程中的装载效能,117,ABC EQU 20H,ORG 0100H,BANKSEL ABC,MOVLW 00H ;,常数00送入,W,MOVWF ABC ;W,送入,ABC,存储器中,ORG 0100H,PAGESEL ABC,GOTO ABC ;,转移至,ABC,ORG 1000H,ABC MOVLW 00H;,常数00送入,W,MOVWF 20H;W,送入20,H,中,补充伪指令,PAGESEL、BANKSEL,118,在程序设计中,除主程序以外还有一局部很重要的内容就是关于子程序的设计,它是为完成特定的目的而构成的复合程序。,6.4常用子程序的设计,119,转移和循环程序,主要是通过跳转、判断和位测试指令来构成的。,1.跳转指令,GOTO,2.判断指令,INCFSZ,、DECFSZ,3.位测试指令,BTFSS,、,BTFSC,6.4.1 转移和循环子程序,120,【例题6-6】比较两个数据存放器20H和30H内容的大小,将较大的数送入40H中。,【例题6-6】请将通用存放器单元20H-2FH,分别对应赋值20H-2FH,请编写相应的软件程序。,【例题6-7】假定RB0接入一个按键K,当K按下时,RB0为高电平,而K为常态时,RB0为低电平。请编写按键K的监控扫描片段程序,DELAY10MS为10M延迟程序,程序框图如6-4所示。,121,单片机的延时程序,在程序设计中具有很重要的地位。延时的设计,一般可以通过两种方式:硬件延时和软件延时。,所谓硬件延时,就是由单片机系统的定时器实现;而软件延时,是通过循环程序实现。一般来说,前者适用于精确定量延时,而后者常用于初略定性延时。,【,例题6-8,】简单循环的软件延时子程序。,【,例题6-9,】请编写10,MS,软件延时子程序。,【,例题6-10,】请编写1,S,软件延时子程序。,6.4.2 软件延时子程序,122,数据查表子程序在某些特殊场合是非常有用的,如共阴极,LED,八段显示器以及其它具有固定显示模式的场合,需根据其显示数值去查找对应参考数据库编码输出。,6.4.3 数据查表子程序,123,【,例题6-11,】将,RC,端口与共阴极,LED,八段显示器相连,从0-9循环显示,间隔时间为1秒,请编写相应的软件程序。,八段显示数值0-9编码,124,00000000,XXXXXXXX,PIC,单片机架构,PC,相对寻址,查表实例,movlwHIGH Decode,movwfPCLATH,movf DisplayValue,W,callDecode,movwfPORTB,gotoContinue,Decode,addwfPCL,F,retlwB00111111 ;decode 0,retlwB00000110 ;decode 1,retlwB01011011 ;decode 2,retlwB01001111 ;decode 3,retlwB01100110 ;decode 4,retlwB01101101 ;decode 5,retlwB01111101 ;decode 6,retlwB00000111 ;decode 7,retlwB01111111 ;decode 8,retlwB01101111 ;decode 9,Continue,b,e,g,a,f,d,c,RB0,RB1,RB2,RB3,RB4,RB5,RB6,b,c,d,e,f,g,W 存放器,I/O B,口,01101101,00000101,01101101,g,a,f,d,c,b,e,125,【,例题6-12,】将,RC,端口与八个,LED,显示器相连,请按照表6-4即跑马灯流动显示方式,间隔时间为1秒,请编写相应的软件程序。,126,在,PIC,指令系统中并没有类似的语句,但如果借助于,PIC,单片机指令的特殊功能,同样可以轻松地构成分支跳转。,分支跳转实际上是多条件判断指令,条件本身是一个整数或事件,而跳转出口应该是整数的信息返回或事件功能内容的具体表现。,在程序形式上,分支功能跳转子程序与数据查表子程序的结构类似,只是它是用,GOTO,语句替代了,RETLW,语句。,6.4.4 分支功能跳转子程序,127,假定,W,为某个按键的输入值,JIANGNADDWFPCL,F ;,确定相对偏移量,GOTOPKEY0 ;,执行,PKEY0,键盘定义功能,GOTOPKEY1;,执行,PKEY1,键盘定义功能,GOTOPKEY2;,执行,PKEY2,键盘定义功能,.,.,.,GOTOPKEYN;,执行,PKEYN,键盘定义功能,128,本节给出一些常用的数学运算类子程序,主要有加、减、乘、除等子程序,还有为外扩系统设计中的数码显示所需的BCD码和二进制数据的互换子程序。,均涉及入口条件及出口条件,在调用时务必加以注意。一般入口条件是指参与操作的相关源数据,用S1、S2source等表示,而操作结果用R1、R2result等表示。上下8位数据分别用H、L表示,另外用Z表示中8位数据。,可以将这些固定变量参数定义在PIC16F877的头文件内,并且单元定义位于映射区域70H7FH,这样就可以不受程序所在页面的影响。,6.4.4 常用数学运算类子程序,129,将两个无符号16位数相加,编写双精度运算程序。,将两个无符号16位数相减,编写双精度运算程序。,将两个无符号16位数相乘,编写双精度运算程序。,将两个无符号16位数相除,编写双精度运算程序。,将一个5位数65 535 的BCD码转换成二进制数。,将一个16位二进制数转换成BCD码 65535 ,130,单片机的性能优劣在很大程度上取决于I/O端口功能的强弱,F877 PDIP型单片机共有40个管脚,其中有33个是I/O引脚。,33个I/O引脚归属于5个端口,分别为PORTA6、PORTB8、PORTC8、PORTD8、PORTE3,其中括号内的数字为该端口的位数。,第7章 输入输出端口,131,F877单片机有5 个I/O端口,它们的设计思想和内部结构都是不同的,即使同一个端口各个引脚的内部结构也存在差异。但就其通用的输入/输出功能,根本具有类同的线路结构。,7.1 I/O,端口功能的通用结构,132,根本端口内部结构,133,F877单片机共有十个外围功能模块,几乎每一个或多或少都与I/O端口有关系,有些涉及到控制引脚,有些作为数据输入输出通道。,根本I/O端口功能的设置非常方便,只要对I/O端口的方向存放器TRIS进行定义即可。某个引脚对于位:设置为1定义为输入状态,设置为0定义为输出状态。,7.2 I/O端口存放器及其初始化,134,【,例题7-2,】将,RC,端口的高四位和低四位分别设置为输入和输出端,而把,RB,端口全部定义为输出接口。,135,【,例题7-3,】 接上例,将,RC,端口的高四位和低四位分别设置为输入和输出端后,高四位引脚分别与四个输入按钮相连,低四位引脚分别与四个,LED,发光管相连,如图7-3所示。编程要求:当,K1,按下,,LED1,亮1秒;当,K2,按下,,LED2,亮2秒;当,K3,按下,,LED3,亮3秒;当,K4,按下,,LED4,亮4秒。,7.3根本输入/输出应用实例,136,【例题7-4】RC口连接八个LED显示器,以作为自动加1计数器的显示窗口,间隔时间为1秒。请编写相应的控制程序。,137,第八章 定时器计数器,定时器/计数器模块是大局部单片机都内置的一项重要功能,定时器/计数器的正常工作一般表现为计数累计功能,通常是由时钟脉冲来驱动。,定时器/计数器模块一般适用于以下3种不同的应用场合:,从单片机I/O引脚上向外部电路输出一系列符合一定时序标准的方波信号。,从单片机I/O引脚上,检测外部电路输入的一系列方波信号的脉宽、周期或频率,以便单片机接收外部电路的输入信号或通信信号。,单片机对其端口引脚上输入的由外部事件产生的触发信号进行准确地计数,依据计数结果来控制完成相应的动作。,138,F877,单片机配置3个定时器/计数器模块,:,CCP:输入捕捉、输出比较和PWM脉冲宽度调制功能,低频时基振荡器 :32768Hz,139,三者的共同点:,它们的核心局部都是一个由时钟信号触发,按递增方式累加工作的循环计数器;从预先设定的某一初始值开始累计,在累计到计数器产生溢出,并且同时会建立一个相应的溢出中断标志。,140,8.1 定时器计数器,TMR0,它们的核心局部都是一个由时钟信号触发,按递增方式累加工作的循环计数器;,从预先设定的某一初始值开始累计,在累计到计数器产生溢出,并且同时会建立一个相应的溢出中断标志。,141,是一个8位宽的由时钟信号上升沿触发的循环累加计数寄,存器TMR0;,TMR0也是一个在文件存放器区域内统一编址的存放器,,地址为01H或101H。用户用软件方式可直接读/写计数器,的内容;,具有一个软件可编程的8位预分频器;,既可工作于定时器模式,又可工作于计数器模式;,当使用内部触发信号,即指令周期作为时钟信号源时
展开阅读全文