linux中设置串口的系统调用tcgetattr,tcsetattr,tcflush的使用总结

本文主要是介绍linux中设置串口的系统调用tcgetattr,tcsetattr,tcflush的使用总结,希望对大家解决编程问题提供一定的参考价值,需要的开发者们随着小编来一起学习吧!

头文件:
#include <termios.h>
函数原型:
int tcsetattr(int fd, int optional_actions, const struct termios *termios_p);//设置串口属性

int tcgetattr(int fd, struct termios *termios_p);//获得串口属性

int tcflush(int fd, int queue_selector);//刷新串口的缓冲区

speed_t cfgetispeed(struct termios *termios_p);//获得输入速度

speed_t cfgetospeed(struct termios *termios_p);//获得输出速度

int cfsetispeed(struct termios *termios_p, speed_t speed);

int cfsetospeed(struct termios *temios_p, speed_t speed);

参数:

int fd:是打开的串口终端的文件描述符。如:/dev/ttyS0

 

struct termios *termios_p:存放参数的结构体的指针。

具体参见:https://baike.baidu.com/item/Termios/1467529?fr=aladdin

 

int optional_actions:用于控制修改起作用的时间,可以使用如下的取值:

TCSANOW:不等数据传输完毕立即改变属性。

TCSADRAIN:等所有的数据传输完毕才改变属性。

TCSAFLUSH:等所有的数据传输完毕,并且清空输入输出的缓冲区才改变属性。

 

int queue_selector:代表刷新的具体的缓冲区,可以有如下的取值:

TCIFLUSH:刷新输入缓冲区。

TCOFLUSH:刷新输出缓冲区。

TCIOFLUSH:刷新输入输出缓冲区。


如下为,实例;

int Uart0_Init(void)
{const char *path_utf = "/dev/ttyS0";printf("Open Uart0Init!! \n");if (uart0_fd == -1){uart0_fd = open(path_utf, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK); if(uart0_fd == -1){printf("Failed to open serial port %s, %s\n", path_utf, strerror(errno));return -1;}printf("Open Uart0 OK!! \n");}/* Configure device */struct termios newtio, oldtio;if ( tcgetattr(uart0_fd, &oldtio ) != 0) {  perror("tcgetattr error");return -1;}//tcflush(fd, TCIOFLUSH);bzero( &newtio, sizeof(newtio) );newtio.c_cflag |= CLOCAL | CREAD;newtio.c_cflag &= ~CSIZE;newtio.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);newtio.c_oflag &= ~OPOST;newtio.c_oflag &= ~(ONLCR | INLCR);newtio.c_iflag &= ~(ICRNL | INLCR);newtio.c_iflag &= ~(IXON | IXOFF | IXANY);//newtio.c_lflag &= ~(ICANON | ISIG | ECHO | ECHOE | IEXTEN);//newtio.c_oflag &= ~OPOST;//newtio.c_iflag &= ~(IXON | IXOFF | IXANY | ICRNL | BRKINT | INPCK | ISTRIP);//newtio.c_cflag &= ~CRTSCTS;newtio.c_cflag |= CS8;newtio.c_cflag &= ~PARENB;//   cfsetispeed(&newtio, B115200);//   cfsetospeed(&newtio, B115200);cfsetispeed(&newtio, B230400);cfsetospeed(&newtio, B230400);	newtio.c_cflag &= ~CSTOPB;newtio.c_cc[VTIME] = 0;newtio.c_cc[VMIN] = 0;tcflush(uart0_fd, TCIOFLUSH);if ((tcsetattr(uart0_fd, TCSANOW, &newtio)) != 0) {perror("set opt error");return -1;}return uart0_fd;
}
int Uart1Init(void)
{const char *path_utf = "/dev/ttyS1";int fd = -1;
//	speed_t speed = B115200;//speed_t speed = B230400;//fd = open(path_utf, O_RDWR | O_NOCTTY);fd = open(path_utf, O_RDWR | O_NOCTTY | O_NDELAY | O_NONBLOCK);if(fd == -1){printf("Failed to open serial --1-- port %s,\n", path_utf);return -1;}printf("Open Uart1 OK!! \n");/* Configure device */struct termios newtio, oldtio;if ( tcgetattr( fd, &oldtio ) != 0) {perror("tcgetattr error");return -1;}//tcflush(fd, TCIOFLUSH);bzero( &newtio, sizeof(newtio) );newtio.c_cflag |= CLOCAL | CREAD;newtio.c_cflag &= ~CSIZE;newtio.c_lflag &= ~(ICANON | ECHO | ECHOE | ISIG);newtio.c_oflag &= ~OPOST;newtio.c_oflag &= ~(ONLCR | INLCR);newtio.c_iflag &= ~(ICRNL | INLCR);newtio.c_iflag &= ~(IXON | IXOFF | IXANY);//newtio.c_lflag &= ~(ICANON | ISIG | ECHO | ECHOE | IEXTEN);//newtio.c_oflag &= ~OPOST;//newtio.c_iflag &= ~(IXON | IXOFF | IXANY | ICRNL | BRKINT | INPCK | ISTRIP);//newtio.c_cflag &= ~CRTSCTS;newtio.c_cflag |= CS8;newtio.c_cflag &= ~PARENB;//  cfsetispeed(&newtio, B115200);//  cfsetospeed(&newtio, B115200);cfsetispeed(&newtio, B230400);cfsetospeed(&newtio, B230400);newtio.c_cflag &= ~CSTOPB;newtio.c_cc[VTIME] = 0;newtio.c_cc[VMIN] = 0;tcflush(fd, TCIOFLUSH);if ((tcsetattr(fd, TCSANOW, &newtio)) != 0) {perror("set opt error");return -1;}uart_fd = fd;printf("fd-open=%d\n",fd);// InitSocket();/**************************************************************************/return fd;
}

 

 

 

 

 

