linux串口测试

串口介绍

对于linux来说,所有的资源都是文件,串口更是如此,比如龙芯2K1000,可以出12路串口,这些多路串口,在linux系统下就有12个设备节点,/dev/ttyS0~11,对这些节点open,ioctl,read,write即可读写对应的串口.
linux下的串口收发应用程序,向固定串口以固定波特率发送16进制数据,并不断接收

#include <stdio.h>
#include <stdlib.h>
#include <strings.h>
#include <string.h>
#include <pthread.h>
#include <unistd.h>
#include <fcntl.h>
#include <stdlib.h>
#include <error.h>
#include <termios.h>
#include <malloc.h>
#include <sys/types.h>
#include <sys/stat.h>
typedef struct termios termios_t;

typedef struct serial_data{

    unsigned char databuf[100];
    int serfd;

}ser_Data;

int num = 6;
void *sersend(void *arg);
void *serrecv(void *arg);

int main(int argc,char *argv[])
{
    pthread_t pid1,pid2;
    pthread_attr_t *pthread_arr1,*pthread_arr2;
    pthread_arr1 = NULL;
    pthread_arr2 = NULL;
    int serport1fd;
    termios_t *ter_s = malloc(sizeof(*ter_s));

    serport1fd = open(argv[1],O_RDWR | O_NONBLOCK);
    if(serport1fd < 0){
        printf("%s open faild\r\n",argv[1]);
        return -1;
    }

    bzero(ter_s,sizeof(*ter_s));

    ter_s->c_cflag |= CLOCAL | CREAD; 

    ter_s->c_cflag &= ~CSIZE;
    ter_s->c_cflag |= CS8;

    ter_s->c_cflag &= ~CSTOPB;

    ter_s->c_cflag &= ~PARENB;

    ter_s->c_cc[VTIME] = 1;
    ter_s->c_cc[VMIN] = 1;

    ter_s->c_lflag &=~(ICANON|ECHO|ECHOE);

    cfsetispeed(ter_s,B115200);
    cfsetospeed(ter_s,B115200);
    tcflush(serport1fd,TCIFLUSH);

    if(tcsetattr(serport1fd,TCSANOW,ter_s) != 0){
            printf("com set error!\r\n");
    }


    unsigned char buffer[10] = {0x01,0x02,0x03,0x04,0x05,0x06,0x07,0x08,0x09,0x0a};
    unsigned char recvbuf[100] = {};

    ser_Data snd_data;
    ser_Data rec_data;

    snd_data.serfd = serport1fd;
    rec_data.serfd = serport1fd;

    memcpy(snd_data.databuf,buffer,10);
    pthread_create(&pid1,pthread_arr1,sersend,(void *)&snd_data);
    pthread_create(&pid2,pthread_arr2,serrecv,(void *)&rec_data);


    ssize_t sizec;
    while(1){

            usleep(100000);
    }

    pthread_join(pid1,NULL);
    pthread_join(pid2,NULL);
    free(ter_s);
    return 0;
}


void *sersend(void *arg)
{
    ser_Data *snd = (ser_Data *)arg ;
    printf("send fuction\n");
    int ret,i;
    while(num--){
       sleep(3);
       ret = write(snd->serfd,snd->databuf,10);
       if(ret > 0){
            printf("send success, data len 10\r\n");
            for(i=0;i<10;i++)
                    printf(" 0x%02x",snd->databuf[i]);
            printf("\n");
       }else{
           printf("send error!\r\n");
       }
       usleep(300000);
    }
}

void *serrecv(void *arg)
{
 ser_Data *rec= (ser_Data *)arg ;
    int ret,i;
    while(1){
       ret = read(rec->serfd,rec->databuf,1024);
       if(ret > 0){
            printf("recv success,recv size is %d \r\n",ret );

       for(i=0;i<ret;i++)
               printf(" 0x%02x",rec->databuf[i]);
       printf("\n");

       }else{

       }
       usleep(1000);

    }
}

进行测试时,在linux下输入命令即可 ./uart /dev/ttyS2,启动uart为上面应用程序编译后的名字;
未完待续

  • 1
    点赞
  • 4
    收藏
    觉得还不错? 一键收藏
  • 打赏
    打赏
  • 0
    评论
下面是一个简单的Linux串口测试程序的源码示例: ```c #include <stdio.h> #include <stdlib.h> #include <fcntl.h> #include <unistd.h> #include <termios.h> int main() { int fd; struct termios options; fd = open("/dev/ttyS0", O_RDWR | O_NOCTTY | O_NDELAY); // 打开串口设备 if (fd == -1) { perror("无法打开串口"); exit(EXIT_FAILURE); } fcntl(fd, F_SETFL, 0); // 获取当前串口的配置 tcgetattr(fd, &options); // 设置串口的波特率 cfsetispeed(&options, B9600); cfsetospeed(&options, B9600); // 设置数据位、停止位和奇偶校验位 options.c_cflag &= ~CSIZE; options.c_cflag |= CS8; options.c_cflag &= ~PARENB; options.c_cflag &= ~CSTOPB; // 应用配置到串口 tcsetattr(fd, TCSANOW, &options); // 向串口发送数据 char buffer[] = "Hello, Serial Port!"; write(fd, buffer, sizeof(buffer)); // 从串口接收数据 char read_buffer[256]; int num_bytes = read(fd, read_buffer, sizeof(read_buffer)); read_buffer[num_bytes] = '\0'; printf("接收到的数据:%s\n", read_buffer); close(fd); return 0; } ``` 在以上示例中,程序首先打开了一个串口设备(在这里使用的是/dev/ttyS0,你可以根据实际情况修改)。然后,它获取了当前串口的配置,对其进行了相应的设置(如波特率、数据位、停止位和奇偶校验位等),并将配置应用到串口。程序接着向串口发送了一串数据,并从串口接收了数据。最后,程序关闭了串口设备。如果程序无法打开串口或者在读写串口时出现错误,它会打印相应的错误信息。 这只是一个简单的串口测试程序示例,你可以根据自己的需求对其进行修改和扩展。另外,请注意在编译时链接所需的头文件和库文件。

“相关推荐”对你有帮助么?

  • 非常没帮助
  • 没帮助
  • 一般
  • 有帮助
  • 非常有帮助
提交
评论
添加红包

请填写红包祝福语或标题

红包个数最小为10个

红包金额最低5元

当前余额3.43前往充值 >
需支付:10.00
成就一亿技术人!
领取后你会自动成为博主和红包主的粉丝 规则
hope_wisdom
发出的红包

打赏作者

打工人1379号

你的鼓励将是我创作的最大动力

¥1 ¥2 ¥4 ¥6 ¥10 ¥20
扫码支付:¥1
获取中
扫码支付

您的余额不足,请更换扫码支付或充值

打赏作者

实付
使用余额支付
点击重新获取
扫码支付
钱包余额 0

抵扣说明:

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

余额充值