linux 串口 read(linux的read命令)

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串口连接ttyS0、ttyS1是什么意思

这是通信串口名称。

在Linux环境下,串口名从ttyS0开始依次是ttyS1、ttyS2等。在本程序中,使用ttyS0作为通信串口。在打开ttyS0的时候,选项 O_NOCTTY表示不能把本串口当成控制终端,否则用户的键盘输入信息将影响程序的执行; O_NDELAY表示打开串口的时候,程序并不关心另一端的串口是否在使用中。在Linux中,打开串口设备和打开普通文件一样,使用的是open()系统调用。比如我么打开串口设备1也就是COM1,只需要:

fd= open("/dev/ttyS0", O_RDWR| O_NOCTTY| O_NDELAY);

打开的串口设备有很多设置选项。本文中使用int setup_com(int fd)设置。在系统头文件中定义了终端控制结构struct termios,tcgetattr()和tcsetattr()两个系统函数获得和设置这些属性。结构 struct termios中的域描述的主要属性包括:

c_cflag:控制选项

c_lflag:线选项

c_iflag:输入选项

c_oflag:输出选项

c_cc:控制字符

c_ispeed:输入数据波特率

c_ospeed:输出数据波特率

如果要设置某个选项,那么就使用"|=“运算,如果关闭某个选项就使用”&=“和”~"运算。本文使用的各个选项的意义定义如下:

c_cflag:

CLOCAL本地模式,不改变端口的所有者

CREAD表示使能数据接收器

PARENB表示偶校验

PARODD表示奇校验

CSTOPB使用两个停止位

CSIZE对数据的bit使用掩码

CS8数据宽度是8bit

c_lflag:

ICANON使能规范输入,否则使用原始数据(本文使用)

ECHO回送(echo)输入数据

ECHOE回送擦除字符

ISIG使能SIGINTR,SIGSUSP, SIGDSUSP和 SIGQUIT信号

c_iflag:

IXON使能输出软件控制

IXOFF使能输入软件控制

IXANY允许任何字符再次开启数据流

INLCR把字符NL(0A)映射到CR(0D)

IGNCR忽略字符CR(0D)

ICRNL把CR(0D)映射成字符NR(0A)

c_oflag: OPOST输出后处理,如果不设置表示原始数据(本文使用原始数据)

c_cc[VMIN]:最少可读数据

c_cc[VTIME]:等待数据时间(10秒的倍数)

linuxc++串口clinux串口

如何用C语言写一个读、写串口的程序?

大致过程就是

配置串口通信,包括串口号、波特率、校验位、停止位这些信息;

打开串口,和打开文件一样,在Linux下是这样,Windows下没试过,估计也差不多;

发送数据,即写串口,就跟写文件类似;

读取串口,用read就行。

具体的函数和配置参数可以参考一些别人的代码。

linux怎么在驱动中使用串口?

Linux发行版自带usbtoserial驱动,以模块方式编译驱动,在内核源代码目录下运行MakeMenuConfig选择Devcesdrivers-->USBseupport-->

linux查看某个串口参数(波特率,数据位等)命令什么?

用CAT命令查看#cat/proc/tty/driver/serial如果需要配置串口参数,minicom是个很好的选择。

一、安装sudoapt-getinstallminicom

二、配置配置minicom的参数运行$sudominicom-s便进入了minicom的配置界面,使用上下键选择Serialportsetup,回车。此时光标在“changewhichsetting”后面停留,它的上面有如下菜单:只需输入上面对应的字母,就可以进如相应的菜单进行设置。设置完成,回车,光标会回到“changewhichsetting”后面,如此重复。完成按回车返回主菜单即可。

linux下如何查看串口3,4的irq中断号?

第一个是/dev/ttyS0查看命令setserial/dev/ttyS2setserial/dev/ttyS3

串口号和IP地址一样吗?

串口号和ip地址不一样。

串口叫做串行接口,也称串行通信接口,按电气标准及协议来分包括RS-232-C、RS-422、RS485、USB等。一般家用的电脑都带有串口,在设备管理可以查看,windows系统下串口为COM前缀加数字,例如COM1。Linux系统下串口号一般为/dev/ttyS0。串口一般用于点对点的数据传输。

ip地址则是用于标识互联网通信是本机的地址。简单来讲,ip是用于多点通信的。ip地址是一串由点分格式输写的数字,比如,192.168.1.1。一个电脑可以配置多个ip。而串口如果没有虚拟化的话,串口号个数和实际的物理串口个数相等。

ip地址不能直接用于数据传输,需要封装在以太头,即数据数据链路层的支持。串口则不需要,可以直接发送数据。

因此从通信方式,以及使用场景上两个都是不一样的。

阅读剩余
THE END