linux read 串口(linux嵌入式软件开发)

大家好,今天来为大家解答linux read 串口这个问题的一些问题点,包括linux嵌入式软件开发也一样很多人还不知道,因此呢,今天就来为大家分析分析,现在让我们一起来看看吧!如果解决了您的问题,还望您关注下本站哦,谢谢~

如何查看linux下串口是否可用串口名称等

分析如下:

1、查看串口是否可用,可以对串口发送数据比如对com1口,echo lyjie126>/dev/ttyS0。

2、查看串口名称使用ls-l/dev/ttyS*一般情况下串口的名称全部在dev下面,如果你没有外插串口卡的话默认是dev下的ttyS*,一般ttyS0对应com1,ttyS1对应com2,当然也不一定是必然的;

3、查看串口驱动:cat/proc/tty/drivers/serial。

4、查看串口设备:dmesg| grep ttyS*。

扩展资料

串口控制器顾名思义,就是可通过串口实现控制功能的一台控制器。即由上位机通过串口发送特定协议格式的指令给控制器,进而来控制外围设备或器件,也叫单片机串口控制器。

串口控制器就是1台写入了串口通信程序的单片机控制器,有2种工作模式:

1)上位机监控模式:可由上位机串口控制,实现串口监控;

2)脱机控制模式:在通过上位机设置好相关参数后,也可脱离上位机进行独立控制。

串口控制器就是1台写入了串口通信程序的单片机控制器,有2种工作模式:

1)上位机监控模式:可由上位机串口控制,实现串口监控;

2)脱机控制模式:在通过上位机设置好相关参数后,也可脱离上位机进行独立控制。

参考资料来源:百度百科:串口控制器

Linux下串口通信丢字节的问题是怎么样解决

int con=atoi(portstr);

unsigned char Port_file_name[30];

int fd0,rc;

struct termios ts0;

switch(con)

{//选项O_NOCTTY表示不能把本串口当成控制终端,否则用户的键盘输入信息将影响程序的执行

//O_NDELAY表示打开串口的时候,程序并不关心另一端的串口是否在使用中

case 1: fd0=open("/dev/ttyM0",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 2: fd0=open("/dev/ttyM1",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 3: fd0=open("/dev/ttyM2",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 4: fd0=open("/dev/ttyM3",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 5: fd0=open("/dev/ttyM4",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 6: fd0=open("/dev/ttyM5",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 7: fd0=open("/dev/ttyM6",O_RDWR| O_NOCTTY| O_NDELAY); break;

case 8: fd0=open("/dev/ttyM7",O_RDWR| O_NOCTTY| O_NDELAY); break;

default: fd0=open("/dev/ttyM0",O_RDWR| O_NOCTTY| O_NDELAY); break;

}

tcgetattr(fd0,&ts0);

bzero(&ts0,sizeof(struct termios));

switch(gytype)

{

case 1:{ts0.c_cflag|= B300| CS7| CLOCAL| CREAD| PARENB;

ts0.c_cflag&=~PARODD;//转换为偶效验

ts0.c_iflag|= INPCK;// Disnable parity checking

break;}

case 2:{ts0.c_cflag|= B1200| CS8| CLOCAL| CREAD| PARENB;

ts0.c_cflag&=~PARODD;//转换为偶效验

ts0.c_iflag|= INPCK;// Disnable parity checking

break;

}

case 3:{

ts0.c_cflag|= B9600| CS8| CLOCAL| CREAD;

ts0.c_cflag&=~PARENB;// Clear parity enable

ts0.c_iflag&=~INPCK;// Enable parity checking

break;

}

case 4:{ts0.c_cflag|= B9600| CS8| CLOCAL| CREAD| PARENB;

ts0.c_cflag&=~PARODD;//转换为偶效验

ts0.c_iflag|= INPCK;// Disnable parity checking

break;

}

}

ts0.c_lflag&=~ECHO;

ts0.c_lflag&=~ECHONL;

ts0.c_iflag&=~IXOFF;

ts0.c_iflag&=~IXON;

ts0.c_cflag&=~CSIZE;

switch(gytype)

{

case 1:{ts0.c_cflag|= CS7; break;}

case 2:{ts0.c_cflag|= CS8; break;}

case 3:{ts0.c_cflag|= CS8; break;}

case 4:{ts0.c_cflag|= CS8; break;}

}

ts0.c_lflag&=~ICANON;//如果设置使能规范输入,否则使用原始数据(本文使用)

ts0.c_oflag&=~ONLCR;//如果设置将NL转换成CR-NL后输出

ts0.c_iflag&=~INLCR;//如果设置将接收到的NL(换行)转换成CR(回车)。

ts0.c_cc[VMIN]= 0;//最少可读数据

ts0.c_cc[VTIME]= 0;//等待数据时间(10秒的倍数)

ts0.c_cflag&=~CSTOPB;//如果设置则使用两个停止位,如果取消则使用一个停止位

ts0.c_iflag|= IGNBRK;//如果设置则忽略接收到的break信号

ts0.c_lflag&=~IEXTEN;//如果设置则启用实现自定义的输入处理

ts0.c_lflag|= NOFLSH;//如果设置则禁止产生SIGINT,SIGQUIT和SIGSUSP信号时刷新输入和输出队列

switch(gytype)

{

case 1:{rc= cfsetospeed(&ts0,B300);break;}

case 2:{rc= cfsetospeed(&ts0,B1200);break;}

case 3:{rc= cfsetospeed(&ts0,B9600);break;}

case 4:{rc= cfsetospeed(&ts0,B9600);break;}

}

rc= tcsetattr(fd0,TCSAFLUSH,&ts0);

return fd0;

Linux下使用串口阅读数据linux查看串口数据

Linux是一个广泛使用的开源操作系统,功能强大,在阅读串口设备的数据方面也得到了支持。本文将介绍如何在 Linux下使用串口阅读数据。

首先,我们需要在系统中找到我们的串口设备,这可以通过 ls/dev/tty*和 ls/dev/serial/by-id/命令来完成。在上面的命令中,/dev/tty*将会显示出正在使用的系统串口(例如:/dev/ttyUSB0),而/dev/serial/by-id/将会显示出设备唯一标识符,这将会有利于我们在多台设备之间做区分。

接下来,我们就可以使用标准的 Linux串口工具(如 minicom)来读取数据了。Minicom是一款可以用来从串口读取数据和发送数据的终端程序。它需要使用如下命令:

$ minicom-D/dev/ttyUSB0

这里的-D参数用来指定串口,我们也可以指定波特率(可选的)。例如:

$ minicom-D/dev/ttyUSB0-b 115200

最后,我们可以使用另一种更加详细的串口工具, cutecom。它可以用来更好地查看数据,甚至可以从设备中读取 hex数据。可以使用在下述命令来安装:

$ sudo apt-get install cutecom

安装后,可以使用下面的命令来运行它:

$ cutecom

在耨叏中,可以选择我们的串口设备,并设置一些选项,来更方便地读取数据。

总结:

以上就是 Linux下使用串口读取数据的一般方法。首先,我们需要找到我们的串口设备,然后使用标准的 Linux串口工具,比如 minicom或 cutecom,就可以开始阅读数据了。通过以上方法,可以实现在 Linux下更方便地读取串口设备中的数据。

阅读剩余
THE END