Linux下ARM 和单片机的串口通信设计

Linux下ARM 和单片机的串口通信设计,第1张

    0 引言

  数据采集系统中由于单片机侧重于控制,数据处理能力较弱,对采集的数据进行运算处理比较繁琐,如果通过串口与上位机通信,利用上位机强大的数据处理能力和友好的控制界面对数据进行处理和显示则可以提高设计效率。串口通信以其简单的硬件连接,成熟的通信协议,成为上下位机之间通信的首选。移植了Linux *** 作系统的s3c2440 可以在Linux 环境下 *** 作串口,降低了串口 *** 作的难度,可以使开发者集中精力开发大规模的应用程序,而不必在 *** 作底层设计上耗费时间。

  1 硬件连接

  s3c2440 是三星公司生产的基于ARM9 核的处理器,采用3.3 V 电压供电; C8051Fxxx 系列单片机是美国CYGNAL 公司推出的与8051 兼容的高性能高速单片机,采用3.3 V 电压供电。两者供电电压相同,所以进行串行口通信时不需要进行电平转换。硬件连接采用最常用的TXD,RXD,GND 三线连接方式。注意采用交叉连接方式,即TXD?RXD,RXD?TXD.

  2 Linux 下串口通信

  2.1 Linux 下串口设备描述

  s3c2440 上移植了Linux 2.6.32 *** 作系统,加载了s3c2440 的串口驱动程序,通过Linux 提供的串口 *** 作函数和文件 *** 作函数把对串口的 *** 作等同于文件 *** 作,降低了串口的 *** 作难度,提高了效率。在程序中设备和文件都是通过文件描述符来 *** 作的,文件描述符在Linux 内核中是一个非负整数。Linux 设备文件都存放在“/dev”目录下,串口也不例外,在/dev 中可以找到串口对应的设备文件,本文对应的串口1 的设备文件路径是“/dev /ttySAC1”。

  2.2 Linux 下串口通信程序设计

  串口通信需要设置一些参数,如波特率、数据位、停止位,输入输出方式等。这些参数都存在于Linux提供的termios 结构中,该结构是Linux 系统用于查询和 *** 作各个终端的一个标准接口,定义在头文件《 ter-mios. h 》 中,如下所示:

  STruct termios{

  tcflag_t c_iflag; /* 输入标志* /

  tcflag_t c_oflag; /* 输出标志* /

  tcflag_t c_cflag /* 控制标志* /

  tcflag_t c_lflag /* 本地标志* /

  cc_t c_cc[NCCS]; /* 控制特性* /

  } ;

  Linux 串口通信步骤可分为以下三步, *** 作流程如图1 所示。

  Linux下ARM 和单片机的串口通信设计,Linux下ARM 和单片机的串口通信设计,第2张

  图1 *** 作流程

  第一步: 打开串口

  调用open( ) 函数打开串口设备文件,若出错则返回- 1,成功则返回文件句柄。

  #define UART1 /dev /ttySAC1

  int fd;

  fd = open( “UART1”,O_RDWR) /* 以可读可写方式打开串口设备* /

  第二步: 设置串口属性

  函数tcsetattr 可以设置串口的结构属性,tcgetatt( ) 可以得到串口的结构属性。在termios 结构中,最重要的是c_cflag,用户通过对其进行赋值可以实现串口波特率、数据位、停止位、奇偶校验位等参数的设置。c_cc 数组中的两个变量VMIN 和VTIME 判断是否返回输入,c _cc[VTIME]设定字节输入时间计时器,c _cc[VMIN]设定满足读取功能的最低接收字节数。这两个变量的值要设定合理,才能保证串口的通信成功率。

  int set_attr( int fd)

  {

  struct termios newTIo,oldTIo;

  tcgetattr( fd,&oldtio) ;

  cfsetispeed( &newtio,B9600) ; /* 设置读波特率为9600* /

  cfsetospeed( &newtio,B9600) ; /* 设置写波特率为9600* /

  memset( &newtio,0

  , sizeof( newtio) )

  ;

  newtio. c_cflag = CS8 | CREAD; /* 设置数据位为8 位并且使能接收* /

  newtio. c_cflag & = ~ PARENB; /* 不进行奇偶校验* /

  newtio. c_cflag & = ~ CSTOPB; /* 1 位停止位* /

  newtio. c_cc[VMIN]= 1; /* 当接收到一个字节数据就读取* /

  newtio. c_cc[VTIME]= 0; /* 不使用计时器* /

  tcflush( fd,TCIOFLUSH) ; /* 刷清输入输出缓冲区* /

  tcsetattr( fd,TCSANOW,&newtio) /* 使设置的终端属性立即生效* /

  }

  第三步: 串口读写,串口关闭

  设置完通信参数后,就可以用标准的文件读写命令read( ) 和write( ) *** 作串口了。最后在退出之前,用close( ) 函数关闭串口。

  void rd_wr( )

  {

  write( fd,wbuf,10) ;

  usleep( 500000) ; /* 延时50 ms 等待下位机发送数据* /

  read( fd, rbuf,10) ;

  printf( “read string is %s ”, rbuf) ;

  }

欢迎分享,转载请注明来源:内存溢出

原文地址: https://outofmemory.cn/dianzi/2714159.html

(0)
打赏 微信扫一扫 微信扫一扫 支付宝扫一扫 支付宝扫一扫
上一篇 2022-08-17
下一篇 2022-08-17

发表评论

登录后才能评论

评论列表(0条)

保存