ch340x驱动移植主要概念
移植指的是将厂商提供的驱动源码调整适配到特定的系统版本。Linux系统通常会提供这些驱动的源代码。
ch340简介
这是一种用于USB转串口的芯片,需要编写驱动程序。
实验目的
在Linux平台上熟悉驱动移植、编译和加载的方法,实现官方ch34x驱动的USB转串口功能。
硬件电路
开发板和一个CH340模块。
驱动源码下载
从blog.csdn.net/JAZZSOLDI...下载Linux驱动CH341SER_LINUX.ZIP,包含ch34x.c(驱动源码)、Makefile(编译文件)和readme.txt(版本和命令说明)。
代码修改
主要修改ch34x.c的两处代码,注释某些代码,同时自定义Makefile。
编译运行
使用make命令编译,生成ch34x.ko的目标文件。使用make install将目标文件拷贝到NFS目录。插入CH340模块后,使用insmod命令加载ch34x驱动。
实验现象
加载驱动后,系统立即识别出新的串口,证明移植成功。
总结
完成驱动的移植后,验证了USB转串口功能的实现,验证了驱动在特定系统环境下的兼容性与可用性。
❷ 如何实现linux下的串口中断编程
#include
#include
#include
#include
#include
#include
#define BAUDRATE B38400
#define MODEMDEVICE "/dev/ttyS1"
#define _POSIX_SOURCE 1 /* POSIX 系统相容 */
#define FALSE 0
#define TRUE 1
volatile int STOP=FALSE;
void signal_handler_IO (int status); /* 定义讯号处理程序 */
int wait_flag=TRUE; /* 没收到讯号的话就会是 TRUE */
main()
{
int fd,c, res;
struct termios oldtio,newtio;
struct sigaction saio; /* definition of signal action */
char buf[255];
/* 开启装置为 non-blocking (读取功能会马上结束返回) */
fd = open(MODEMDEVICE, O_RDWR | O_NOCTTY | O_NONBLOCK);
if (fd <0) {perror(MODEMDEVICE); exit(-1); }
/* 在使装置异步化前, 安装讯号处理程序 */
saio.sa_handler = signal_handler_IO;
saio.sa_mask = 0;
saio.sa_flags = 0;
saio.sa_restorer = NULL;
sigaction(SIGIO,&saio,NULL);
/* 允许行程去接收 SIGIO 讯号*/
fcntl(fd, F_SETOWN, getpid());
/* 使档案ake the file descriptor 异步 (使用手册上说只有 O_APPEND 及
O_NONBLOCK, 而 F_SETFL 也可以用...) */
fcntl(fd, F_SETFL, FASYNC);
tcgetattr(fd,&oldtio); /* 储存目前的序列端口设定值 */
/* 设定新的序列端口为标准输入程序 */
newtio.c_cflag = BAUDRATE | CRTSCTS | CS8 | CLOCAL | CREAD;
newtio.c_iflag = IGNPAR | ICRNL;
newtio.c_oflag = 0;
newtio.c_lflag = ICANON;
newtio.c_cc[VMIN]=1;
newtio.c_cc[VTIME]=0;
tcflush(fd, TCIFLUSH);
tcsetattr(fd,TCSANOW,&newtio);
/* 等待输入讯号的回圈. 很多有用的事我们将在这做 */
while (STOP==FALSE) {
printf(".\n");usleep(100000);
/* 在收到 SIGIO 后, wait_flag = FALSE, 输入讯号存在则可以被读取 */
if (wait_flag==FALSE) {
res = read(fd,buf,255);
buf[res]=0;
printf(":%s:%d\n", buf, res);
if (res==1) STOP=TRUE; /* 如果只输入 CR 则停止回圈 */
wait_flag = TRUE; /* 等待新的输入讯号 */
}
}
/* 回存旧的序列端口设定值 */
tcsetattr(fd,TCSANOW,&oldtio);
}
❸ Linux RS485串口编程
对于编程来说,没什么区别,通过控制485的使能端该程序完全可以使用。唯一的区别就是你在发送的时候通过程序把485的控制脚拉高,接收的时候把他拉低就可以了。至于电气方面的区别:RS232是全双工,可以同时收发,RS485是半双工,不能同时收发,还有电平信号不一样,这个编程你就不要理了。
❹ 很简单的linux串口编程问题:fd = open("/dev/ttysn",|XXXXXXX)。其中哪个ttysn具体是多少
没做过linux下的,提供个建议,看成不成。
PC端的串口必须配置正确。 要确定 与 板子的 波特率 要一致。
此外, PC端作为串口总控端, COM端口配置只针对于PC端自己。 比如你使用了COM1口,那么定义的时候,(ttysn 应该是 ttysn1 --- 没用过linux下的不知道是不是在这配置,你要查)
板子端的COM口配置也是只针对于自己,如果你使用板子的COM1和COM2, 那么程序中初始化的时候需要同时把COM1/2都初始化,那么PC端就可以连接任意的板子端口。
PC(COM1) ---- 板子(COM1) 或 PC(COM1) ---- 板子(COM2)
在确保板子硬件没有问题的情况下,且PC端程序无误, 如果PC端无法接收到数据, 尝试
在PC端编写程序时,在 接收数据之前 加上时间延迟。 也就是说,PC发出数据后需要等待
一段时间才能接收到板子 返回的数据。 具体时间测试来看。
❺ Linux c串口编程中什么是奇偶效验
奇偶校验是一种校验代码传输正确性的方法。根据被传输的一组二进制代码的数位中“1”的个数是奇数或偶数来进行校验。采用奇数的称为奇校验,反之,称为偶校验。采用何种校验是事先规定好的。通常专门设置一个奇偶校验位,用它使这组代码中“1”的个数为奇数或偶数。若用奇校验,则当接收端收到这组代码时,校验“1”的个数是否为奇数,从而确定传输代码的正确性。