• ubuntu 安装串口工具和添加虚拟串口


    目录

    一、串口工具安装

    二、使用Windows本身虚拟的串口

    (一)添加串口

    1、保证虚拟机是关闭状态,打开“虚拟机设置”,点击“添加”。

    2、选中“串行端口”,点击“完成”。

    3、选中刚添加的串口,下拉选择自己需要使用的端口,点击完成即可。

    (二)注册权限 

     1、注意:在使用串口进行通信时,需要先注册其权限。

      2、注册完权限后,打开CuteCom,选择串口,再点击Open,即可打开。如果没有注册权限,则打不开。

    3、打开成功: 

    (三)通讯测试

    三、添加虚拟串口

    原文:

    1.下载socat

    2.使用socat配置虚拟串口

    3.重新打开终端 编写串口通信的代码 

    4.执行程序

    5.总结


    一、串口工具安装

    安装cute:

    sudo apt-get install cutecom

    安装完成,打开如下,点击“Settings”可以进行设置:

    二、使用Windows本身虚拟的串口

    (一)添加串口

    1、保证虚拟机是关闭状态,打开“虚拟机设置”,点击“添加”。

    2、选中“串行端口”,点击“完成”。

    3、选中刚添加的串口,下拉选择自己需要使用的端口,点击完成即可。

    进行查看:

    (二)注册权限 

     1、注意:在使用串口进行通信时,需要先注册其权限。

    1. //注册所有:
    2. sudo chmod 777 /dev -R

      2、注册完权限后,打开CuteCom,选择串口,再点击Open,即可打开。如果没有注册权限,则打不开。

    3、打开成功: 

    (三)通讯测试

            1、在Windows下开启串口助手,选择与Ubuntu添加的端口成对的另一个虚拟串口,并使用Hex编码;

            2、CuteCom选择Hex的编码方式,再随机输入发送的内容,按回车即可发送,然后就能在Windows上的串口助手上看到发送过来的数据了。

    三、添加虚拟串口

    原文:

    https://blog.csdn.net/qq_62106718/article/details/130949814

    使用socat完成虚拟串口的配置

    1.下载socat

    sudo apt install socat

    2.使用socat配置虚拟串口

    socat -d -d pty,raw,echo=0 pty,raw,echo=0

     可以看到配置好的两个虚拟串口的路径:/dev/pts/3  /dev/pts/3, 不要关闭该进程。

    3.重新打开终端 编写串口通信的代码 

    1. #include
    2. #include
    3. #include
    4. #include
    5. #include
    6. #include
    7. #include
    8. #include
    9. #include
    10. #include
    11. #include
    12. #include
    13. #include
    14. typedef struct termios termios_t;
    15. typedef struct serial_data{
    16. char databuf[100];//发送/接受数据
    17. int serfd;//串口文件描述符
    18. }ser_Data;
    19. void *sersend(void *arg);
    20. void *serrecv(void *arg);
    21. int main(int argc,char *argv[])
    22. {
    23. pthread_t pid1,pid2;
    24. pthread_attr_t *pthread_arr1,*pthread_arr2;
    25. pthread_arr1 = NULL;
    26. pthread_arr2 = NULL;
    27. int serport1fd;
    28. /* 进行串口参数设置 */
    29. termios_t *ter_s = malloc(sizeof(*ter_s));
    30. serport1fd = open(argv[1],O_RDWR | O_NOCTTY | O_NDELAY);//不成为控制终端程序,不受其他程序输出输出影响
    31. if(serport1fd < 0){
    32. printf("%s open faild\r\n",argv[1]);
    33. return -1;
    34. }
    35. bzero(ter_s,sizeof(*ter_s));
    36. ter_s->c_cflag |= CLOCAL | CREAD; //激活本地连接与接受使能
    37. ter_s->c_cflag &= ~CSIZE;//失能数据位屏蔽
    38. ter_s->c_cflag |= CS8;//8位数据位
    39. ter_s->c_cflag &= ~CSTOPB;//1位停止位
    40. ter_s->c_cflag &= ~PARENB;//无校验位
    41. ter_s->c_cc[VTIME] = 0;
    42. ter_s->c_cc[VMIN] = 0;
    43. /*1 VMIN> 0 && VTIME> 0
    44. VMIN为最少读取的字符数,当读取到一个字符后,会启动一个定时器,在定时器超时事前,如果已经读取到了VMIN个字符,则read返回VMIN个字符。如果在接收到VMIN个字符之前,定时器已经超时,则read返回已读取到的字符,注意这个定时器会在每次读取到一个字符后重新启用,即重新开始计时,而且是读取到第一个字节后才启用,也就是说超时的情况下,至少读取到一个字节数据。
    45. 2 VMIN > 0 && VTIME== 0
    46. 在只有读取到VMIN个字符时,read才返回,可能造成read被永久阻塞。
    47. 3 VMIN == 0 && VTIME> 0
    48. 和第一种情况稍有不同,在接收到一个字节时或者定时器超时时,read返回。如果是超时这种情况,read返回值是0。
    49. 4 VMIN == 0 && VTIME== 0
    50. 这种情况下read总是立即就返回,即不会被阻塞。----by 解释粘贴自博客园
    51. */
    52. cfsetispeed(ter_s,B115200);//设置输入波特率
    53. cfsetospeed(ter_s,B115200);//设置输出波特率
    54. tcflush(serport1fd,TCIFLUSH);//刷清未处理的输入和/或输出
    55. if(tcsetattr(serport1fd,TCSANOW,ter_s) != 0){
    56. printf("com set error!\r\n");
    57. }
    58. char buffer[] = {"hello my world!\r\n"};
    59. char recvbuf[100] = {};
    60. ser_Data snd_data;
    61. ser_Data rec_data;
    62. snd_data.serfd = serport1fd;
    63. rec_data.serfd = serport1fd;
    64. memcpy(snd_data.databuf,buffer,strlen(buffer));//拷贝发送数据
    65. pthread_create(&pid1,pthread_arr1,sersend,(void *)&snd_data);
    66. pthread_create(&pid2,pthread_arr2,serrecv,(void *)&rec_data);
    67. ssize_t sizec;
    68. while(1){
    69. usleep(100000);
    70. }
    71. pthread_join(pid1,NULL);
    72. pthread_join(pid2,NULL);
    73. free(ter_s);
    74. return 0;
    75. }
    76. void *sersend(void *arg)//串口发送线程函数
    77. {
    78. ser_Data *snd = (ser_Data *)arg ;
    79. int ret;
    80. while(1){
    81. scanf("%s",snd->databuf);
    82. ret = write(snd->serfd,snd->databuf,strlen(snd->databuf));
    83. if(ret > 0){
    84. printf("send success, data is %s\r\n",snd->databuf);
    85. }else{
    86. printf("send error!\r\n");
    87. }
    88. usleep(300000);
    89. /*
    90. if(发生中断)
    91. break;//退出
    92. */
    93. }
    94. }
    95. void *serrecv(void *arg)//串口发送线程函数
    96. {
    97. ser_Data *rec= (ser_Data *)arg ;
    98. int ret;
    99. while(1){
    100. ret = read(rec->serfd,rec->databuf,1024);
    101. if(ret > 0){
    102. printf("recv success,recv size is %d,data is %s\r\n",ret,rec->databuf);
    103. }else{
    104. /*
    105. 什么也不做
    106. */
    107. }
    108. usleep(1000);
    109. /*
    110. if(发生中断)
    111. break;//退出
    112. */
    113. }
    114. }

    使用下面命令编译

    gcc serial.c -o serial -lpthread

    4.执行程序

    认真看上面的串口通信代码 在运行程序需要传入main函数的参数,该参数就是虚拟串口的位置

    所以执行下面的命令运行程序

    ./serial /dev/pts/2

     再打开一个终端输入下面命令

    ./serial /dev/pts/3

    5.总结

    如果出现open fail 可能原因:权限不够  或者 虚拟串口关闭或位置错误

  • 相关阅读:
    评估大型语言模型生成文章的能力
    I/O多路复用:解锁服务器高性能的钥匙
    Vue3中ref与reactive的区别
    [附源码]java毕业设计校园淘宝节系统
    【软考 系统架构设计师】案例分析⑤ 质量属性和架构评估
    vue-element学习(一)
    Java面向对象进阶
    【Java 进阶篇】Ajax 入门:打开前端异步交互的大门
    Redis入门完整教程:Java客户端Jedis
    【漏洞复现】图书馆集群管理系统存在逻辑绕过
  • 原文地址:https://blog.csdn.net/WenHuiJun_/article/details/134015978