Ubuntu 串口测试

1>.虚拟串口测试(http://www.xappsoftware.com/wordpress/2013/10/07/using-virtual-serial-ports-on-linux-ubuntu/?goback=%2Egde_65688_member_5792872722853814274#%21
windows下有虚拟串口工具。ubuntu下也有:
安装虚拟串口:

sudo apt-get install socat

创建并连接2个虚拟串口

socat -d -d PTY PTY 

路径在: /dev/pts 下。
没创建前是没有的,可以用 ls /dev/pts 测试。
打开一个新的终端,并输入命令打开虚拟串口5:

# sudo cat /dev/pts/5

打开另外一个终端,向虚拟串口6发送数据,因为6和5是相通的,所以5会收到数据。

# sudo echo "Hello World" > /dev/pts/6

That’s all, nothing more.
见下图:
这里写图片描述
没有创建虚拟串口当然不存在,见下图:
这里写图片描述
2>和minicom的通讯
见下图:
(minicom打开虚拟串口7,向虚拟串口28发送字符,minicom会收到)
这里写图片描述
3>
最后用自己编写的代码测试,串口源码如下(参考http://blog.csdn.net/u010925447/article/details/72763052):
uart.c

#include     <stdio.h>      /*标准输入输出定义*/
#include     <stdlib.h>     /*标准函数库定义*/
#include     <unistd.h>     /*Unix 标准函数定义*/
#include     <sys/types.h>  
#include     <sys/stat.h>   
#include     <fcntl.h>      /*文件控制定义*/
#include     <termios.h>    /*PPSIX 终端控制定义*/
#include     <errno.h>      /*错误号定义*/
/**********************************************************************/
#define FALSE  -1
#define TRUE   0
/*********************************************************************/
#if 0
int main(void)
{       
    int fd;
    struct  termios Opt;
tcgetattr(fd, &Opt);
    cfsetispeed(&Opt,B19200);     /*设置为19200Bps*/
    cfsetospeed(&Opt,B19200);
    tcsetattr(fd,TCANOW,&Opt);
    /*以读写方式打开串口*/
    fd = open( "/dev/ttyS0", O_RDWR);
    if (-1 == fd){ 
        perror(" 提示错误!");
    }   
}
#endif

/**
*@brief  设置串口通信速率
*@param  fd     类型 int  打开串口的文件句柄
*@param  speed  类型 int  串口速度
*@return  void
*/
int speed_arr[] = { B38400, B19200, B9600, B4800, B2400, B1200, B300,
     B38400, B19200, B9600, B4800, B2400, B1200, B300, };
int name_arr[] = {38400,  19200,  9600,  4800,  2400,  1200,  300, 38400,  
     19200,  9600, 4800, 2400, 1200,  300, };
void set_speed(int fd, int speed){
 int   i; 
 int   status; 
 struct termios   Opt;
 tcgetattr(fd, &Opt); 
 for ( i= 0;  i < sizeof(speed_arr) / sizeof(int);  i++) { 
  if  (speed == name_arr[i]) {     
   tcflush(fd, TCIOFLUSH);     
   cfsetispeed(&Opt, speed_arr[i]);  
   cfsetospeed(&Opt, speed_arr[i]);   
   status = tcsetattr(fd, TCSANOW, &Opt);  
   if  (status != 0) {        
    perror("tcsetattr fd1");  
    return;     
   }    
   tcflush(fd,TCIOFLUSH);   
  }  
 }
}

/**
*@brief   设置串口数据位,停止位和效验位
*@param  fd     类型  int  打开的串口文件句柄
*@param  databits 类型  int 数据位   取值 为 7 或者8
*@param  stopbits 类型  int 停止位   取值为 1 或者2
*@param  parity  类型  int  效验类型 取值为N,E,O,,S
*/
int set_Parity(int fd,int databits,int stopbits,int parity)
{ 
     struct termios options; 
     if  ( tcgetattr( fd,&options)  !=  0) { 
      perror("SetupSerial 1");     
      return(FALSE);  
     }
     options.c_cflag &= ~CSIZE; 
     switch (databits) /*设置数据位数*/
     {   
     case 7:  
      options.c_cflag |= CS7; 
      break;
     case 8:     
      options.c_cflag |= CS8;
      break;   
     default:    
      fprintf(stderr,"Unsupported data sizen"); return (FALSE);  
     }
    switch (parity) 
    {   
     case 'n':
     case 'N':    
      options.c_cflag &= ~PARENB;   /* Clear parity enable */
      options.c_iflag &= ~INPCK;     /* Enable parity checking */ 
      break;  
     case 'o':   
     case 'O':     
      options.c_cflag |= (PARODD | PARENB); /* 设置为奇效验*/  
      options.c_iflag |= INPCK;             /* Disnable parity checking */ 
      break;  
     case 'e':  
     case 'E':   
      options.c_cflag |= PARENB;     /* Enable parity */    
      options.c_cflag &= ~PARODD;   /* 转换为偶效验*/     
      options.c_iflag |= INPCK;       /* Disnable parity checking */
      break;
     case 'S': 
     case 's':  /*as no parity*/   
         options.c_cflag &= ~PARENB;
      options.c_cflag &= ~CSTOPB;break;  
     default:   
      fprintf(stderr,"Unsupported parityn");    
      return (FALSE);  
     }  
    /* 设置停止位*/  
    switch (stopbits)
    {   
     case 1:    
      options.c_cflag &= ~CSTOPB;  
      break;  
     case 2:    
      options.c_cflag |= CSTOPB;  
        break;
     default:    
       fprintf(stderr,"Unsupported stop bitsn");  
       return (FALSE); 
    } 
    /* Set input parity option */ 
    if (parity != 'n')   
     options.c_iflag |= INPCK; 
    tcflush(fd,TCIFLUSH);
    options.c_cc[VTIME] = 150; /* 设置超时15 seconds*/   
    options.c_cc[VMIN] = 0; /* Update the options and do it NOW */
    if (tcsetattr(fd,TCSANOW,&options) != 0)   
    { 
     perror("SetupSerial 3");   
     return (FALSE);  
    } 
    return (TRUE);  
}



/**
代码说明:使用串口二测试的,发送的数据是字符,
但是没有发送字符串结束符号,所以接收到后,后面加上了结束符号。我测试使用的是单片机发送数据到第二个串口,测试通过。
*/
int OpenDev(char *Dev)
{
 int fd = open( Dev, O_RDWR );         //| O_NOCTTY | O_NDELAY 
 if (-1 == fd) 
 {    
  perror("Can''t Open Serial Port");
  return -1;  
 } 
 else 
  return fd;
}

int main(int argc, char **argv){
 int fd;
 int nread;
 char buff[512]={0};
 char *dev  = "/dev/pts/7";//"/dev/ttyS1"; //串口二
 fd = OpenDev(dev);
 set_speed(fd,19200);
 if (set_Parity(fd,8,1,'N') == FALSE)  {
  printf("Set Parity Errorn");
  exit (0);
 }
while (1) //循环读取数据
{   
 while((nread = read(fd, buff, 512))>0)
 { 
  printf("nLen=%d\n",nread); 
 // buff[nread+1] = '\0';   
  printf( "Rx:%s\n", buff);   
 }
}
 //close(fd);  
 // exit (0);
}
//write: char  buffer[1024];int    Length;int    nByte;nByte = write(fd, buffer ,Length)
//read: char  buff[1024];int    Len;int  readByte = read(fd,buff,Len);

uart.c
编译:
gcc uart.c -o uart
执行(此串口打开的是虚拟串口7):
./uart
然后向虚拟串口28发送数据,uart程序会打印收到的长度和数据。只是长度貌似不对???
如下图:
这里写图片描述

### 回答1: Ubuntu串口助手是一种在Ubuntu操作系统上使用的串口通信工具。串口助手可以帮助用户通过串口与其他设备进行通信,例如单片机、传感器或其他外部设备。 Ubuntu操作系统自带有串口设备的驱动程序,因此用户无需额外安装驱动程序来使用串口助手。用户只需将串口设备连接到计算机上的串口接口,并打开串口助手软件。 使用Ubuntu串口助手,用户可以进行以下操作: 1. 打开串口:用户可以在串口助手中选择正确的串口号,并设置波特率和其他串口参数,然后点击打开串口按钮。这将建立计算机与外部设备之间的串口连接。 2. 发送数据:用户可以向外部设备发送数据。在串口助手的发送区域,用户可以输入要发送的数据,并通过点击发送按钮将数据发送到串口。 3. 接收数据:用户可以接收外部设备发送的数据。串口助手会实时显示从串口接收到的数据,并在接收区域中显示。 4. 监控串口串口助手还可以作为串口的实时监控工具。用户可以实时监测串口的状态,包括数据传输速率、信号电平等。 5. 调试和测试:通过串口助手,用户可以进行串口通信的调试和测试。用户可以发送各种命令和数据,并验证外部设备的响应。 总之,Ubuntu串口助手是一款方便实用的工具,可帮助Ubuntu用户在串口通信中实现数据的发送、接收、调试和测试。它简化了串口通信的过程,提供了可靠的方法来与外部设备进行交互。 ### 回答2: Ubuntu 串口助手是一种用于在Ubuntu操作系统上管理串口通信的应用程序。它可以帮助用户在Ubuntu系统中连接和控制外部设备,如传感器、机器人、单片机等。 Ubuntu 串口助手的主要功能包括串口通信的设置与配置、数据的发送与接收,以及数据的分析与显示。通过该助手,用户可以方便地设置串口通信的参数,如波特率、数据位数、校验位等。同时,用户可以随时发送数据到串口,也可以实时接收来自串口的数据,并进行查看和分析。 在使用串口助手时,用户可以选择发送不同类型的数据,如ASCII码、16进制、2进制等,以满足不同外部设备的要求。同时,助手还支持数据的循环发送,方便用户进行自动化测试和调试。 此外,串口助手还提供了实时显示数据的功能,用户可以通过图表、曲线等方式对接收到的数据进行直观展示,并进行相应的数据处理和分析。 总之,Ubuntu 串口助手是一款功能全面的软件工具,适用于在Ubuntu操作系统上进行串口通信的应用开发和调试。它提供了方便的界面和丰富的功能,帮助用户轻松实现串口通信的设置、数据的发送与接收,以及数据的分析与显示。 ### 回答3: Ubuntu 串口助手是一种用于在Ubuntu操作系统上进行串口通信的工具。串口通信是一种用于在计算机和外部设备之间传输数据的通信方式。通常,串口通信被用于连接计算机和一些特殊设备,例如机器人、传感器和手机。 Ubuntu 串口助手提供了一个用户界面,使用户能够方便地配置和管理串口连接。它能够自动检测可用的串口设备,并允许用户选择并配置所需的串口。 使用Ubuntu 串口助手,用户可以进行多种串口操作,如发送和接收数据,设定串口的波特率、数据位、停止位和奇偶校验等参数,以及监视串口的通信状态和数据流。 Ubuntu 串口助手还允许用户通过命令行界面(CLI)进行串口通信。用户可以使用命令命令来打开、关闭、发送和接收串口数据。这为需要自动化串口通信的用户提供了更大的灵活性。 本工具还提供错误检测和故障排除功能。如果在串口通信过程中遇到问题,用户可以通过观察软件界面上的错误消息或使用工具自带的诊断工具来检查问题所在,并进行相应的修复。 总之,Ubuntu 串口助手是一款功能强大且易于使用的工具,可以让Ubuntu用户方便地进行串口通信和管理。无论是进行简单的数据传输还是进行更复杂的串口操作,用户都可以依靠这个助手来完成任务。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包
实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

1.余额是钱包充值的虚拟货币,按照1:1的比例进行支付金额的抵扣。
2.余额无法直接购买下载,可以购买VIP、付费专栏及课程。

余额充值