这篇关于linux中设置串口的系统调用tcgetattr,tcsetattr,tcflush的使用总结的文章就介绍到这儿,希望我们推荐的文章对编程师们有所帮助!



http://www.chinasem.cn/article/978660

相关文章

Linux线程同步/互斥过程详解

《Linux线程同步/互斥过程详解》文章讲解多线程并发访问导致竞态条件,需通过互斥锁、原子操作和条件变量实现线程安全与同步,分析死锁条件及避免方法,并介绍RAII封装技术提升资源管理效率... 目录01. 资源共享问题1.1 多线程并发访问1.2 临界区与临界资源1.3 锁的引入02. 多线程案例2.1 为

Java使用Thumbnailator库实现图片处理与压缩功能

《Java使用Thumbnailator库实现图片处理与压缩功能》Thumbnailator是高性能Java图像处理库,支持缩放、旋转、水印添加、裁剪及格式转换,提供易用API和性能优化,适合Web应... 目录1. 图片处理库Thumbnailator介绍2. 基本和指定大小图片缩放功能2.1 图片缩放的

Python使用Tenacity一行代码实现自动重试详解

《Python使用Tenacity一行代码实现自动重试详解》tenacity是一个专为Python设计的通用重试库,它的核心理念就是用简单、清晰的方式,为任何可能失败的操作添加重试能力,下面我们就来看... 目录一切始于一个简单的 API 调用Tenacity 入门:一行代码实现优雅重试精细控制:让重试按我

MySQL中EXISTS与IN用法使用与对比分析

《MySQL中EXISTS与IN用法使用与对比分析》在MySQL中,EXISTS和IN都用于子查询中根据另一个查询的结果来过滤主查询的记录,本文将基于工作原理、效率和应用场景进行全面对比... 目录一、基本用法详解1. IN 运算符2. EXISTS 运算符二、EXISTS 与 IN 的选择策略三、性能对比

Oracle数据库定时备份脚本方式(Linux)

《Oracle数据库定时备份脚本方式(Linux)》文章介绍Oracle数据库自动备份方案,包含主机备份传输与备机解压导入流程,强调需提前全量删除原库数据避免报错,并需配置无密传输、定时任务及验证脚本... 目录说明主机脚本备机上自动导库脚本整个自动备份oracle数据库的过程(建议全程用root用户)总结

使用Python构建智能BAT文件生成器的完美解决方案

《使用Python构建智能BAT文件生成器的完美解决方案》这篇文章主要为大家详细介绍了如何使用wxPython构建一个智能的BAT文件生成器,它不仅能够为Python脚本生成启动脚本,还提供了完整的文... 目录引言运行效果图项目背景与需求分析核心需求技术选型核心功能实现1. 数据库设计2. 界面布局设计3

使用IDEA部署Docker应用指南分享

《使用IDEA部署Docker应用指南分享》本文介绍了使用IDEA部署Docker应用的四步流程:创建Dockerfile、配置IDEADocker连接、设置运行调试环境、构建运行镜像,并强调需准备本... 目录一、创建 dockerfile 配置文件二、配置 IDEA 的 Docker 连接三、配置 Do

Linux如何查看文件权限的命令

《Linux如何查看文件权限的命令》Linux中使用ls-R命令递归查看指定目录及子目录下所有文件和文件夹的权限信息,以列表形式展示权限位、所有者、组等详细内容... 目录linux China编程查看文件权限命令输出结果示例这里是查看tomcat文件夹总结Linux 查看文件权限命令ls -l 文件或文件夹

Android Paging 分页加载库使用实践

《AndroidPaging分页加载库使用实践》AndroidPaging库是Jetpack组件的一部分,它提供了一套完整的解决方案来处理大型数据集的分页加载,本文将深入探讨Paging库... 目录前言一、Paging 库概述二、Paging 3 核心组件1. PagingSource2. Pager3.

idea的终端(Terminal)cmd的命令换成linux的命令详解

《idea的终端(Terminal)cmd的命令换成linux的命令详解》本文介绍IDEA配置Git的步骤:安装Git、修改终端设置并重启IDEA,强调顺序,作为个人经验分享,希望提供参考并支持脚本之... 目录一编程、设置前二、前置条件三、android设置四、设置后总结一、php设置前二、前置条件