51单片机模拟 SPI 总线的方法
MC51 AVR MCU 的I2C、SPI、232、485、IO的使用

MC51\AVR MCU 的I2C\SPI\232\485\IO的使用首先:AVR的IO口操作玉日信有三个寄存器:DDR xn PORTxn PINxnDD Rxn(方向选择):1为输出0为输入PORTxn:在引脚为输入的前提下,为1上啦电阻使能0不使能在引脚为输出的前提下,为1输出高电平0输出低电平PINxn:通过读取PINxn来得到该引脚的状态,他不会所存状态,他读到的只是当前管脚的电平状态。
注意:xn是 A B CD..口管脚设置PA口的第一个脚为输出:DDRA|=0x01;51单片机的IO口操作比如现让P1.7为输出,其余为输入,P2=0x0111 1111B,也就是0x7F。
=============================================================一、模拟SPI的使用时钟是100KHZ这样延时3微妙一周期6微妙这样最大传输速度为输入时钟频率的1/8CS输出低电平→MOSI与1向与→CLK输出一个脉冲→MOSI的数据右移动一位与1相与→ CLK输出一个脉冲……输出够8位(一个字节了)再下一个字节或者停止→停止之后CS拉高CS输出低电平→ CLK输出一个脉冲→MISO管脚取数据→ CLK输出一个脉冲→MISO管脚取数据→ CLK输出一个脉冲……输入够8位(一个字节了)再下一个字节或者停止→停止之后CS拉高3、一个主机和多个从器件的通信系统。
(2)3个既可以当做主机也可以当做从机的单片机组成的系统。
特点:SPI是一位一位发送的,并允许暂停,发多少位都行,不用寻址操作AVR有SPI功能接口的单片机SPI操作时钟是最大1/4 FOSC 最小1/128 FOSC把数据写到数据寄存器→CS拉低(启动一次通信)→再把数据写到数据寄存器→CS拉低(启动一次通信)→CS拉高结束通信注意:是时钟的上升沿还是下降沿有效时可以设置的---CPHA为1上升沿采样数据,为0下降沿采样数据,传输结束了SPIF会置位高位还是地位先发送是可以设置的----DORD为1地位先发送为0高位先发送数据寄存器SPFR是可读可写的—写数据进去就启动数据传输,读数据将读取数据的接收缓存区在主模式下,时钟信号的1次作用对应一位数据的发送(MOSI)和另一位数据的接收(MISO)。
51单片机模拟spi串行接口程序

51 单片机模拟spi 串行接口程序51 单片机模拟spi 串行接口程序,在keilc51 下编写sbit CS=P3A5;sbit CLK= P"5;sbit DataI=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPI_TransferByte(unsigned char val){unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // write if(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit DataI=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPI_TransferByte(unsigned char val){unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // write if(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5; sbit DataI=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPI_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // writeif(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit DataI=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPI_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // writeif(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit Datal=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPl_TransferByte(unsigned char val) unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // writeif(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit Datal=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPl_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;DataI=0; // write if(val&0x80) DataI=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit Datal=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPl_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;Datal=0; // writeif(val&0x80) Datal=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;}sbit CLK= P1A5;sbit Datal=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPl_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;Datal=0; // writeif(val&0x80) Datal=1;val<<=1;CLK=1;if(DataO)val|=1; // readCLK=0;return val;}sbit CLK= P1A5;sbit Datal=P1A7;sbit DataO=P1A6;#define SD_Disable() CS=1 // 片选关#define SD_Enable() CS=0 // 片选开unsigned char SPl_TransferByte(unsigned char val) { unsigned char BitCounter;for(BitCounter=8; BiCounter!=0; BitCounter--){ CLK=0;Datal=0; // writeif(val&0x80) Datal=1;val<<=1;CLK=1;if(DataO)val|=1; // read}CLK=0;return val;。
基于SPI总线的51单片机多机互连编程技术

