利用ptmx搭建本地虚拟串口回环测试环境

留个备份,执行这个搭建程序可以在当前目录生成ttyNeo1和ttyNeo2两个互连的虚拟串口,在Linux上写上位机和下位机串口通信程序时就不需要利用物理串口测试了。

#define _XOPEN_SOURCE
#include <stdio.h>
#include <unistd.h>
#include <stdlib.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <errno.h>
#include <string.h>
#include <signal.h>
#include <poll.h>

static int alive = 0;
static char buf[8*1024] = {0};

static void neo_handler(int sig)
{
    printf("got signal(%d)\n", sig);
    alive = 0;
}

int main(int argc, char **argv)
{
    int ret = 0;
    int m1 = 0;
    int m2 = 0;
    char *pts = NULL;
    struct pollfd pollfds[2];
    signal(SIGTERM, neo_handler);
    signal(SIGINT, neo_handler);
    m1 = open("/dev/ptmx", O_RDWR);
    if (m1 < 0) {
        printf("open /dev/ptmx failed, errno=%d(%s)\n", errno, strerror(errno));
        return -1;
    }
    grantpt(m1);
    unlockpt(m1);
    m2 = open("/dev/ptmx", O_RDWR);
    if (m2 < 0) {
        printf("open /dev/ptmx failed, errno=%d(%s)\n", errno, strerror(errno));
        goto err_m2;
    }
    grantpt(m2);
    unlockpt(m2);
    pts = ptsname(m1);
    if (!pts)
        goto err_pts;
    remove("./ttyNeo1");
    ret = symlink(pts, "./ttyNeo1");
    if (ret < 0) {
        printf("create ./ttyNeo1 failed, errno=%d(%s)\n", errno, strerror(errno));
        goto err_pts;
    }
    pts = ptsname(m2);
    remove("./ttyNeo2");
    ret = symlink(pts, "./ttyNeo2");
    if (ret < 0) {
        printf("create ./ttyNeo2 failed, errno=%d(%s)\n", errno, strerror(errno));
        goto err_pts;
    }
    memset(&pollfds, 0, sizeof(pollfds));
    pollfds[0].fd = m1;
    pollfds[0].events = POLLIN;
    pollfds[1].fd = m2;
    pollfds[1].events = POLLIN;
    alive = 1;
    while (alive) {
        ret = poll(&pollfds[0], 2, 500);
        if ((ret < 0) && (errno == EINTR) || (ret == 0))
            continue;
        else if (ret < 0) {
            printf("poll failed, errno=%d(%s)\n", errno, strerror(errno));
            break;
        }
        if (pollfds[0].revents & POLLIN) {
            memset(buf, 0, sizeof(buf));
            ret = read(m1, buf, sizeof(buf));
            if (ret > 0)
                write(m2, buf, ret);
            pollfds[0].revents = 0;
        }
        if (pollfds[1].revents & POLLIN) {
            memset(buf, 0, sizeof(buf));
            ret = read(m2, buf, sizeof(buf));
            if (ret > 0)
                write(m1, buf, ret);
            pollfds[1].revents = 0;
        }
    }
err_pts:
    close(m2);
    m2 = -1;
err_m2:
    close(m1);
    m1 = -1;
    return 0;
}

  • 1
    点赞
  • 1
    收藏
    觉得还不错? 一键收藏
  • 0
    评论
错误消息"unable to start container process: open /dev/ptmx: no such file or directory"表示在启动容器过程中,无法打开/dev/ptmx设备文件,并且该文件或目录不存在。该错误通常出现在使用容器技术(如Docker)时。 /dev/ptmx设备文件是Linux系统中的一个伪终端设备,用于处理终端会话和虚拟终端。当容器尝试创建终端会话或执行与终端相关的操作时,会使用/dev/ptmx设备文件。因此,容器无法找到或打开该文件时,会导致该错误。 要解决此问题,我们可以采取以下步骤: 1. 检查宿主系统:确保宿主系统上存在/dev/ptmx设备文件,并具有正确的权限。您可以使用命令"ls -l /dev/ptmx"来检查其权限和属性。 2. 重启宿主系统:有时,这个错误可能是由于系统配置问题导致的。尝试重启宿主系统,看是否解决了这个问题。 3. 更新容器平台:如果您正在使用的是Docker或其他容器平台,确保您使用的是最新版本。有时,容器平台的旧版本可能会出现与设备文件相关的问题,而新版本可能已经修复了这些问题。 4. 检查容器配置:查看您的容器配置文件,确保没有错误或不正确的配置导致无法找到/dev/ptmx设备文件。验证您的配置文件,并确保正确设置了终端会话和相关的设置。 5. 检查容器镜像:如果问题仅出现在特定的容器镜像中,那么有可能是镜像本身存在问题。尝试使用另一个镜像或更新镜像来解决该问题。 如果仍然无法解决该问题,您可以查看容器技术的文档或寻求相关技术支持,以获得更多帮助和指导。
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

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

抵扣说明:

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

余额充值