Linux驱动之串口驱动配置
简介
I.MX6ULL 的 UART 驱动 NXP 已经编写好了,所以不需要我们编写关于IMX6ULL 开发板UART程序, 以下为UART3作为rs232使用。
串口驱动配置
1、 UART3 IO 节点创建
UART3 用到了 UART3_TXD 和 UART3_RXD 这两个 IO,因此要先在 iomuxc 中创建 UART3对应的 pinctrl 子节点,在 iomuxc 中添加如下内容:
pinctrl_uart3: uart3grp {fsl,pins = <
MX6UL_PAD_UART3_TX_DATA__UART3_DCE_TX 0X1b0b1
MX6UL_PAD_UART3_RX_DATA__UART3_DCE_RX 0X1b0b1>;};
最后检查一下 UART3_TX 和 UART3_RX 这两个引脚有没有被用作其他功能,如果有用作其它功能的话要将其屏蔽掉,保证这两个 IO 只用作 UART3
2、添加 uart3 节点
默认情况下 imx6ull-alientek-emmc.dts 中只有 uart1 和 uart2 这两个节点,如下图所示:
uart1 是 UART1 的,在 I.MX6ull开发板上没有用到 UART2,而且 UART2默认用到了 UART3 的 IO,因此需要将 uart2 这个节点删除掉,然后加上 UART3 对应的 uart3,uart3 节点内容如下:
&uart3 {pinctrl-names = "default";pinctrl-0 = <&pinctrl_uart3>;status = "okay";};
完成以后重新编译设备树
并使用新的设备树启动 Linux, 如果设备树修改成功的话,系统启动以后就会生成一个名为“/dev/ttymxc2”的设备文件
, ttymxc2 就是 UART3 对应的设备文件,应用程序可以通过访问 ttymxc2 来实现对 UART3 的操作。
串口应用程序编写
#include <stdio.h>
#include <string.h>
#include <unistd.h>
#include <sys/types.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <termios.h>
#include <errno.h>int set_opt(int,int,int,char,int);
void main()
{int fd,nByte,flag=1;char *uart3 = "/dev/ttymxc2"; //"/dev/ttymxc2"是COM3char buffer[512];char *uart_out = "Please input,waiting....\r\n";char *uart_demo = "Linux uart demo\r\n";memset(buffer, 0, sizeof(buffer));//if((fd = open(uart3, O_RDWR|O_NOCTTY))<0)//默认为阻塞读方式if((fd = open(uart3, O_RDWR|O_NONBLOCK))<0)//非阻塞读方式printf("open %s is failed",uart3);else{set_opt(fd, 115200, 8, 'N', 1);write(fd,uart_demo, strlen(uart_demo));write(fd,uart_out, strlen(uart_out));while(1){while((nByte = read(fd, buffer, 512))>0){buffer[nByte+1] = '\0'; write(fd,buffer,strlen(buffer));memset(buffer, 0, strlen(buffer));nByte = 0;}}}
}int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop)
{struct termios newtio,oldtio;if ( tcgetattr( fd,&oldtio) != 0) { perror("SetupSerial 1");return -1;}bzero( &newtio, sizeof( newtio ) );newtio.c_cflag |= CLOCAL | CREAD;newtio.c_cflag &= ~CSIZE;switch( nBits ){case 7:newtio.c_cflag |= CS7;break;case 8:newtio.c_cflag |= CS8;break;}switch( nEvent ){case 'O':newtio.c_cflag |= PARENB;newtio.c_cflag |= PARODD;newtio.c_iflag |= (INPCK | ISTRIP);break;case 'E': newtio.c_iflag |= (INPCK | ISTRIP);newtio.c_cflag |= PARENB;newtio.c_cflag &= ~PARODD;break;case 'N': newtio.c_cflag &= ~PARENB;break;}switch( nSpeed ){case 2400:cfsetispeed(&newtio, B2400);cfsetospeed(&newtio, B2400);break;case 4800:cfsetispeed(&newtio, B4800);cfsetospeed(&newtio, B4800);break;case 9600:cfsetispeed(&newtio, B9600);cfsetospeed(&newtio, B9600);break;case 115200:cfsetispeed(&newtio, B115200);cfsetospeed(&newtio, B115200);break;case 460800:cfsetispeed(&newtio, B460800);cfsetospeed(&newtio, B460800);break;default:cfsetispeed(&newtio, B9600);cfsetospeed(&newtio, B9600);break;}if( nStop == 1 )newtio.c_cflag &= ~CSTOPB;else if ( nStop == 2 )newtio.c_cflag |= CSTOPB;newtio.c_cc[VTIME] = 100;///* 设置超时10 seconds*/newtio.c_cc[VMIN] = 0;tcflush(fd,TCIFLUSH);if((tcsetattr(fd,TCSANOW,&newtio))!=0){perror("com set error");return -1;}// printf("set done!\n\r");return 0;
}
串口用编程函数介绍
1、读取当前参数函数:
int tcgetattr(int fd,struct termios *termios_p)
fd:open操作后返回的文件句柄
*termios_p:为前面介绍的结构体
初始化开始前调用这个函数.
2、获取当前波特率函数:
int speed_t cfgetispeed(const struct termios *termios_p)
int speed_t cfgetospeed(const struct termios *termios_p)
*termios_p:为前面介绍的结构体
成功返回0,失败返回-1
3、波特率设置函数:
int cfsetispeed(struct termios *termios_p,speed_t speed)
int cfsetospeed(struct termios *termios_p,speed_t speed)
*termios_p:为前面介绍的结构体
speed:波特率,常用B2400,B4800,B9600,B115200,B460800
成功返回0,失败返回-1
4、清空buffer数据函数:
int tcflush(int fd,int queue_selector)
queue_selector:有三个常用宏定义TCIFLUSH:清空正读的数据,且不会读出TCOFLUSH:清空正写入的数据,且不会发送到终端TCIOFLUSH:清空所有正在发生的I/O数据.成功返回0,失败返回-1
5、设置串口参数函数:
int tcsetattr(int fd,int optional_actions,cons struct termios *termios_p)
optional_actions:有三个常用宏定义TCSANOW:不等数据传输完毕,立即改变属性TCSADRAIN:等所有数据传输完毕,再改变属性TCSAFLUSH:清空输入输出缓冲区才改变属性
成功返回0,失败返回-1
串口号介绍
PC的默认串口为ttyS0;
嵌入式设备的默认串口为ttymxc*(代表数字);
注:嵌入式设备Samsung Artik 710架构的则是ttySAC(*代表数字)
检查串口是否可以
通过echo 命令直接往/dev/ttyN 设备写字符,如果有被写字符输出显示的话,就说明这个tty设备可用。例如下图中就可以看到/dev/ttyAMA0这个设备可用
Linux驱动之串口驱动配置相关推荐
- Linux:TTY串口驱动数据接收设置
Linux的uart串口,无论是rs232格式的还是rs485格式的 ,最终都封装为tty接口.一般串口驱动都是芯片厂商开发好的.我们基本只要正确使用就能正常工作. 我这边开发的时候,使用应用层的测试 ...
- linux系统中串口驱动的基本实现原理
大家好,今天主要和大家聊一聊,如何利用linux系统中的串口驱动. 目录 第一:linux系统中UART驱动框架 第二:uart_ops的具体实现 第三:串口驱动设备树的添加 第一:linux系统中U ...
- 从串口驱动到Linux驱动模型,想转Linux的必会!
关注.星标公众号,直达精彩内容 ID:技术让梦想更伟大 整理:李肖遥 本文通过对Linux下串口驱动的分析.由最上层的C库.到操作系统系统调用层的封装.再到tty子系统的核心.再到一系列线路规程.再到 ...
- 嵌入式驱动解析:从串口驱动到Linux驱动模型
本文通过对Linux下串口驱动的分析.由最上层的C库.到操作系统系统调用层的封装.再到tty子系统的核心.再到一系列线路规程.再到最底层的硬件操作. 对Linux中的tty子系统进行简要的说明.从理论 ...
- 从串口驱动到Linux驱动模型
大学的时候,帮朋友写的操作系统调研的作业,最近整理过去的文档时候偶然发现,遂作为博客发出来. 从串口驱动到Linux的tty子系统驱动模型简要分析 基于ARM920T核心 Samsung的S3C244 ...
- linux设备驱动之串口移植,Linux设备驱动之UART驱动结构
一.对于串口驱动Linux系统中UART驱动属于终端设备驱动,应该说是实现串口驱动和终端驱动来实现串口终端设备的驱动.要了解串口终端的驱动在Linux系统的结构就先要了解终端设备驱动在Linux系统中 ...
- Linux驱动开发——串口设备驱动
Linux驱动开发--串口设备驱动 一.串口简介 串口全称叫做串行接口,通常也叫做 COM 接口,串行接口指的是数据一个一个的顺序传输,通信线路简单.使用两条线即可实现双向通信,一条用于发送,一条用于 ...
- Linux终端tty设备驱动
在Linux系统中,终端设备非常重要,没有终端设备,系统将无法向用户反馈信息,Linux中包含控制台.串口和伪终端3类终端设备. 14.1节阐述了终端设备的概念及分类,14.2节给 出了Linu ...
- Linux设备驱动之UART驱动结构
一.对于串口驱动Linux系统中UART驱动属于终端设备驱动,应该说是实现串口驱动和终端驱动来实现串口终端设备的驱动.要了解串口终端的驱动在Linux系统的结构就先要了解终端设备驱动在Linux系统中 ...
- CP2102 USB to UART Bridge Controller 串口驱动安装(windows or Ubuntu)
CP2102 USB to UART Bridge Controller 驱动安装(windows or Ubuntu) 串口驱动下载 串口驱动安装 reference 串口驱动下载 CP2102是一 ...
最新文章
- 第十六届智能车竞赛广东省线上比赛第二波来袭
- linuxdeployqt打包
- 如何统计网站用户的停留时间?
- 前端学习(1142):预定义类
- STM32CubeMX使用(五)之IIC及数字加速度计LIS2DW12使用
- 【水果识别】基于matalb GUI水果分类系统【含Matlab源码 174期】
- 专业pdf转word转换软件 pdf转换器 pdf转txt pdf转ppt、excel
- php微信h5支付对接流程,微信H5支付接口开发的流程与常见问题
- 系统的性能与压力测试
- 虚幻4UE4使用PS4 DualShock4手柄ProController Switch手柄
- 免费而优秀的图表JS插件、js图表、html图表--百度的Echart、Highcharts、阿里的G2、Chart.js
- 邮箱搬家操作步骤及详细说明
- python怎么输入下一行_python中怎么换行,怎么从第一行换到第二行的?
- OSChina 周二乱弹 ——室友开始买假发女装了
- 计算机网络-自顶向下方法 第三章课后习题答案(第七版)
- Postman安装与基本操作
- python 循环控制语句结束_孤荷凌寒自学python第十五天python循环控制语句
- 嵌入式新闻早班车-第9期
- 利用PIFU-HD生成自己的三维人体图像
- 原版蓝光光盘加国语配音加中文字幕及解说字幕保留弹出菜单傻瓜版教程