基于SPI总线的51单片机多机互连编程技术李强;潘启军【期刊名称】《单片机与嵌入式系统应用》【年(卷),期】2012(12)7【摘要】Serial expansion and serial communication become the mainstream way of current MCU system expansion. The microcontroller market has not only traditional UART serial interfaces,but also SPI,I2C bus serial interfaces. SPI interface is a high-speed serial com- munication interface , and it is particularly for high-speed communication between MCU. But the work mode is very different from the traditional UART serial communication. This paper introduces all kinds of serial communication work mode's configuration and driver programming, and shows the integral test.%串行扩展和串行通信方式已经成为当前单片机系统扩展的主流方式。
目前单片机市场上不但有传统的UART串行接口,而且还有SPI、I2C总线等串行接口。
SPI接口是一种高速串行通信接口,特别适合于单片机之间的高速通信,但其工作方式较之传统的UART串行通信方式有很大的不同。
本文给出SPI接口基础上的各种串行通信工作方式配置及驱动编程,并进行完整的测试。
【总页数】3页(P24-26)【作者】李强;潘启军【作者单位】韶关学院计算机科学学院,韶关512000;韶关光栅测量控制技术研究所【正文语种】中文【中图分类】TP314【相关文献】1.基于SPI的CAN总线控制器与MCS-51单片机的接口设计 [J], 谢桂波2.51单片机综合学习系统——SPI总线的基本原理与应用实例 [J], 庄建清;徐玮3.SPI总线在51单片机系统中的实现 [J], 万江4.Intel 8098/8051单片机的多机互连方案的研究 [J], 刘鲁源;么莉;王欣东5.基于AT89C51单片机的CAN总线的多机通信 [J], 刘永富因版权原因,仅展示原文概要,查看原文内容请购买。
单片机与外部设备的SPI接口设计与实现

单片机与外部设备的SPI接口设计与实现1.引言单片机与外部设备的通信是嵌入式系统设计中的重要环节。
SPI(Serial Peripheral Interface)是一种常用的串行通信协议,用于实现单片机与外设之间的数据传输。
本文将探讨单片机与外部设备之间的SPI接口设计与实现。
2.SPI接口简介SPI接口是一种同步的数据总线协议,通常由一个主设备和一个或多个从设备组成。
SPI接口包含四个信号线:时钟线(SCK)、主输出从输入线(MISO)、主输入从输出线(MOSI)和片选线(SS)。
通过时钟线的同步操作,主设备可以与从设备进行双向数据传输。
3.SPI接口的工作原理SPI接口的工作原理如下:首先,主设备通过片选线选择从设备,并将数据发送到MOSI线上;随后,主设备通过时钟线提供时钟信号,从而同步数据的传输;同时,从设备将数据通过MISO线发送给主设备;最后,主设备将片选线置高,表示数据传输结束。
4.SPI接口的硬件设计在实现SPI接口的硬件设计时,需要考虑以下几个方面:4.1 片选线的设计片选线的数量由从设备的数量决定。
如果只有一个从设备,可以直接连接到片选线上。
如果有多个从设备,需要使用多个片选线,并通过逻辑门进行选择。
4.2 时钟线的设计时钟线的频率由主设备的时钟频率决定。
需要根据从设备的要求,选择适当的时钟频率。
时钟频率过高可能导致数据传输出错,过低可能导致传输速度较慢。
4.3 数据线的设计数据线包括主输出从输入线(MISO)和主输入从输出线(MOSI)。
需要根据从设备的要求,确定数据线的数量和宽度。
通常,每个从设备都需要一个MISO线和一个MOSI线。
5.SPI接口的软件实现在单片机中实现SPI接口的软件需要编写相应的驱动程序。
以下是SPI接口软件实现的基本步骤:5.1 硬件初始化首先,需要初始化单片机的IO口,并设置片选线等相应的引脚。
5.2 时钟设置根据从设备的时钟要求,设置单片机相应的时钟频率。
SPI总线在51系列单片机系统中的实现(一)

