博客
关于我
Linux下串口程序设计
阅读量:351 次
发布时间:2019-03-04

本文共 1366 字,大约阅读时间需要 4 分钟。

Linux串口访问指南

Linux系统支持通过设备文件访问串口,类似于其他操作系统。在需要访问串口时,只需打开对应的设备文件即可。Linux系统通常提供多个串口设备,默认位于/dev文件夹下,设备名称通常为ttyS0ttyS1等,其中"S"代表"Serial"的意思。

打开串口后,可以进行读写操作,但在操作之前需要进行串口设置,以确保使用默认配置。以下是详细的操作步骤。

打开串口设备

使用open函数打开对应的串口设备,指定读写模式、控制终端属性和延迟模式:

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

其中:

  • O_RDWR:设置为读写模式
  • O_NOCTTY:指示系统不将该端口视为控制终端,避免由串口发送的信号(如Ctrl+C)中断当前进程
  • O_NDELAY:不等待DCD信号线状态,串口将立即响应

串口配置

配置串口参数需要使用termios结构体和相关函数。以下是详细步骤:

1. 保存原始配置

首先,获取当前串口的属性:

struct termios newtio, oldtio;
tcgetattr(fd, &oldtio);

2. 激活配置选项

设置本地连接和读取模式:

newtio.c_cflag |= CLOCAL | CREAD;

3. 设置波特率

配置串口波特率,常见速率如115200:

cfsetispeed(&newtio, B115200);
cfsetospeed(&newtio, B115200);

4. 设置数据位

通常使用8位数据位:

newtio.c_cflag &= ~CSIZE;
newtio.c_cflag |= CS8;

5. 设置奇偶校验

配置奇校验或偶校验:

奇校验配置:

newtio.c_cflag |= PARENB;
newtio.c_cflag |= PARODD;
newtio.c_iflag |= (INPCK | ISTRIP);

偶校验配置:

newtio.c_iflag |= (INPCK | ISTRIP);
newtio.c_cflag |= PARENB;
newtio.c_cflag |= ~PARODD;

6. 设置停止位

配置停止位数量:

newtio.c_cflag &= ~CSTOPB;

7. 设置最少字符和等待时间

通常设置为0:

newtio.c_cc[VTIME] = 0;
newtio.c_cc[VMIN] = 0;

8. 刷新缓存

清除输入和输出缓存:

tcflush(fd, TCOFLUSH);

9. 应用配置

激活配置设置:

tcsetattr(fd, TCSANOW, &newtio);

读写操作

使用标准的readwrite函数进行通信:

读取数据时:

n = read(fd, buffer, sizeof(buffer));

写入数据时:

n = write(fd, "tangquan\r\n", 10);

读取优化

在非阻塞模式下读取:

fcntl(fd, F_SETFL, FNDELAY);

恢复阻塞模式:

fcntl(fd, F_SETFL, 0);

关闭串口

使用close函数关闭文件描述符:

close(fd);

转载地址:http://bhzh.baihongyu.com/

你可能感兴趣的文章
Oracle中序列的操作以及使用前对序列的初始化
查看>>
oracle中新建用户和赋予权限
查看>>
Oracle中的NVL,NVL2,NULLIF以及COALESCE函数使用
查看>>
Oracle中的rownum 和rowid的用法和区别
查看>>
oracle中的大小写、字符、dual、数字、处理、日期、函数、显/隐式、时间、条件表达式case、decode、to_date、to_char、sysdate
查看>>
Oracle修改字段类型
查看>>
oracle典型安装失败,安装oracle 10失败
查看>>
Oracle分析函数之LEAD和LAG
查看>>
Oracle和SQL server的数据类型比较
查看>>
Oracle用游标删除重复数据
查看>>
Oracle监听配置、数据库实例配置等
查看>>
Oracle系列:安装Oracle RAC数据库(二)
查看>>
oracle系统 介绍,ORACLE数据库管理系统介绍
查看>>
oracle获取数据库表、字段、注释、约束等
查看>>
Oracle计划将ZGC项目提交给OpenJDK
查看>>
Oracle闪回技术(Flashback)
查看>>
oracle零碎要点---ip地址问题,服务问题,系统默认密码问题
查看>>
oracle零碎要点---oracle em的web访问地址忘了
查看>>
Oracle零碎要点---多表联合查询,收集数据库基本资料
查看>>
Oracle静默安装
查看>>