《基于SPI总线的无线呼叫接收器设计word格式源文件.doc》由会员分享,可在线阅读,更多相关《基于SPI总线的无线呼叫接收器设计word格式源文件.doc(45页珍藏版)》请在三一办公上搜索。
1、基于SPI总线的无线呼叫接收器设计摘 要SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约布局空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。近年来,SPI串行接口设备凭借其控制灵活,接口简单、占用资源少等优点在工业控制、仪器仪表等领域被广泛应用。这些发展趋势更加使得串行通信功能加强了,同时带有串行接口的器件也被广泛使用。本次设计是对基于SPI总线的无线呼叫用接收器进行研究,并选取带有一种总线接口的器件进行系统设计。本文以AT89C51单片机作为主控中心,由带有SPI接口的时钟芯片提供时钟,并用LCD液晶显示器进行显示。AT89
2、C51单片机是有Atmel公司推出的,功耗小,电压可选用4-6V电压供电。因此,基于SPI总线的无线呼叫接收器的设计和研究意义重大而实用。关键词 SPI/AT89C51/无线呼叫/接收器SPI BUS WIRELESS CALL RECEIVER DESIGNABSTRACTSPI, it is a high-speed, full-duplex, synchronous communication bus, and the tube feet in chip only occupy four thread, save layout space, providing convenient, i
3、t is out of this easy-to-use features, now more and more chip integrated the communication protocol. In recent years, SPI serial interface device with its control flexible, simple interface, occupancy resources advantages such as less in industrial control, instruments, etc widely application. These
4、 trends more makes serial communications functions strengthened, meanwhile with serial interface devices were also widely used.The design is based on SPI bus wireless call with receivers studied, and select the bus interface with a kind of devices system design. Based on AT89C51 as the master centre
5、, and from the clock with SPI interface chip, and provide the clock on LCD display. AT89C51 single product even with Atmel company launched, low consumption, voltage can choose 4-6V voltage power supply. Therefore, based on SPI bus wireless calls the design and study with receiver is significant and
6、 practical. KEYWORDS SPI, AT89C51, Wireless Call, Receiver目录中文摘要英文摘要1 绪论11.1 无线呼叫器的应用11.2 SPI总线的优点21.3 无线呼叫器的优势22 SPI串行总线的结构和工作原理42.1 SPI串行总线的结构62.2 SPI串行总线的工作原理113 总体设计方案143.1 系统从机结构143.2 系统主机结构154 硬件电路164.1元器件的选择164.2电路原理图185 软件流程235.1 发射部分设计235.2 接收部分设计266 结论31致 谢32参考文献33附录341 绪论1.1 无线呼叫器的应用无线呼叫器
7、是在有线呼叫器的基础上发展起来的,我们所常见的有线呼叫器,如:医院的病床呼叫器、电梯里的求助按钮和公共场所的紧急报警按钮等,因其操作简单而有效。但是有线呼叫器需要布线,费用高,施工繁琐而无法得到广泛应用。有需求,就会有产品,无线呼叫器应运而生。 无线呼叫器是一种新型的无线电子产品,广泛用于:餐饮、娱乐、休闲、工厂、超市、办公和家庭等场所。无线呼叫器按照无线调试方式的不同可分为调频FM无线呼叫器和调幅AM无线呼叫器两大类。下面以调频无线呼叫器为例,产品主要包括:外壳、电源、按键、稳压电路、单片机编码控制、晶体放大器、倍频放大器和天线等部分。无线呼叫器从技术和应用可大致分为三个阶段:第一阶段以调幅
8、AM技术为主(即:第一代无线呼叫器),主要用于场地较小的场所;第二阶段是以调频FM为核心技术的产品(即:第二代无线呼叫器系统),信号稳定,适合大型组网,应用行业从茶楼、咖啡厅等小型服务场所,发展到大型娱乐场所、酒店、工厂、超市、学校和银行等行业,这个阶段是无线呼叫器应用发展最为迅速的一个时期;第三阶段是调频技术、语音技术和对讲技术为核心的语音无线呼叫系统,实现了无线呼叫器从模拟、数字到语音的蜕变,成为无线呼叫器系统应用的趋势和主流。无线呼叫的典型应用有医院无线呼叫系统,如图1所示。本设计设置AT89S51为主控器,ISD4002为从器件,通过SPI口完成通信控制的过程。而完成SPI总线接口设计
9、,首先需要了解SPI总线的组成结构和工作原理。图1 医院呼叫系统总体框架图1.2 SPI总线的优点SPI,是英语Serial Peripheral interface的缩写,顾名思义就是串行外围设备接口。SPI,高速同步串行口是一种标准的四线同步双向串行总线,是Motorola首先在其MC68HCXX系列处理器上定义的。SPI接口主要应用在 EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在
10、越来越多的芯片集成了这种通信协议,比如AT91RM9200. 1.3 无线呼叫器的优势无线呼叫器的安装简便,操作简单,针对性解决服务呼叫,紧急呼叫等问题,越来越受服务场所的青睐。 1、无线呼叫器有利于提升服务形象 2、无线呼叫器有利于提高服务工作效率; 3、无线呼叫器解决紧急呼叫问题; 4、无线呼叫器可使服务管理标准化; 无线呼叫器,从技术上又分调频无线呼叫器和调幅无线呼叫器。调频无线呼叫器在性能上明显比调幅无线呼叫器好。大家选择的时候可以优先选择调频无线呼叫器,质量上有保障。2 SPI串行总线的结构和工作原理SPI:高速同步串行口是一种标准的四线同步双向串行总线,顾名思义就是串行外围设备接口
11、。是Motorola首先在其MC68HCXX系列处理器上定义的。SPI接口主要应用在 EEPROM,FLASH,实时时钟,AD转换器,还有数字信号处理器和数字信号解码器之间。SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。SPI总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。SPI总线系统可直接与各个厂家生产的多种标准外围
12、器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。 SPI的通信原理很简单,它以主从方式工作,这种模式通常有一个主设备和一个或多个从设备,需要至少4根线,事实上3根也可以(用于单向传输时,也就是半双工方式)。也是所有基于SPI的设备共有的,它们是SDI(数据输入),SDO(数据输出),SCK(时钟),CS(片选)。 (1)SDO 主设备数据输出,从设备数据输入 (2)SDI 主设备数据输入,从设
13、备数据输出 (3)SCLK 时钟信号,由主设备产生 (4)CS 从设备使能信号,由主设备控制 其中CS是控制芯片是否被选中的,也就是说只有片选信号为预先规定的使能信号时(高电位或低电位),对此芯片的操作才有效。这就允许在同一总线上连接多个SPI设备成为可能。如图所示是由一个主机对接一个从机进行全双工通信的系统构成的方式。在该系统中,由于主机和从机的角色是固定不变的,并且只有一个从机,因此,可以将主机的丽端接高电平,将从机的SS端固定接地。图2 主机控制从机接下来就负责通讯的3根线了。通讯是通过数据交换完成的,这里先要知道SPI是串行通讯协议,也就是说数据是一位一位的传输的。这就是SCK时钟线存
14、在的原因,由SCK提供时钟脉冲,SDI,SDO则基于此脉冲完成数据传输。数据输出通过 SDO线,数据在时钟上升沿或下降沿时改变,在紧接着的下降沿或上升沿被读取。完成一位数据传输,输入也使用同样原理。这样,在至少8次时钟信号的改变(上沿和下沿为一次),就可以完成8位数据的传输。 要注意的是,SCK信号线只由主设备控制,从设备不能控制信号线。同样,在一个基于SPI的设备中,至少有一个主控设备。这样传输的特点:这样的传输方式有一个优点,与普通的串行通讯不同,普通的串行通讯一次连续传送至少8位数据,而SPI允许数据一位一位的传送,甚至允许暂停,因为SCK时钟线由主控设备控制,当没有时钟跳变时,从设备不
15、采集或传送数据。也就是说,主设备通过对SCK时钟线的控制可以完成对通讯的控制。SPI还是一个数据交换协议:因为SPI的数据输入和输出线独立,所以允许同时完成数据的输入和输出。不同的SPI设备的实现方式不尽相同,主要是数据改变和采集的时间不同,在时钟信号上沿或下沿采集有不同定义,具体请参考相关器件的文档。 在点对点的通信中,SPI接口不需要进行寻址操作,且为全双工通信,显得简单高效。在多个从设备的系统中,每个从设备需要独立的使能信号,硬件上比I2C系统要稍微复杂一些。2.1 SPI串行总线的结构无线呼叫系统是一种用于呼叫的电子产品,是一个包含软件和硬件的系统,被广泛的应用于餐饮、休闲、医护、行政
16、办公等场所。 从硬件的组件来看,有调频呼叫器或调幅呼叫器、控制中心、数字信息机、监控系统接收机、监控系统软件、信号增强器、取号器、外接发射机等。 从功能和应用上分为医院呼叫系统,酒店无线呼叫系统,餐饮无线呼叫系统,工厂专用无线呼叫系统等等。 从技术角度分有两大类:调幅(AM)产品和调频(FM)产品,我们生活中的无线门铃、玩具和汽车遥控器等属于调幅产品,手机、对讲机、寻呼机等属于调频产品。目前,无线呼叫系统调频技术的代表产品是多嘴猫,调幅技术的代表产品是讯铃、红铃等。利用SPI总线可在软件的控制下构成各种系统。如一个主MCU和几个从MCU、几个从MCU相互连接构成多主机系统(分布式系统)、一个主
17、MCU和一个或几个从I/O设备所构成的各种系统等。在大多数应用场合,可使用一个MCU作为主控机来控制数据,并向一个或几个从外围器件传送数据。从器件只有在主机发命令时才能接收或发送数据。其数据的传输格式是高位(MSB)在前,地位(LSB)在后。SPI总线接口系统的典型结构如图3所示。 图3 SPI总线的典型结构当一个主控制机通过SPI与几种不同的串行I/O芯片相连时,必须使用每片的允许控制端,这可通过MCU的I/O口输出线来实现。但应特别注意这些串行I/O芯片的输入输出特性:首先是输入芯片的串行数据输出是否有三态控制端。平时未选中芯片时,输出端应处于高阻态。若没有三态控制端,而应外加三态门。否则
18、MCU的MISO端只能连接一个输入芯片。其次是输出芯片的串行数据输入是否有允许控制端。因此只有在芯片允许时,SCK脉冲才把串行数据移入该芯片;在禁止时,SCK对芯片无影响。若没有允许控制端,则应该在外围用门电路对SCK进行控制,然后再加到芯片的时钟输入端;当然,也可以只在SPI总线上连接一个芯片,而不再连接其他输入或输出芯片。SPI总线是Motorola公司推出的三线同步接口,同步串行3线方式进行通信:一条时钟线SCK,一条数据输入线MOSI,一条数据输出线MISO;用于 CPU与各种外围器件进行全双工、同步串行通讯。SPI主要特点有:可以同时发出和接收串行数据;可以当作主机或从机工作;提供频
19、率可编程时钟;发送结束中断标志;写冲突保护;总线竞争保护等。SPI总线有四种工作方式(SP0, SP1, SP2, SP3),其中使用的最为广泛的是SPI0和SPI3方式。SPI模块为了和外设进行数据交换,根据外设工作要求,其输出串行同步时钟极性和相位可以进行配置,时钟极性(CPOL)对传输协议没有重大的影响。如果CPOL=0,串行同步时钟的空闲状态为低电平;如果CPOL=1,串行同步时钟的空闲状态为高电平。时钟相位(CPHA)能够配置用于选择两种不同的传输协议之一进行数据传输。如果 CPHA=0,在串行同步时钟的第一个跳变沿(上升或下降)数据被采样;如果CPHA=1,在串行同步时钟的第二个跳
20、变沿(上升或下降)数据被采样。SPI主模块和与之通信的外设音时钟相位和极性应该一致。SPI总线实施简单,仅使用四条数据信号线和控制信号线,如图4所示。图4 SPI端口数据传输通常会包含一次数据交换。当主节点向从节点发送数据时,从节点也会向主节点发送数据。为此,主节点的内部移位寄存器和从节点被设置成环形,如图5所示。图5 数据传输SPI总线有四种工作方式(SP0, SP1, SP2, SP3),其中使用的最为广泛的是SPI0和SPI3方式。SPI时序图详解-SPI接口在模式0下输出第一位数据的时刻SPI接口在模式0下输出第一位数据的时刻SPI接口有四种不同的数据传输时序,取决于CPOL和CPHL
21、这两位的组合。图1中表现了这四种时序,时序与CPOL、CPHL的关系也可以从图6中看出。图6 时序图CPOL是用来决定SCK时钟信号空闲时的电平,CPOL0,空闲电平为低电平,CPOL1时,空闲电平为高电平。CPHA是用来决定采样时刻的,CPHA=0,在每个周期的第一个时钟沿采样,CPHA1,在每个周期的第二个时钟沿采样。由于我使用的器件工作在模式0这种时序(CPOL0,CPHA0),所以将图2.21简化为图7,只关注模式0的时序。图7 时序简化图在 SPI 中,主节点可以与单个或多个从节点进行通信。在使用单个从节点的情况下,从选择信号可以关联到从设备的本地接地电位以允许永久接入。对于使用多个
22、从节点的应用,可能有两种结构:独立和菊花链式从节点,如图8所示。图8 独立和菊花链式两种结构从节点独立寻址时,主节点必须提供多个从选择信号。该结构一般用在数据采集系统中,其中的多个模数转换器 (ADC) 和数模转换器 (DAC) 都必须单独接入。菊花链式从节点需要主节点提供唯一的从选择信号,因此该结构要求同时启用所有从节点,以确保菊花链内通过所有移位寄存器的数据流不会中断。典型的应用为工业级 I/O 模块中的级联多通道输入串行器和输出驱动器。2.2 SPI串行总线的工作原理SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空
23、间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。SPI是一个环形总线结构,由ss(cs)、sck、sdi、sdo构成,其时序其实很简单,主要是在sck的控制下,两个双向移位寄存器进行数据交换。上升沿发送、下降沿接收、高位先发送。上升沿到来的时候,sdo上的电平将被发送到从设备的寄存器中。下降沿到来的时候,sdi上的电平将被接收到主设备的寄存器中。假设主机和从机初始化就绪:并且主机的sbuff=0xaa (10101010),从机的sbuff=0x55 (01010101),下面将分步对spi的8个时钟周期的数据情况演示一遍(假设上升沿发送数据)。表1如下:-脉冲
24、 主机sbuff 从机sbuff sdi sdo-0 00-0 10101010 01010101 0 0-1 0-1 0101010x 10101011 0 11 1-0 01010100 10101011 0 1-2 0-1 1010100x 01010110 1 02 1-0 10101001 01010110 1 0-3 0-1 0101001x 10101101 0 13 1-0 01010010 10101101 0 1-4 0-1 1010010x 01011010 1 04 1-0 10100101 01011010 1 0-5 0-1 0100101x 10110101 0
25、15 1-0 01001010 10110101 0 1-6 0-1 1001010x 01101010 1 06 1-0 10010101 01101010 1 0-7 0-1 0010101x 11010101 0 17 1-0 00101010 11010101 0 1-8 0-1 0101010x 10101010 1 08 1-0 01010101 10101010 1 0-这样就完成了两个寄存器8位的交换,上面的0-1表示上升沿、1-0表示下降沿,sdi、 sdo相对于主机而言的。根据以上分析,一个完整的传送周期是16位,即两个字节,因为,首先主机要发送命令过去,然后从机根据主机的
26、名准备数据,主机在下一个8位时钟周期才把数据读回来。 3 总体设计方案无线呼叫系统是一个包含软件和硬件的系统,被广泛的应用于餐饮、休闲、医护、行政办公等场所。其系统又可分为主机部分和从机部分,其结构分别如下。3.1 系统从机结构无线呼叫系统从机部分由主机部分控制。该设计是SPI总线通过SPI接口与STR710FZ20相连。STR710FZ20又与外围的按键电路、射频电路、语音电路和辅助电路相连通过声光报警和LCD显示出来。如下图9所示。图9 系统从机结构框图3.2系统主机结构无线呼叫系统的主机部分控制从机部分。主机部分的大致结构为SPI总线通过SPI接口与单片机设备相连。该设备又通过SPI接口
27、与PC机相连,此外,还有按键电路、语音电路、辅助电路组成,通过声光报警和LCD显示出来。如下图10所示。图10 系统主机结构框图4 硬件电路4.1元器件的选择本无限呼叫器用接收器以Atmel AT89C51为内核。AT89C51是Atmel公司生产的一种低功耗、高性能的8位CMOS微处理器芯片。片内带有4KB的闪烁可编程及可擦除的只读存储器,与工业标准的80C51指令集兼容。片上的PEROM允许在线对程序存储器重新编程,也可用常规的非易挥发储存芯片编程器编程。本设计最重要的当然是SPI接口芯片的选取,在此选用美国Xicor公司生产的集“看门狗”定时器、电压监控和串行EEPROM三项功能于一体的
28、专用集成芯片X5045。这种组合降低了系统成本并减少了对电路板空间的要求。其功能框图如11所示。图11 X5045功能框图芯片特性:可选时间的看门狗定时器。 VCC的降压检测和复位控制5种标准的开始复位电压使用特定的编程顺序即可对低电压检测和复位开始电压进行编程。 复位电压可低至VCC=1V。省电特性 在看门狗打开时,电流小于50uA 在看门狗关闭时,电流小10uA 在读操作时,电流小2mA 不同的型号的器件,其供电电压可以是1.8-3.6V,2.7V-5.5V,4.5V-5.5V。4K位EEPROM,1,000,000次的擦写周期。具有数据的块保护功能可以保护1/4、1/2、全部的EEPRO
29、M,当然也可以置于不保护状态。内建的防误写措施 用指令允许写操作。 写保护引脚。 时钟可达3.3M。短的编程时间 16字节的页写模式。写时由器件内部自动完成。 典型的器件写周期为5ms。 该芯片内的串行EEPROM是具有Xicor公司的块锁保护CMOS串行EEPROM,它被组织成8位的结构。它由一个由4线构成的SPI总线方式进行操作,其擦写周期至少有1000000次,并且写好的数据能够保存100年。无线接发芯片采用PT2262/2272。PT2262/2272是一种CMOS工艺制造的低功耗低价位通用编码解码电路,是目前在无线通信电路中作地址编码识别最常用的芯片之一。PT2262/2272最多可
30、有12位(A0A11)三态地址端管脚(悬空,接高电平,接低电平),任意组合可提供531441地址码,PT2262最多可有6位(D0D5)数据端管脚,设置的地址码和数据码从17脚串行输出。音频功放选用双声道音频功放TDA2822。4.2电路原理图无限呼叫器用接收器电路原理图可分为4部分:X5045接口电路,如图11所示;无线收发接口电路,如图12所示;按键及音频功放接口电路和单片机系统电路,如附表所示。其各个引脚的功能如表2所示。图12 X5045接口表2 X5045引脚功能表引脚名称功能描述1芯片选择输入:当CS是高电平时,芯片未选中,并将SO置为高组态。器件处于标准的功耗模式,除非一个向非易
31、失单元写的周期开始。在CS是高电平时,将CS拉低将使器件处于选择状态,器件将工作于工作功耗状态。在上电后任何操作之前,CS必须要有一个高变低的过程。看门狗输入:在看门狗定时器超时并产生复位之前,一个加在WDI引脚上的有高变低的电平变化将复位看门狗定时器。2SO串行输入:SO是一个推/拉串行数据输出引脚,在读数据时,数据在SCK脉冲的下降沿由这个引脚送出。3WP写保护:当WP引脚是低电平时,向X5045中的写的操作被禁止,但是其他的功能正常。当引脚是高电平时,所有操作正常,包括写操作。如果是在CS是低电平的时候,WP变为低电平,则会中断向X5045中的写操作,但是,如果此时内部的非易失性写周期已
32、经初始化了,WP变为低电平不起作用。4Vss地5SI串行输入:SI是串行数据输入端,指令码、地址、数据都可以通过这个引脚进行输入。在SCK的上升沿进行数据的输入,并且高位(MSB)在前。6SCK串行时钟:串行时钟的上升沿通过SI引脚进行数据的输入,下降沿通过SO的引脚进行数据的输出。7RESET复位输出:RESET是一个开漏型输出引脚。只要Vcc下降到最小允许Vcc值,这个引脚就会输出高电平,一直到Vcc上升超过最小允许值之后200ms。同时它也受看门狗定时器控制,只要看门狗处于激活状态,并且WDI引脚上电平保持为高或者为低超过了定时的时间,就会产生复位信号。CS引脚上的一个下降沿将会复位看门
33、狗定时器。由于这是一个开漏型的输出引脚,所以在使用时必须接上拉电阻。8Vcc正电源。如图15所示,利用89C51的并行I/O口模拟串口。89C51的P1.2、P1.3分别与SI、SO相连。用于数据写入或读出;89C51的P1.1与SCK相连,可编程模拟时钟信号;89C51的P1.0与CS相连,用于片选。图13 无线接收集成2272的模块如图12所示,无线接收部分采用集成2272的模块,负责接收发送数据。9912的输出端经硬件电路反相,连接到INT0引脚,上调沿触发。图14 发射模块原理图图15 接受和显示模块原理图按键及音频功效接口模块见附表。音频功法的输出由TXD引脚控制,音量大小由VOL1
34、、VOL2控制。由于单片机与X5045模数转换器件进行数据交换是通过SPI总线,所以不必使用其他接口芯片,简化了电路设计,其工作原理图见附表。AT89C51的P1.0、P1.1、P1.2、P1.3用来模拟SPI总线,和X5045进行数据交换。P0、P2口用于控制数码管的段选线。P1.6、P1.7接两个按键,用于功能设置和参数查询等。P3.2(INT0)、P3.3(INT1)分别接到接收模块9912的输出端。P3.3(TXD)主要用于控制音频运放输出。SED1335是液晶显示模块。如下图16所示:图16 AT89C51控制图5 软件流程5.1 发射部分设计无线呼叫器用接收器的主要功能是接收用户的
35、呼叫并应答。其发射模块流程图17如下。其主要流程为上电位进入初始化环节,主要初始化模拟串口、定时器、外部中断、判断是否发射数据、等待延迟。 图17 发射部分流程图发射部分主要程序:ORG 0000HLJMP STARTORG 0003HLJMP MINT0ORG 000BHLJMP TIME0ORG 0013HLJMP MINT1ORG 001BH LJMP TIME1 ORG 0100H START1: NOPNOPJB P3.0,ST1 ;按键是否按下MOV P3,#10111011BSETB P3.2 ;让发射头开始工作LCALL DELAY100MSCLR P3.2 ;发射头结束工作L
36、CALL DELAY10MSMOV P3,#00001011BSETB P3.2LCALL DELAY100MSCLR P3.2LCALL DELAY10MSMOV P3,#00001011BSETB P3.2LCALL DELAY100MSCLR P3.2LCALL DELAY10MSMOV P3,#00001011BSETB P3.2LCALL DELAY100MSCLR P3.2LCALL DELAY10MSMOV P3,#00010011BSETB P3.2LCALL DELAY100MSCLR P3.2LCALL DELAY10MSMOV P3,#00000011BSETB P3.2
37、LCALL DELAY100MSCLR P3.2LCALL DELAY10MSLJMP STST1: NOP ;等待按键按下ST: LJMP START5.2 接收部分设计无线呼叫器用接收器的主要功能是接收用户的呼叫并应答。其接收部分如下图18所示。其流程为上电位进入初始化环节、等待服务中断子程序、依次处理各组数据、端口分析数据、等待延迟。图18 接收部分流程图接收部分中断子程序: BUF1 EQU 20HBUF2 EQU 21HBUF3 EQU 22HBUF4 EQU 23HORG OOOOHLJMP STARTORG 0003HLJMP MINT0ORG 000BHLJMP TIME0OR
38、G 0013HLJMP MINT1ORG 001BHLJMP TIME1ORG 0100H MINT0: NOP MOV A,P2 ;判断第一组数 SWAP AANL A,#00001111BCJNE A,#00001111B,ST1LCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2 ;第二组ANL A,#11110000BMOV BUF1,ALCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2SWAP AANL A,#00001111BORL A,BUF1MOV BUF2,ALCAL
39、L DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2ANL A,#11110000BORL A,BUF1MOV BUF4,ALCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,BUF2CJNE A,BUF4,STSETB P3.5LJMP STST1:NOP CJNE A,#00000000B,STLCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2ANL A,#11110000BMOV BUF1,ALCALL DELAY100MSLCALL D
40、ELAY10MSLCALL DELAY1MSMOV A,P2SWAP AANL A,#00001111BORL A,#00001111BORL A,BUF1MOV BUF2,ALCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2ANL A,#11110000BMOV BUF3,ALCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSMOV A,P2SWAP AANL A,#00001111BORL A,BUF4,ALCALL DELAY100MSLCALL DELAY10MSLCALL DELAY1MSM
41、OV A,P2ANL A,#11110000BCJNE A,#11110000B,STMOV A,BUF2CJNE A,BUF4,STCLR P3.5延时子程序:(发射接收程序中都有) DELAY1:MOV R1,#0c0H DEL11:NOPNOPDJNZ R1,DEL11RETDELAY1MS:MOV R4,#2 ;延时1MS D1:MOV R5,#248DJNZ R5,$DJNZ R4,D1RETDELAY10MS:MOV R4,#20 ;延时10MS D2:MOV R5,#248DJNZ R5,$DJNZ R4,D2RETDELAY100MS:MOV R4,#200 ;延时100MSD
42、3:MOV R5,#248DJNZ R5,$DJNZ R4,D3RETEND6 结论SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,简化了电路设计,提高了设计的可靠性,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。 在点对点的通信中,SPI接口不需要进行寻址操作,且为全双工通信,显得简单高效。在多个从设备的系统中,每个从设备需要独立的使能信号,硬件上比I2C系统要稍微复杂一些。无线呼叫器是一种新型的无线电子产品,相对于有线呼叫器需要布线,费用高,施工繁琐而无法得到广泛应用,因而无线呼叫器广泛用于:餐饮、娱乐、休闲、工厂、超市、办公和家庭等场所。基于以上各种优势,本次“基于SPI总线的无限呼叫接收器设计”的意义重大,应有广泛,具