SPI总线在51系列单片机系统中的实现(一)摘要:MCS51系列、MCS96系列等单片机由于都不带SPI串行总线接口而限制了其在SPI总线接口器件的使用。
文中介绍了SPI串行总线的特征和时序,并以串行E2PROM为例,给出了在51系列单片机上利用I/O口线实现SPI串行总线接口的方法和软件设计程序。
关键词:单片机SPI串行总线总线接口1引言SPI(SerialPeripheralInterface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。
外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。
SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOST和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。
由于SPI系统总线一共只需3~4位数据线和控制即可实现与具有SPI总线接口功能的各种I/O器件进行接口,而扩展并行总线则需要8根数据线、8~16位地址线、2~3位控制线,因此,采用SPI总线接口可以简化电路设计,节省很多常规电路中的接口器件和I/O口线,提高设计的可靠性。
由此可见,在MCS51系列等不具有SPI接口的单片机组成的智能仪器和工业测控系统中,当传输速度要求不是太高时,使用SPI总线可以增加应用系统接口器件的种类,提高应用系统的性能。
2SPI总线的组成利用SPI总线可在软件的控制下构成各种系统。
如1个主MCU和几个从MCU、几个从MCU相互连接构成多主机系统(分布式系统)、1个主MCU和1个或几个从I/O设备所构成的各种系统等。
在大多数应用场合,可使用1个MCU作为控机来控制数据,并向1个或几个从外围器件传送该数据。
(完整)spi总线协议详细说明

SPI总线原理与应用篇《电子制作》2008年9月站长原创,如需引用请注明出处大家好,通过以前的学习,我们已经对51单片机综合学习系统的使用方法及学习方式有所了解与熟悉,学会了使用IIC总线的基本知识,体会到了综合学习系统的易用性与易学性,这一期我们将一起学习SPI总线的基本原理与应用实例。
先看一下我们将要使用的51单片机综合学习系统能完成哪些实验与产品开发工作:分别有流水灯,数码管显示,液晶显示,按键开关,蜂鸣器奏乐,继电器控制,IIC总线,SPI 总线,PS/2实验,AD模数转换,光耦实验,串口通信,红外线遥控,无线遥控,温度传感,步进电机控制等等。
主体系统如图1所示,其配套书本教程《单片机快速入门》如图2所示。
图1 51单片机综合学习系统主机部分图片图2 51单片机综合学习系统配套书本教程——《单片机快速入门》上图是我们将要使用的51单片机综合学习系统硬件平台,如图1所示,本期实验我们用到了综合系统主机、板载的AT93C46芯片,综合系统其它功能模块原理与使用详见前几期《电子制作》杂志及后期连载教程介绍。
SPI总线简介SPI总线基本概念SPI ( Serial Peripheral Interface ———串行外设接口) 总线是Motorola公司推出的一种同步串行接口技术。
SPI总线系统是一种同步串行外设接口,允许MCU 与各种外围设备以串行方式进行通信、数据交换。
外围设备包括FLASHRAM、A/ D 转换器、网络控制器、MCU 等。
SPI,是一种高速的,全双工,同步的通信总线,并且在芯片的管脚上只占用四根线,节约了芯片的管脚,同时为PCB的布局上节省空间,提供方便,正是出于这种简单易用的特性,现在越来越多的芯片集成了这种通信协议。
其工作模式有两种:主模式和从模式。
SPI是一种允许一个主设备启动一个从设备的同步通讯的协议,从而完成数据的交换。
也就是SPI是一种规定好的通讯方式。
这种通信方式的优点是占用端口较少,一般4根就够基本通讯了(不算电源线)。
51单片机模拟 SPI 总线的方法

51单片机模拟SPI 总线的方法1 引言SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MC U与各种外围设备以串行方式进行通信以交换信息。
外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。
SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI 和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。
由于SPI系统总线一共只需3~4位数据线和控制即可实现与具有SP I总线接口功能的各种I/O器件进行接口,而扩展并行总线则需要8根数据线、8~16位地址线、2~3位控制线,因此,采用SPI总线接口可以简化电路设计,节省很多常规电路中的接口器件和I/O口线,提高设计的可靠性。
由此可见,在MCS51系列等不具有SPI接口的单片机组成的智能仪器和工业测控系统中,当传输速度要求不是太高时,使用SPI总线可以增加应用系统接口器件的种类,提高应用系统的性能。
2 SPI总线的组成利用SPI总线可在软件的控制下构成各种系统。
如1个主MCU和几个从MCU、几个从MCU相互连接构成多主机系统(分布式系统)、1个主MCU和1个或几个从I/O设备所构成的各种系统等。
在大多数应用场合,可使用1个MCU作为控机来控制数据,并向1个或几个从外围器件传送该数据。
从器件只有在主机发命令时才能接收或发送数据。
其数据的传输格式是高位(MSB)在前,低位(LSB)在后。
SPI 总线接口系统的典型结构如图1所示。
当一个主控机通过SPI与几种不同的串行I/O芯片相连时,必须使用每片的允许控制端,这可通过M CU的I/O端口输出线来实现。
但应特别注意这些串行I/O芯片的输入输出特性:首先是输入芯片的串行数据输出是否有三态控制端。
51单片机模拟串口的三种方法

51单片机模拟串口的三种方法单片机模拟串口是指通过软件实现的一种串口通信方式,主要应用于一些资源有限的场合,如单片机中没有硬件UART模块的情况下。
下面将介绍三种常用的单片机模拟串口的方法。
1.轮询法轮询法是最简单的一种模拟串口方法,其原理是通过轮询方式不断查询接收和发送的数据。
在接收数据时,单片机通过忙等待的方式查询接收端是否有数据到达,并且处理数据。
在发送数据时,单片机通过检查发送端是否空闲,然后发送数据。
这种方法的优点是实现简单,占用资源少。
缺点是轮询过程可能会浪费一定的时间,同时由于忙等待可能会占用CPU资源,影响其他任务的执行。
2.中断法中断法是一种基于中断机制实现的模拟串口方法,其原理是通过外部中断或定时器中断触发,单片机响应中断并进行串口数据的接收和发送。
在接收数据时,单片机通过外部中断或定时器中断来检测串口接收中断,并处理接收到的数据;在发送数据时,单片机通过定时器中断来定时发送数据。
这种方法的优点是能够及时响应串口的数据接收和发送,不会浪费过多的时间。
缺点是中断处理可能会占用一定的CPU资源,同时中断嵌套可能会引起一些问题。
3.环形缓冲法环形缓冲法是一种基于环形缓冲区的模拟串口方法,其原理是通过环形缓冲区来缓存接收和发送的数据。
在接收数据时,单片机将串口接收到的数据放入环形缓冲区,并使用指针指示当前读取位置和写入位置,然后通过轮询或中断方式从缓冲区中读取数据并进行处理;在发送数据时,单片机将要发送的数据放入环形缓冲区,并通过轮询或中断方式从缓冲区中读取数据并发送。
这种方法的优点是能够有效地处理串口数据的接收和发送,不会浪费过多的时间,并且能够缓存一定量的数据。
缺点是需要额外的缓冲区,占用一定的内存空间。
综上所述,通过轮询法、中断法和环形缓冲法三种方法,可以实现单片机的串口模拟功能。
根据实际需求,选择合适的方法来实现串口通信。
- 1、下载文档前请自行甄别文档内容的完整性,平台不提供额外的编辑、内容补充、找答案等附加服务。
- 2、"仅部分预览"的文档,不可在线预览部分如存在完整性等问题,可反馈申请退款(可完整预览的文档不适用该条件!)。
- 3、如文档侵犯您的权益,请联系客服反馈,我们会尽快为您处理(人工客服工作时间:9:00-18:30)。
51单片机模拟 SPI 总线的方法1 引言SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。
外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。
SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。
由于SPI系统总线一共只需3~4位数据线和控制即可实现与具有SPI总线接口功能的各种I/O器件进行接口,而扩展并行总线则需要8根数据线、8~16位地址线、2~3位控制线,因此,采用SPI总线接口可以简化电路设计,节省很多常规电路中的接口器件和I/O口线,提高设计的可靠性。
由此可见,在MCS51系列等不具有SPI接口的单片机组成的智能仪器和工业测控系统中,当传输速度要求不是太高时,使用SPI总线可以增加应用系统接口器件的种类,提高应用系统的性能。
2 SPI总线的组成利用SPI总线可在软件的控制下构成各种系统。
如1个主MCU和几个从MCU、几个从MCU 相互连接构成多主机系统(分布式系统)、1个主MCU和1个或几个从I/O设备所构成的各种系统等。
在大多数应用场合,可使用1个MCU作为控机来控制数据,并向1个或几个从外围器件传送该数据。
从器件只有在主机发命令时才能接收或发送数据。
其数据的传输格式是高位(MSB)在前,低位(LSB)在后。
SPI总线接口系统的典型结构。
当一个主控机通过SPI与几种不同的串行I/O芯片相连时,必须使用每片的允许控制端,这可通过MCU的I/O端口输出线来实现。
但应特别注意这些串行I/O芯片的输入输出特性:首先是输入芯片的串行数据输出是否有三态控制端。
平时未选中芯片时,输出端应处于高阻态。
若没有三态控制端,则应外加三态门。
否则MCU的MISO端只能连接1个输入芯片。
其次是输出芯片的串行数据输入是否有允许控制端。
因此只有在此芯片允许时,SCK脉冲才把串行数据移入该芯片;在禁止时,SCK对芯片无影响。
若没有允许控制端,则应在外围用门电路对SCK进行控制,然后再加到芯片的时钟输入端;当然,也可以只在SPI总线上连接1个芯片,而不再连接其它输入或输出芯片。
3 在MCS-51系列单片机中的实现方法对于不带SPI串行总线接口的MCS-51系列单片机来说,可以使用软件来模拟SPI的操作,包括串行时钟、数据输入和数据输出。
对于不同的串行接口外围芯片,它们的时钟时序是不同的。
对于在SCK的上升沿输入(接收)数据和在下降沿输出(发送)数据的器件,一般应将其串行时钟输出口P1.1的初始状态设置为1,而在允许接收后再置P1.1为0。
这样,MCU 在输出1位SCK时钟的同时,将使接口芯片串行左移,从而输出1位数据至MCS-51单片机的P1.3口(模拟MCU的MISO线),此后再置P1.1为1,使MCS-51系列单片机从P1.0(模拟MCU 的MOSI线)输出1位数据(先为高位)至串行接口芯片。
至此,模拟1位数据输入输出便宣告完成。
此后再置P1.1为0,模拟下1位数据的输入输出……,依此循环8次,即可完成1次通过SPI总线传输8位数据的操作。
对于在SCK的下降沿输入数据和上升沿输出数据的器件,则应取串行时钟输出的初始状态为0,即在接口芯片允许时,先置P1.1为1,以便外围接口芯片输出1位数据(MCU接收1位数据),之后再置时钟为0,使外围接口芯片接收1位数据(MCU发送1位数据),从而完成1位数据的传送。
图2所示为MCS-51系列单片机与存储器X25F008(E2PROM)的硬件连接图,图2中,P1.0模拟MCU的数据输出端(MOSI),P1.1模拟SPI的SCK输出端,P1.2模拟SPI的从机选择端,P1.3模拟SPI的数据输入端(MISO)。
下面介绍用MCS-51单片机的汇编语言模拟SPI串行输入、串行输出和串行输入/输出的3个子程序,实际上,这些子程序也适用于在串行时钟的上升沿输入和下降沿输出的其它各种串行外围接口芯片(如A/D转换芯片、网络控制器芯片、LED显示驱动芯片等)。
对于下降沿输入、上升沿输出的各种串行外围接口芯片,只要改变P1.1的输出电平顺序,即先置P1.1为低电平,之后再次置P1.1为高电平,再置P1.1为低电平……,则这些子程序也同样用。
3.1 MCU串行输入子程序SPIIN从X25F008的SPISO线上接收8位数据并放入寄存器R0中的应用子程序如下:SPIIN:SETB P1.1 ;使P1.1(时钟)输出为1CLR P1.2 ;选择从机MOV R1,#08H ;置循环次数SPIIN1: CLR P1.1 ;使P1.1(时钟)输出为0NOP ;延时NOPMOV C,P1.3 ;从机输出SPISO送进位CRLC A ;左移至累加器ACCSETB P1.1 ;使P1.0(时钟)输出为1DJNZ R1,SPIIN1 ;判断是否循环8次(8位数据)MOV R0,A ;8位数据送R0RET3.2 MCU串行输出子程序SPIOUT将MCS-51单片机中R0寄存器的内容传送到X25F008的SPISI线上的程序如下:SPIOUT:SETB P1.1 ;使P1.1(时钟)输出为1CLR P1.2 ;选择从机MOV R1,#08H ;置循环次数MOV A,R0 ;8位数据送累加器ACCSPIOUT1:CLR P1.1 ;使P1.1(时钟)输出为0NOP ;延时NOPRLC A ;左移至累加器ACC最高位至CMOV P1.0,C ;进位C送从机输入SPISI线上SETB P1.1 ;使P1.1(时钟)输出为1DJNZ R1,SPIOUT1 ;判是否循环8次(8位数据)RET1 引言SPI(Serial Peripheral Interface--串行外设接口)总线系统是一种同步串行外设接口,它可以使MCU与各种外围设备以串行方式进行通信以交换信息。
外围设置FLASHRAM、网络控制器、LCD显示驱动器、A/D转换器和MCU等。
SPI总线系统可直接与各个厂家生产的多种标准外围器件直接接口,该接口一般使用4条线:串行时钟线(SCK)、主机输入/从机输出数据线MISO、主机输出/从机输入数据线MOSI和低电平有效的从机选择线SS(有的SPI接口芯片带有中断信号线INT或INT、有的SPI接口芯片没有主机输出/从机输入数据线MOSI)。
由于SPI系统总线一共只需3~4位数据线和控制即可实现与具有SPI总线接口功能的各种I/O器件进行接口,而扩展并行总线则需要8根数据线、8~16位地址线、2~3位控制线,因此,采用SPI总线接口可以简化电路设计,节省很多常规电路中的接口器件和I/O口线,提高设计的可靠性。
由此可见,在MCS51系列等不具有SPI接口的单片机组成的智能仪器和工业测控系统中,当传输速度要求不是太高时,使用SPI总线可以增加应用系统接口器件的种类,提高应用系统的性能。
2 SPI总线的组成利用SPI总线可在软件的控制下构成各种系统。
如1个主MCU和几个从MCU、几个从MCU 相互连接构成多主机系统(分布式系统)、1个主MCU和1个或几个从I/O设备所构成的各种系统等。
在大多数应用场合,可使用1个MCU作为控机来控制数据,并向1个或几个从外围器件传送该数据。
从器件只有在主机发命令时才能接收或发送数据。
其数据的传输格式是高位(MSB)在前,低位(LSB)在后。
SPI总线接口系统的典型结构。
当一个主控机通过SPI与几种不同的串行I/O芯片相连时,必须使用每片的允许控制端,这可通过MCU的I/O端口输出线来实现。
但应特别注意这些串行I/O芯片的输入输出特性:首先是输入芯片的串行数据输出是否有三态控制端。
平时未选中芯片时,输出端应处于高阻态。
若没有三态控制端,则应外加三态门。
否则MCU的MISO端只能连接1个输入芯片。
其次是输出芯片的串行数据输入是否有允许控制端。
因此只有在此芯片允许时,SCK脉冲才把串行数据移入该芯片;在禁止时,SCK对芯片无影响。
若没有允许控制端,则应在外围用门电路对SCK进行控制,然后再加到芯片的时钟输入端;当然,也可以只在SPI总线上连接1个芯片,而不再连接其它输入或输出芯片。
3 在MCS-51系列单片机中的实现方法对于不带SPI串行总线接口的MCS-51系列单片机来说,可以使用软件来模拟SPI的操作,包括串行时钟、数据输入和数据输出。
对于不同的串行接口外围芯片,它们的时钟时序是不同的。
对于在SCK的上升沿输入(接收)数据和在下降沿输出(发送)数据的器件,一般应将其串行时钟输出口P1.1的初始状态设置为1,而在允许接收后再置P1.1为0。
这样,MCU 在输出1位SCK时钟的同时,将使接口芯片串行左移,从而输出1位数据至MCS-51单片机的P1.3口(模拟MCU的MISO线),此后再置P1.1为1,使MCS-51系列单片机从P1.0(模拟MCU 的MOSI线)输出1位数据(先为高位)至串行接口芯片。
至此,模拟1位数据输入输出便宣告完成。
此后再置P1.1为0,模拟下1位数据的输入输出……,依此循环8次,即可完成1次通过SPI总线传输8位数据的操作。
对于在SCK的下降沿输入数据和上升沿输出数据的器件,则应取串行时钟输出的初始状态为0,即在接口芯片允许时,先置P1.1为1,以便外围接口芯片输出1位数据(MCU接收1位数据),之后再置时钟为0,使外围接口芯片接收1位数据(MCU发送1位数据),从而完成1位数据的传送。
图2所示为MCS-51系列单片机与存储器X25F008(E2PROM)的硬件连接图,图2中,P1.0模拟MCU的数据输出端(MOSI),P1.1模拟SPI的SCK输出端,P1.2模拟SPI的从机选择端,P1.3模拟SPI的数据输入端(MISO)。
下面介绍用MCS-51单片机的汇编语言模拟SPI串行输入、串行输出和串行输入/输出的3个子程序,实际上,这些子程序也适用于在串行时钟的上升沿输入和下降沿输出的其它各种串行外围接口芯片(如A/D转换芯片、网络控制器芯片、LED显示驱动芯片等)。
对于下降沿输入、上升沿输出的各种串行外围接口芯片,只要改变P1.1的输出电平顺序,即先置P1.1为低电平,之后再次置P1.1为高电平,再置P1.1为低电平……,则这些子程序也同样用。