串口程序流程图.doc
- 格式:doc
- 大小:14.04 KB
- 文档页数:3
串口通信流程图单片机串口通信流程图
串口通信流程图窗口通信结构
串口通信是指外设和计算机间,通过数据信号线
、地线、控制线等,按位进行传输数据的一种通讯方式。
这种通信方式使用的数据线少,在远距离通信中可以节约通信成本,但其传输速度比并行传输低。
串口是计算机上一种非常通用的设备通信协议。
大多数计算机(不包括笔记本电脑)包含两个基于RS-232的串口。
串口同时也是仪器仪表设备通用的通信协议;很多GPIB兼容的设备也带有RS-232口。
同时,串口通信协议也可以用于获取远程采集设备的数据。
RS-232(ANSI/EIA-232标准)是IBM-PC及其兼容机上的串行连接标准。
可用于许多用途,比如连接鼠标、打印机或者Modem,同时也可以接工业仪器仪表。
用于驱动和连线的改进,实际应用中RS-232的传输长度或者速度常常超过标准的值。
RS-232只限于PC 串口和设备间点对点的通信。
RS-232串口通信最远距离是50英尺。
串口通信流程图
第 1 页共 1 页。
摘要本文详细介绍了基于RS-485总线的单片机与多台单片机间的串行通信原理、实现方法和相应的通信硬件、软件设计。
该设计是由单片机与单片机组成的主从控制系统,其中单片机做为上位机对下位单片机是实现控制和监视功能。
它包括通信和控制两个功能模块。
单片机作为下位机在整个系统中属于从属地位,主要用来接收上位机的命令。
由于此通信的单片接口是RS232的9针接口,且下位机数目有限(32台)。
所以本设计采用了RS485总线以及RS232转RS485的协议芯片以满足长距离多机通信,本文讨论了总线接口转换、主从式通信协议设计方法,给出了采用中断式处理的通信过程流程图,并叙述了设计过程中必备的绘图软件Protel DXP的应用,以及编辑源代码软件keil uVision2的应用,实现了单片机对多个单片机组成采集终端的通信与管理。
关键词:单片机单片机RS-485 通信AbstractThe communication 、realized method and corresponding design of hardware and software between 单片and multiple MCUs based on RS-485 is described in detai in the article. This design instroduces a pincipal and subordinate control system which is composed of 单片and single chip. Divided from its function, it includes two parts: communication and control, in which 单片is used as master, and MCUs is used as slave so as to receive the single order from the master.The bus interface conversion and the design of master-slave communication protocol is introduced and The program flowchart of communication with interrupt process is also given. In the process of design, the use of unnecessary painter software and code editor software is depicted so that realize the communication and administration between 单片and multiple MCUs which composed collection terminal.Keywords: 单片MCUs RS-485 communication目录第一章绪论 (1)第二章课题实施方案 (2)2.1 系统硬件设计 (2)2.2 系统软件设计 (3)第三章硬件电路设计 (9)3.1 C51单片机结构 (9)一CPU结构 (10)二ROM存储器 (11)三I/O端口 (11)四定时器/计数器 (12)五中断系统 (13)3.1.2 51单片机引脚功能及其连接 (13)3.1.3 51 中断系统 (15)3.1.4 C-51的串行通信 (15)3.2.1串行接口RS232结构与引脚功能 (21)3.3 Protel DXP 2004原理图设计 (23)3.3.1 Protel 2004的基本操作 (23)3.3.2绘制原理图 (25)3.3.3制作芯片原理图库 (27)第四章软件电路设计 (30)4.1 系统的通信协议 (31)4.2 C51编程实现单片机与单片机之间的串行通信 (31)4.3 Windows集成开发环境uVision2 (35)4.3.1启动uVision2 (35)4.3.2创建程序 (36)总结 (41)致谢 (42)参考文献 (43)第一章绪论单片机由于其具有控制功能强、设计灵活和性能价格比高的特点。
单片机应用课程设计任务书单片机应用课程设计任务书学院名称:计算机与信息工程学院班级名称:学生姓名:学号:题目:双机间的串口双向通信设计指导教师:起止日期:目录一、绪论 (5)1.1设计背景 (5)二、相关知识 (5)2.1 双机通信简介 (5)2.2 单片机A T89C51介绍 (5)2.3串口通信 (6)三、总体设计 (7)3.1 设计要求 (7)四、硬件设计 (8)4.1.整体电路 (8)4.2复位电路 (8)4.3.控制电路 (9)五、软件设计 (9)5.1甲机软件设计 (10)5.2乙机软件设计 (11)六、测试及运行 (13)心得与感受 (15)参考文献 (16)指导教师评语 (17)附录:源程序 (18)一、绪论1.1设计背景随着电子技术的飞速发展,单片机也步如一个新的时代,越来越多的功能各异的单片机为我们的设计提供了许多新的方法与思路。
对于一些场合,比如:复杂的后台运算及通信与高实时性前台控制系统、软件资源消耗大的系统、功能强大的低消耗系统、加密系统等等。
如果合理使用多种不同类型的单片机组合设计,可以得到极高灵活性与性能价格比,因此,多种异型单片机系统设计渐渐成为一种新的思路,单片机技术作为计算机技术的一个重要分支,由于单片机体积小,系统运行可靠, 数据采集方便灵活,成本低廉等优点,在通信中发挥着越来越重要的作用。
但在一些相对复杂的单片机应用系统中,仅仅一个单片机资源是不够的,往往需要两个或多个单片机系统协同工作。
这就对单片机通信提出了更高要求。
单片机之间的通信可以分为两大类:并行通信和串行通信。
串行通信传输线少,长距离传输时成本低,且可以利用数据采集方便灵活,成本低廉等优点,在通信中发挥着越来越重要的作用。
所以本系统采用串行通信来实现单片机之间可靠的,有效的数据交换。
二、相关知识2.1 双机通信简介两台机器的通信方式可分为单工通信、半双工通信、双工通信,他们的通信原理及通信方式为:1.单工通信:是指消息只能单方向传输的工作方式。
程序流程图及其说明依据本系统的结构原理,可以绘制出程序流程图,如下面图5. 5. 3(1)和图 5. 5. 3(2)所示。
NY回示子程序中使用DPTR地址寄存器作为地址指针,开头时指向数据表首地址,当一帧(即一屏四个字符)字符显示完成后,进入下一帧(即下一屏四个字符)字符,从右到左的流淌显示,此时DPTR指向字符表的第三个字节处。
第一次调用列扫描子程序时,先向掌握列线的八个74HC595发送 63个1和1个0,同时第一次调用行数据发送子程序,使DPTR指向字符表的第一个字节,在循环体中DPTR加1,从而发送16行的数据到掌握行线的两个74HC595中,这样就完成了第一次列扫描子程序和第一第次行数据发送子程序的调用。
其次次调用列扫描子程序时,只需发送一个1,就能实现移位的操作,而此时行数据发送子程序将发送字符表中第三、四个字节的数据,以后DPTR增加到第128个字节处,行数据发送子程序将发第128个字节的数据,这个就完成一帧的显示(即一屏四个字的显示,由于一个汉字的点阵字模大小为32 byte)。
由LED的结构原理可知,在列扫描子程序中,1对应的列为暗,而O对应的列被点亮。
数据表按显示要求编码。
每两个字节为LED点阵板一列中16位相应的显示行数据。
由于数据为16位,因此必需分两次发送。
当数据发来时, 对应的为O的列线与行线相交点的发光三极管被点亮,为1被关暗。
字符表中每32个字节数据为一个字符的编码信息。
程序中为了能够存取片外数据存储器6264中0020H以上单元的数据, 只能实行MoVX @DPTR,A和MOVX A, @DPTR作为存取数据的指令,缘由是Ro与Rl的间接寻址方式只能寻址到OOlFH单元。
同时为了能够很好地对数据寻址,我们使用50H和51H两个单元来产生每一个帧数据的基值,09H单元作为行数据的指针,而DPTR被更多地用来作地址偏移量使用。
51H在每次循环后使DPTR加2,使得它所指向的数据表地址前移。
1.单片机串行通信的概述在通信领域内,有两种数据通信方式:并行通信和串行通信。
随着计算机网络化和微机分级分布式应用系统的发展,通信的功能越来越重要。
通信是指计算机与外界的信息传输,既包括计算机与计算机之间的传输,也包括计算机与外部设备,如终端、打印机和磁盘等设备之间的传输。
串行通信是指使用一条数据线,将数据一位一位地依次传输,每一位数据占据一个固定的时间长度。
其只需要少数几条线就可以在系统间交换信息,特别使用于计算机与计算机、计算机与外设之间的远距离通信。
使用串口通信时,发送和接收到的每一个字符实际上都是一次一位的传送的,每一位为1或者为0。
在串行通信中,把通信接口只能发送或接收的单向传送办法叫单工传送;而把数据在甲乙两机之间的双向传递,称之为双工传送。
在双工传送方式中又分为半双工传送和全双工传送。
半双工传送是两机之间不能同时进行发送和接收,任一时该,只能发或者只能收信息。
51系列单片机有一个可编程的全双工串行通信接口,它可作异步接收发送器用,也可做同步移位寄存器用,其帧格式可有8位、10位或11位,并能设置各种波特率,给使用带来很大的灵活性。
51系列单片机有两个物理上独立的接收、发送缓冲器SBUF,它们只占用同一地址99H,可同时发送、接送数据。
发送缓冲器只能写入,不能读出,接收缓冲器只能读出、不能写入。
串行发送接收的速率与波特率发生器产生的移位脉冲同频。
51系列单片机用定时器T1或直接用CPU时钟作为通信波特率发生器的输入,在串行接口的不同工作方式中,波特率发生器从两个输入信号中选择一个分频,产生移位脉冲来同步串口的接收和发送,移位脉冲的速率即是波特率。
接收器是双缓冲结构,在前一个字节被从接收缓冲器SBUF读出之前,第二字节即开始被接收。
但是,若在第二个字节接收完毕后,前一个字节还未被CPU 读取的话,第二个字就会覆盖第一个字节,造成第一个字节的丢失。
接收器是双缓冲结构,串行口的发送和接收都是以特殊功能寄存器SBUF的名义进行读或写的。
实验四 串行通信实验一、实验目的1.了解51单片机串行口的结构、串行通讯的原理。
2.掌握51单片机与PC 机之间通讯的方法。
3. 学习系统应用程序的设计和调试二、实验设备PC 机一台 、 实验教学板一块。
三、实验原理51单片机的串行接口是全双工的,它能做异步接收器/发送器(UART ),也能做同步移位寄存器使用。
在做UART 使用时,相关的寄存器有SBUF 、SCON 、和PCON 中的波特率倍增位SMOD 。
SBUF 是数据发送缓冲器和接收缓冲器,逻辑上用同一个地址,物理上是分开的,用读写操作来选择。
SCON 是串行口控制寄存器,用于设定串行口的工作方式;保存方式2和方式3的第9位数据;存放发送、接收的中断标志。
在串行通讯的方式1和方式3中,通信的波特率是可以设置的,满足下式:2/132SMOD=⨯波特率(定时器计数器的溢出率)PC 机的串行通讯口是借助通用异步接收发送器8250(或16C550等)实现的,可使用comdebug.exe 等提供了有关串行口的收、发操作窗口的软件实现通讯。
PC 机的串行通讯采用RS232电平,因此要求单片机的实验板也要配置RS232接口,解决逻辑电平的配接。
如果通讯距离较远,则要配接调制解调器。
四、实验内容1, 自发自收用一根短路线,将实验板中RS232插口的RXD 和TXD 两个插孔短路。
然后编程设定串行口为工作方式1,传送55H 和0AAH 两个数据。
实验要求:程序采用查询方式。
每传送、接收一个数据,做一次检查,看是否正确,若两次都正确,则在显示器上显示“GOOD”,若不正确,则不显示,并要重新传送。
2, 单片机与PC 机的通信先使用通讯电缆将单片机的RS232接口与PC 机的COM1口连接,PC 机起动并运行comdebug.exe 软件,窗口上设置波特率为1200,8位数据、一个停止位。
单片机端也采用工作方式1,波特率为1200,完成单片机与PC 机的通信。
串口连接流程Serial port connection is a common and essential process in various technological applications. In today's digital age, serial ports are still widely used for connecting hardware devices such as printers, scanners, and other peripheral devices to computers. The process of serial port connection involves establishing a communication link between two devices using a serial cable or adapter. This connection allows for data transfer between the devices, facilitating various functions and operations.串口连接是各种技术应用中常见且必不可少的过程。
在当今数字化时代,串口仍然广泛用于将硬件设备(如打印机、扫描仪和其他外围设备)连接到计算机。
串口连接的过程涉及使用串行电缆或适配器在两个设备之间建立通信链接。
这种连接允许数据在设备之间传输,促进各种功能和操作。
To begin the serial port connection process, the first step is to ensure that both devices have serial ports available for connection. This may require checking the specifications of the devices to determine the type of serial port they have, such as RS-232 or USB. Once the compatibility of the serial ports is confirmed, the next step is toobtain the necessary serial cable or adapter to connect the devices. This cable or adapter should have the appropriate connectors to fit the serial ports of the devices being connected.要开始串口连接过程,第一步是确保两个设备都具有可用于连接的串口。
实验一并行输入输出口的使用一、实验目的:学会设计proteus 7仿真电路,学习P1口的使用方法和延时子程序的编写用Keil uVision 3编程实现发光二极管的流水点亮。
二、实验原理:P1口为8位准双向I/O口,它的每一位都可以分别定义为输入线或输出线(作为输入时,口锁存器必须置1)。
P1口作为输出,接8个发光二极管D1~D8经限流电阻分别接至8个引脚。
本实验仿真电路图、流程图如下:三、实验代码:#include<reg51.h>#include<intrins.h> //移位库函数包含于此头文件中void delay(unsigned int d) //定义延时子函数{ while(--d>0);}void main(){ unsigned char i,sel;while(1){ sel=0xfe;for(i=0;i<=8;i++){ P1=sel; //显示变量赋给P1口delay(50000); //延时sel=_crol_(sel,1); //改变显示变量}}}四、实验结论:用while语句实现发光二极管循环流水点亮,从上到下一次点亮。
实验二C51分支程序设计一、实验目的:学习多分支选择结构和switch语句,了解循环的嵌套。
二、实验原理:do while 循环先执行后判断是否循环,switch括号中的表达式的值与某case后的常量表达式的值相同时,就执行它后面的语句,遇到break语句则退出switch语句。
本实验仿真电路图、流程图如下:(仿真电路图)(流程图)三、实验代码:#include <reg51.h>void main(){ char a;do{ P1=0xff;a=P1;a=a&0x03;switch(a){ case 0:P2=0x0e;break;case 1:P2=0x0d;break;case 2:P2=0x0b;break;case 3:P2=0x07;break;}}while(1);}四、实验结论:多分支选择的switch/case语句,可直接处理并行多分支选择问题,从匹配表达式的括号开始执行,不再进行判断。
串口通信步骤嘿,朋友们!今天咱就来讲讲串口通信那些事儿。
你想啊,串口通信就好比两个人聊天。
一个人发送信息,就像你跟朋友说话,把你的想法一股脑儿倒出来;另一个人接收信息,就如同朋友在认真听你讲。
那怎么开始这个“聊天”过程呢?首先得有合适的工具呀,就像你聊天得有手机或者嘴巴一样。
对于串口通信来说,就是要有串口线啦,这可是关键的连接纽带呢!然后呢,得设置好通信的参数,这就好比你和朋友约定好,用什么样的语言、什么样的语速来交流。
波特率、数据位、停止位这些参数都得设置对咯,不然就会像鸡同鸭讲,谁也听不懂谁。
接下来就是发送和接收数据啦!发送方把要表达的内容转化成数字信号,通过串口线传出去。
这就好像你把心里的话组织好,说出来给朋友听。
接收方呢,就静静地等着,一旦收到信号,就赶紧解读出来。
这里面可有意思啦!你想想,要是发送方说得太快,接收方会不会跟不上呀?就像你朋友说话像机关枪一样,你都来不及反应。
所以啊,这节奏得把握好。
还有啊,要是传输过程中出了点差错,那可咋办呢?就像你说话被风吹走了几个字,朋友没听清。
这时候就得有一些纠错机制啦,来确保信息的准确传达。
在实际应用中,串口通信可重要了呢!好多设备之间的交流都靠它。
比如说那些智能小玩意儿,它们之间要互相沟通,传递信息,就得靠串口通信这个小能手。
你说,这串口通信是不是很神奇?就像一个隐形的桥梁,连接着各种设备,让它们能协同工作。
反正啊,我觉得串口通信就像是一个神奇的魔法,让不同的设备能听懂彼此的语言,一起完成各种奇妙的任务。
咱可得好好了解它,掌握它,让它为我们服务呀!这就是我对串口通信的理解,你们觉得呢?。
信息工程学院实验报告课程名称:单片机原理及接口实验项目名称:串口通信实验实验时间:2017.5一、实验目的:1.了解什么是串口,串口的作用等。
2、了解串口通信的相关概念3、利用keil软件,熟悉并掌握中串口通信的使用4、通过实验,熟悉串口通信程序的格式,串口通信的应用等二、实验原理1、串口通信概念:单片机应用与数据采集或工业控制时,往往作为前端机安装在工业现场,远离主机,现场数据采用串行通信方式发往主机进行处理,以降低通信成本,提高通信可靠性。
如下图所示。
2、串口数据通信方式及特点★数据通信方式有两种:并行通信与串行通信★并行通信:所传送数据的各位同时发送或接收,数据有多少位就需要多少根数据线。
特点:速度快,成本高,适合近距离传输如计算机并口,打印机,8255 。
★串行通信:所传送数据的各位按顺序一位一位地发送或接收。
只需一根数据,一根地线,共2 根特点:成本低,硬件方便,适合远距离通信,传输速度低。
串行通信与并行通信示意图如下:成绩:指导老师(签名):3、串行通信基本格式①单工通信:数据只能单向传送。
②半双工通信:通信是双向的,但每一时刻,数据流通的方向是单向的。
③全双工通信:允许数据同时在两个方向流动,即通信双方的数据发送和接收是同时进行的。
4、异步串行通信/同步串行通信①异步串行通信:异步串行通信采用如下的帧结构:起始位+ 8位数据位+ 停止位或起始位+ 9位数据位+ 停止位其中:起始位为低电平,停止位为高电平。
优点:硬件结构简单缺点:传输速度慢②同步串行通信:在同步通信中,发送方在数据或字符开始处就用同步字符(常约定1~2个字节)指示一帧的开始,由时钟来实现发送端和接收端同步,接收方一旦检测到与规定的同步字符符合,下面就连续按顺序传送若干个数据,最后发校验字节。
见下图:5、串行通信过程与UART基本的计算机异步串行通信系统中,两台计算机之间通过三根信号线TxD、RxD和GND连接起来,TxD与GND构成发送线路,RxD与GND构成接收线路。
南昌大学实验报告学生姓名:王维学号:6100212202专业班级:网工121班实验类型:□验证□综合□设计□创新实验日期:4/2实验成绩:一、实验项目名称实验5:多路复用式串口操作二、实验项目名称通过编写多路复用式串口读写,进一步理解多路复用函数的用法,同时更加熟练掌握Linux 设备文件的读写方法。
三、实验内容本实验主要实现两台机器(宿主机和目标机)之间的串口通信,每台机器都可以发送和接收数据。
除了串口设备名称不同(宿主机上使用串口1:/dev/ttyS1,而在目标机上使用串口2:/dev/ttyS2),两台机器上的程序基本相同。
四、实验步骤(1)流程图两台机器上的程序使用同样的流程图。
(2)编写代码/* uart_api.h */#ifndef UART_API_H#define UART_API_H#define GNR_COM 0#define USB_COM 1#define COM_TYPE GNR_COM#define MAX_COM_NUM 3#define HOST_COM_PORT 1#define TARGET_COM_PORT 2#define BUFFER_SIZE 1024#define TIME_DELAY 180#define SEL_FILE_NUM 2#define RECV_FILE_NAME "recv.dat"int open_port(int com_port);int set_com_config(int fd,int baud_rate, int data_bits, char parity, int stop_bits); #endif /* UART_API_H *//* uart_api.c */#include <stdlib.h>#include <unistd.h>#include <sys/types.h>#include <sys/stat.h>#include <fcntl.h>#include <termios.h>#include <errno.h>#include "uart_api.h"/*打开串口函数*/int open_port(int com_port){int fd;#if (COM_TYPE == GNR_COM)char *dev[] = {"/dev/ttyS0", "/dev/ttyS1", "/dev/ttyS2"};#elsechar *dev[] = {"/dev/ttyUSB0", "/dev/ttyUSB1", "/dev/ttyUSB2"};#endifif ((com_port < 0) || (com_port > MAX_COM_NUM)){return -1;}fd = open(dev[com_port - 1], O_RDWR|O_NOCTTY|O_NDELAY);if (fd < 0){perror("open serial port");return(-1);}/*恢复串口为阻塞状态*/if (fcntl(fd, F_SETFL, 0) < 0){perror("fcntl F_SETFL\n");}/*测试是否为终端设备*/if (isatty(STDIN_FILENO) == 0){perror("standard input is not a terminal device");}return fd;}int set_com_config(int fd,int baud_rate, int data_bits, char parity, int stop_bits){struct termios new_cfg,old_cfg;int speed;/*保存测试现有串口参数设置,在这里如果串口号等出错,会有相关的出错信息*/ if (tcgetattr(fd, &old_cfg) != 0){perror("tcgetattr");return -1;}/*步骤一,设置字符大小*/new_cfg = old_cfg;cfmakeraw(&new_cfg);new_cfg.c_cflag &= ~CSIZE;/*设置波特率*/switch (baud_rate){case 2400:{speed = B2400;}break;case 4800:{speed = B4800;}break;case 9600:{speed = B9600;}break;case 19200:{speed = B19200;}break;case 38400:{speed = B38400;}break;default:case 115200:{speed = B115200;}break;}cfsetispeed(&new_cfg, speed);cfsetospeed(&new_cfg, speed);/*设置停止位*/switch (data_bits){case 7:{new_cfg.c_cflag |= CS7;}break;default:case 8:{new_cfg.c_cflag |= CS8;}break;}/*设置奇偶校验位*/switch (parity){default:case 'n':case 'N':{new_cfg.c_cflag &= ~PARENB;new_cfg.c_iflag &= ~INPCK;}break;case 'o':case 'O':{new_cfg.c_cflag |= (PARODD | PARENB);new_cfg.c_iflag |= INPCK;}break;case 'e':case 'E':{new_cfg.c_cflag |= PARENB;new_cfg.c_cflag &= ~PARODD;new_cfg.c_iflag |= INPCK;}break;case 's': /*as no parity*/case 'S':{new_cfg.c_cflag &= ~PARENB;new_cfg.c_cflag &= ~CSTOPB;}break;}/*设置停止位*/switch (stop_bits){default:case 1:{new_cfg.c_cflag &= ~CSTOPB;}break;case 2:{new_cfg.c_cflag |= CSTOPB;}}/*设置等待时间和最小接收字符*/new_cfg.c_cc[VTIME] = 0;new_cfg.c_cc[VMIN] = 1;/*处理未接收字符*/tcflush(fd, TCIFLUSH);/*激活新配置*/if((tcsetattr(fd, TCSANOW, &new_cfg)) != 0) {perror("tcsetattr");return -1;}return 0;}/* com_host.c */#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <string.h>#include <fcntl.h>#include <sys/types.h>#include <sys/stat.h>#include <errno.h>#include "uart_api.h"int main(void){int fds[SEL_FILE_NUM], recv_fd, maxfd;char buff[BUFFER_SIZE];fd_set inset,tmp_inset;struct timeval tv;unsigned loop = 1;int res, real_read, i;if ((recv_fd = open(RECV_FILE_NAME, O_CREAT|O_WRONL Y, 0644)) < 0) {perror("open");return 1;}fds[0] = STDIN_FILENO; /* 标准输入*/if((fds[1] = open_port(HOST_COM_PORT)) < 0) /* 打开串口*/{perror("open_port");return 1;}if(set_com_config(fds[1], 115200, 8, 'N', 1) < 0) /* 配置串口*/{perror("set_com_config");return 1;}FD_ZERO(&inset);FD_SET(fds[0], &inset);FD_SET(fds[1], &inset);maxfd = (fds[0] > fds[1])?fds[0]:fds[1];_sec = TIME_DELAY;_usec = 0;printf("Input some words(enter 'quit' to exit):\n");while (loop && (FD_ISSET(fds[0], &inset) || FD_ISSET(fds[1], &inset))){tmp_inset = inset;res = select(maxfd + 1, &tmp_inset, NULL, NULL, &tv);switch(res){case -1:{perror("select");loop = 0;}break;case 0: /* Timeout */{perror("select time out");loop = 0;}break;default:{for (i = 0; i < SEL_FILE_NUM; i++){if (FD_ISSET(fds[i], &tmp_inset)){memset(buff, 0, BUFFER_SIZE);real_read = read(fds[i], buff, BUFFER_SIZE);if ((real_read < 0) && (errno != EAGAIN)){loop = 0;}else if (!real_read){close(fds[i]);FD_CLR(fds[i], &inset);}else{buff[real_read] = '\0';if (i == 0){write(fds[1], buff, strlen(buff));printf("Input some words(enter 'quit' to exit):\n");}else if (i == 1){write(recv_fd, buff, real_read);}if (strncmp(buff, "quit", 4) == 0){loop = 0;}}} /* end of if FD_ISSET */} /* for i */}} /* end of switch */} /* end of while */close(recv_fd);return 0;}/* com_target.c */#include <stdio.h>#include <stdlib.h>#include <unistd.h>#include <string.h>#include <fcntl.h>#include <sys/types.h>#include <sys/stat.h>#include <errno.h>#include "uart_api.h"int main(void){int fds[SEL_FILE_NUM], recv_fd, maxfd;char buff[BUFFER_SIZE];fd_set inset,tmp_inset;struct timeval tv;unsigned loop = 1;int res, real_read, i;if ((recv_fd = open(RECV_FILE_NAME, O_CREAT|O_WRONL Y, 0644)) < 0) {perror("open");return 1;}fds[0] = STDIN_FILENO; /* 标准输入*/if((fds[1] = open_port(TARGET_COM_PORT)) < 0) /* 打开串口*/{perror("open_port");return 1;}if(set_com_config(fds[1], 115200, 8, 'N', 1) < 0) /* 配置串口*/{perror("set_com_config");return 1;}FD_ZERO(&inset);FD_SET(fds[0], &inset);FD_SET(fds[1], &inset);maxfd = (fds[0] > fds[1])?fds[0]:fds[1];_sec = TIME_DELAY;_usec = 0;printf("Input some words(enter 'quit' to exit):\n");while (loop && (FD_ISSET(fds[0], &inset) || FD_ISSET(fds[1], &inset))){tmp_inset = inset;res = select(maxfd + 1, &tmp_inset, NULL, NULL, &tv);switch(res){case -1:{perror("select");loop = 0;}break;case 0: /* Timeout */{perror("select time out");loop = 0;}break;default:{for (i = 0; i < SEL_FILE_NUM; i++){if (FD_ISSET(fds[i], &tmp_inset)){memset(buff, 0, BUFFER_SIZE);real_read = read(fds[i], buff, BUFFER_SIZE);if ((real_read < 0) && (errno != EAGAIN)){loop = 0;}else if (!real_read){close(fds[i]);FD_CLR(fds[i], &inset);}else{buff[real_read] = '\0';if (i == 0){printf("Input some words(enter 'quit' to exit):\n");write(fds[1], buff, strlen(buff));}else if (i == 1){write(recv_fd, buff, real_read);}if (strncmp(buff, "quit", 4) == 0){loop = 0;}}} /* end of if FD_ISSET */} /* for i */}} /* end of switch */} /* end of while */close(recv_fd);return 0;}(3)分别编译宿主机和目标机的串口程序。
串口程序流程图串行接口简称串口,也称串行通信接口或串行通讯接口(通常指COM接口),是采用串行通信方式的扩展接口。
我给大家整理了关于,希望你们喜欢!串口接口划分标准同步串行接口(英文:SynchronousSerialInterface,SSI)是一种常用的工业用通信接口。
异步串行是指UART(Universal Asynchronous Receiver/Transmitter),通用异步接收/发送。
UART是一个并行输入成为串行输出的芯片,通常集成在主板上。
UART包含TTL电平的串口和RS232电平的串口。
TTL电平是3.3V的,而RS232是负逻辑电平,它定义+5~+12V为低电平,而-12~-5V 为高电平,MDS2710、MDS SD4、EL805等是RS232接口,EL806有TTL接口。
串行接口按电气标准及协议来分包括RS-232-C、RS-422、RS485等。
RS-232-C、RS-422与RS-485标准只对接口的电气特性做出规定,不涉及接插件、电缆或协议。
RS-232也称标准串口,最常用的一种串行通讯接口。
它是在1970年由美国电子工业协会(EIA)联合贝尔系统、调制解调器厂家及计算机终端生产厂家共同制定的用于串行通讯的标准。
它的全名是"[1] 数据终端设备(DTE)和数据通讯设备(DCE)之间串行二进制数据交换接口技术标准"。
传统的RS-232-C接口标准有22根线,采用标准25芯D型插头座(DB25),后来使用简化为9芯D型插座(DB9),现在应用中25芯插头座已很少采用。
RS-232采取不平衡传输方式,即所谓单端通讯。
由于其发送电平与接收电平的差仅为2V至3V左右,所以其共模抑制能力差,再加上双绞线上的分布电容,其传送距离最大为约15米,最高速率为20kb/s。
RS-232是为点对点(即只用一对收、发设备)通讯而设计的,其驱动器负载为3~7k。
串口程序流程图
串行接口简称串口,也称串行通信接口或串行通讯接口(通常指COM接口),是采用串行通信方式的扩展接口。
我给大家整理了关于,希望你们喜欢!
串口接口划分标准
同步串行接口(英文:SynchronousSerialInterface,SSI)是一种常用的工业用通信接口。
异步串行是指UART(Universal Asynchronous Receiver/Transmitter),通用异步接收/发送。
UART是一个并行输入成为串行输出的芯片,通常集成在主板上。
UART包含TTL电平的串口和RS232电平的串口。
TTL电平是3.3V的,而RS232是负逻辑电平,它定义+5~+12V为低电平,而-12~-5V 为高电平,MDS2710、MDS SD4、EL805等是RS232接口,EL806有TTL接口。
串行接口按电气标准及协议来分包括RS-232-C、RS-422、RS485等。
RS-232-C、RS-422与RS-485标准只对接口的电气特性做出规定,不涉及接插件、电缆或协议。
RS-232
也称标准串口,最常用的一种串行通讯接口。
它是在1970年由美国电子工业协会(EIA)联合贝尔系统、调制解调器厂家及计算机终端生产厂家
共同制定的用于串行通讯的标准。
它的全名是"[1] 数据终端设备(DTE)和数据通讯设备(DCE)之间串行二进制数据交换接口技术标准"。
传统的
RS-232-C接口标准有22根线,采用标准25芯D型插头座(DB25),后来使用简化为9芯D型插座(DB9),现在应用中25芯插头座已很少采用。
RS-232采取不平衡传输方式,即所谓单端通讯。
由于其发送电平与接收电平的差仅为2V至3V左右,所以其共模抑制能力差,再加上双绞线上的分布电容,其传送距离最大为约15米,最高速率为20kb/s。
RS-232是为点对点(即只用一对收、发设备)通讯而设计的,其驱动器负载为3~7k。
所以RS-232适合本地设备之间的通信。
[2]
RS-422
标准全称是"平衡电压数字接口电路的电气特性",它定义了接口电路的特性。
典型的RS-422是四线接口。
实际上还有一根信号地线,共5根线。
其DB9连接器引脚定义。
由于接收器采用高输入阻抗和发送驱动器比RS232更强的驱动能力,故允许在相同传输线上连接多个接收节点,最多可接10个节点。
即一个主设备(Master),其余为从设备(Slave),从设备之间不能通信,所以RS-422支持点对多的双向通信。
接收器输入阻抗为4k,故发端最大负载能力是10×4k+100(终接电阻)。
RS-422四线接口由于采用单独的发送和接收通道,因此不必控制数据方向,各装置之间任何必须的信号交换均可以按软件方式(XON/XOFF握手)或硬件方式(一对单独的双绞线)实现。
RS-422的最大传输距离为1219米,最大传输速率为10Mb/s。
其平衡双绞线的长度与传输速率成反比,在100kb/s速率以下,才可能达到最大传
输距离。
只有在很短的距离下才能获得最高速率传输。
一般100米长的双绞线上所能获得的最大传输速率仅为1Mb/s。
RS-485
是从RS-422基础上发展而来的,所以RS-485许多电气规定与RS-422
相仿。
如都采用平衡传输方式、都需要在传输线上接终接电阻等。
RS-485可以采用二线与四线方式,二线制可实现真正的多点双向通信,而采用四线连接时,与RS-422一样只能实现点对多的通信,即只能有一个主(Master)设备,其余为从设备,但它比RS-422有改进,无论四线还是二线连接方式总线上可多接到32个设备。
RS-485与RS-422的不同还在于其共模输出电压是不同的,RS-485是-7V 至+12V之间,而RS-422在-7V至+7V之间,RS-485接收器最小输入阻抗为12k、RS-422是4k;由于RS-485满足所有RS-422的规范,所以RS-485的驱动器可以在RS-422网络中应用。
RS-485与RS-422一样,其最大传输距离约为1219米,最大传输速率为10Mb/s。
平衡双绞线的长度与传输速率成反比,在100kb/s速率以下,才可能使用规定最长的电缆长度。
只有在很短的距离下才能获得最高速率传输。
一般100米长双绞线最大传输速率仅为1Mb/s。
微信扫一扫二维码分享到微信好友或朋友圈来源:网友投稿。