`
xiaoheliushuiya
  • 浏览: 423159 次
文章分类
社区版块
存档分类
最新评论

linux 串口读写 termios说明

 
阅读更多

termios结构体说明

termios结构体中,该结构体一般包括如下的成员:
struct termios
{unsigned short c_iflag; /* 输入模式标志*/
unsigned short c_oflag; /* 输出模式标志*/
unsigned short c_cflag; /* 控制模式标志*/
unsigned short c_lflag; /*区域模式标志或本地模式标志或局部模式*/
unsigned char c_line; /*行控制line discipline */
unsigned char c_cc[NCC]; /* 控制字符特性*/
};


其具体意义如下

c_iflag:输入模式标志,控制终端输入方式,具体参数如下所示。

c_iflag参数表
键值说明
IGNBRK 忽略BREAK键输入
BRKINT如果设置了IGNBRK,BREAK键的输入将被忽略,如果设置了BRKINT ,将产生SIGINT中断
IGNPAR忽略奇偶校验错误
PARMRK标识奇偶校验错误
INPCK允许输入奇偶校验
ISTRIP去除字符的第8个比特
INLCR将输入的NL(换行)转换成CR(回车)
IGNCR忽略输入的回车
ICRNL将输入的回车转化成换行(如果IGNCR未设置的情况下)
IUCLC将输入的大写字符转换成小写字符(非POSIX)
IXON允许输入时对XON/XOFF流进行控制
IXANY输入任何字符将重启停止的输出
IXOFF允许输入时对XON/XOFF流进行控制
IMAXBEL当输入队列满的时候开始响铃,Linux在使用该参数而是认为该参数总是已经设置

c_oflag:输出模式标志,控制终端输出方式,具体参数如下所示。
c_oflag参数
键值说明
OPOST处理后输出
OLCUC将输入的小写字符转换成大写字符(非POSIX)
ONLCR将输入的NL(换行)转换成CR(回车)及NL(换行)
OCRNL将输入的CR(回车)转换成NL(换行)
ONOCR第一行不输出回车符
ONLRET不输出回车符
OFILL发送填充字符以延迟终端输出
OFDEL以ASCII码的DEL作为填充字符,如果未设置该参数,填充字符将是NUL(‘/0’)(非POSIX)
NLDLY换行输出延时,可以取NL0(不延迟)或NL1(延迟0.1s)
CRDLY回车延迟,取值范围为:CR0、CR1、CR2和 CR3
TABDLY水平制表符输出延迟,取值范围为:TAB0、TAB1、TAB2和TAB3
BSDLY空格输出延迟,可以取BS0或BS1
VTDLY垂直制表符输出延迟,可以取VT0或VT1
FFDLY换页延迟,可以取FF0或FF1

c_cflag:控制模式标志,指定终端硬件控制信息,具体参数如下所示。
c_oflag参数
键值说明
CBAUD波特率(4+1位)(非POSIX)
CBAUDEX附加波特率(1位)(非POSIX)
CSIZE字符长度,取值范围为CS5、CS6、CS7或CS8
CSTOPB设置两个停止位
CREAD使用接收器
PARENB使用奇偶校验
PARODD对输入使用奇偶校验,对输出使用偶校验
HUPCL关闭设备时挂起
CLOCAL忽略调制解调器线路状态
CRTSCTS使用RTS/CTS流控制


c_lflag:本地模式标志,控制终端编辑功能,具体参数如下所示。
c_lflag参数
键值说明
ISIG当输入INTR、QUIT、SUSP或DSUSP时,产生相应的信号
ICANON使用标准输入模式
XCASE在ICANON和XCASE同时设置的情况下,终端只使用大写。如果只设置了XCASE,则输入字符将被转换为小写字符,除非字符使用了转义字符(非POSIX,且Linux不支持该参数)
ECHO显示输入字符
ECHOE如果ICANON同时设置,ERASE将删除输入的字符,WERASE将删除输入的单词
ECHOK如果ICANON同时设置,KILL将删除当前行
ECHONL如果ICANON同时设置,即使ECHO没有设置依然显示换行符
ECHOPRT如果ECHO和ICANON同时设置,将删除打印出的字符(非POSIX)
TOSTOP向后台输出发送SIGTTOU信号

与此结构体相关的函数
(一)tcgetattr()
1.原型
int tcgetattr(int fd,struct termois & termios_p);
2.
功能
取得终端介质(fd)初始值,并把其值 赋给temios_p;函数可以从后台进程中调用;但是,终端属性可能被后来的前台进程所改变。


(二)tcsetattr()
1.原型
int tcsetattr(int fd,int actions,const struct termios *termios_p);
2.功能
设置与终端相关的参数 (除非需要底层支持却无法满足),使用 termios_p 引用的 termios 结构。optional_actions (tcsetattr函数的第二个参数)指定了什么时候改变会起作用:
TCSANOW:改变立即发生
TCSADRAIN:改变在所有写入 fd 的输出都被传输后生效。这个函数应当用于修改影响输出的参数时使用。(当前输出完成时将值改变)
TCSAFLUSH :改变在所有写入 fd 引用的对象的输出都被传输后生效,所有已接受但未读入的输入都在改变发生前丢弃(同TCSADRAIN,但会舍弃当前所有值)。


(三)tcsendbreak()
传送连续的 0 值比特流,持续一段时间,如果终端使用异步串行数据传输的话。如果 duration 是 0,它至少传输 0.25 秒,不会超过 0.5 秒。如果 duration 非零,它发送的时间长度由实现定义。
如果终端并非使用异步串行数据传输,tcsendbreak() 什么都不做。


(四)tcdrain()
等待直到所有写入 fd 引用的对象的输出都被传输。


(五)tcflush()
丢弃要写入 引用的对象,但是尚未传输的数据,或者收到但是尚未读取的数据,取决于 queue_selector 的值:

TCIFLUSH :刷新收到的数据但是不读
TCOFLUSH :刷新写入的数据但是不传送
TCIOFLUSH :同时刷新收到的数据但是不读,并且刷新写入的数据但是不传送

(六)tcflow()
挂起 fd 引用的对象上的数据传输或接收,取决于 action 的值:

TCOOFF :挂起输出
TCOON :重新开始被挂起的输出
TCIOFF :发送一个 STOP 字符,停止终端设备向系统传送数据
TCION :发送一个 START 字符,使终端设备向系统传输数据
打开一个终端设备时的默认设置是输入和输出都没有挂起。


(七)波特率函数
被用来获取和设置 termios 结构中,输入和输出波特率的值。新值不会马上生效,直到成功调用了 tcsetattr() 函数。
设置速度为 B0 使得 modem "挂机"。与 B38400 相应的实际比特率可以用 setserial(8) 调整。
输入和输出波特率被保存于 termios 结构中。
cfmakeraw 设置终端属性如下:
termios_p->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON);
termios_p->c_oflag &= ~OPOST;
termios_p->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN);
termios_p->c_cflag &= ~(CSIZE|PARENB);
termios_p->c_cflag |= CS8;

1.cfgetospeed()返回 termios_p 指向的 termios 结构中存储的输出波特率
2.cfsetospeed()设置 termios_p 指向的 termios 结构中存储的输出波特率为 speed。取值必须是以下常量之一:
B0 B50 B75 B110 B134 B150 B200 B300 B600 B1200 B1800 B2400 B4800 B9600 B19200 B38400 B57600 B115200 B230400
其中:零值 B0 用来中断连接。如果指定了 B0,不应当再假定存在连接。通常,这样将断开连接。CBAUDEX 是一个掩码,指示高于 POSIX.1 定义的速度的那一些 (57600 及以上)。因此,B57600 & CBAUDEX 为非零。
3.cfgetispeed()返回 termios 结构中存储的输入波特率。
4.cfsetispeed()设置 termios 结构中存储的输入波特率为 speed。如果输入波特率被设为0,实际输入波特率将等于输出波特率。


RETURN VALUE 返回值
1.cfgetispeed() 返回 termios 结构中存储的输入波特率。
2.cfgetospeed() 返回 termios 结构中存储的输出波特率。
3.其他函数返回:
(1)0:成功
(2) -1:失败,
并且为 errno 置值来指示错误。
注意 tcsetattr() 返回成功,如果任何所要求的修改可以实现的话。因此,当进行多重修改时,应当在这个函数之后再次调用 tcgetattr() 来检测是否所有修改都成功实现


我的工程例子:


#include<stdio.h>

#include<string.h>

#include<unistd.h>

#include<fcntl.h>

#include<errno.h>

#include<termios.h>

#include<sys/time.h>


staticspeed_t getBaudrate(jint baudrate)

{

switch(baudrate){

case 0: return B0;

.....

case4800: return B4800;

case9600: return B9600;

case19200: return B19200;

case38400: return B38400;

.........

case576000: return B576000;

case1152000: return B1152000;

...

case 4000000: return B4000000;

default:return -1;

}

}




/*

*Class: cedric_serial_SerialPort

*Method: open

*Signature: (Ljava/lang/String;)V

*/

JNIEXPORTjobject JNICALL Java_com_jenny_iRelax_serialport_SerialPort_open

(JNIEnv*env, jobject thiz, jstring path, jint baudrate,,int stopbits,jint parity)

{

int fd;

speed_t speed;

jobject mFileDescriptor;


/*Check arguments */

{

speed= getBaudrate(baudrate);

if(speed == -1) {

/*TODO: throw an exception */

LOGI("Invalidbaudrate");

return NULL;

}

}

/*Opening device */

{

jboolean iscopy;

constchar *path_utf = (*env)->GetStringUTFChars(env, path, &iscopy);

LOGI("Openingserial port %s", path_utf);

fd= open(path_utf, O_RDWR | O_SYNC);// | O_DIRECT

LOGI("open()fd = %d,%s", fd,strerror(errno));

(*env)->ReleaseStringUTFChars(env,path, path_utf);

if(fd == -1)

{

/*Throw an exception */

LOGI("Cannotopen port");

/*TODO: throw an exception */

return NULL;

}

}

/*Configure device */

structtermios cfg;

LOGI("Configuringserial port");

//取得终端介质(fd)初始值,并把其值 赋给cfg;

if(tcgetattr(fd, &cfg))

{

LOGI("tcgetattr()failed");

close(fd);

/*TODO: throw an exception */

return NULL;

}

bzero(&cfg,sizeof(cfg));

//setting c_cflag

cfg.c_cflag &=~CSIZE;

switch(databits) /*设置数据位数*/

{

case7: cfg.c_cflag|= CS7; //7位数据位

break;

case8: cfg.c_cflag|= CS8; //8位数据位

break;

default: cfg.c_cflag|= CS8;

break;

}

switch(parity) //设置校验

{

case'n':

case'N':

cfg.c_cflag&= ~PARENB; /*输出不进行奇偶校验*/

cfg.c_iflag&= ~INPCK; /*输入不进行奇偶校验*/

break;

case'o':

case'O':

cfg.c_cflag|= (PARODD | PARENB); /*设置为奇校验*/

cfg.c_iflag|= INPCK; /* Disable parity checking */

break;

case'e':

case'E':

cfg.c_cflag|= PARENB; /* Enable parity */

cfg.c_cflag&= ~PARODD;/* 转换为偶校验*/

cfg.c_iflag|= INPCK; /* Disnable parity checking */

break;

case'S':

case's': /*as no parity*/

cfg.c_cflag&= ~PARENB;

cfg.c_cflag&= ~CSTOPB;break;

default:

cfg.c_cflag&= ~PARENB; /* Clear parity enable */

cfg.c_iflag&= ~INPCK; /* Enable parity checking */

break;

}

switch(stopbits)//设置停止位

{

case 1: cfg.c_cflag&= ~CSTOPB;

break;

case 2: cfg.c_cflag|= CSTOPB;

break;

default: cfg.c_cflag&= ~CSTOPB;

break;

}

cfg.c_cc[VTIME]= 0;

cfg.c_cc[VMIN]= 0;

cfg.c_cflag |= (CLOCAL|CREAD);

cfg.c_oflag|=OPOST;

cfg.c_iflag &=~(IXON|IXOFF|IXANY);

cfmakeraw(&cfg);

cfsetispeed(&cfg,speed);

cfsetospeed(&cfg,speed);

//丢弃要写入引用的对象,TCIFLUSH刷新收到的数据但是不读

tcflush(fd, TCIFLUSH);

//设置与终端相关的参数,TCSANOW ----改变立即发生

if(tcsetattr(fd, TCSANOW, &cfg))

{

LOGI("tcsetattr()failed");

close(fd);

/*TODO: throw an exception */

return NULL;

}


/*Create a corresponding file descriptor */

...........


return mFileDescriptor;

}


termios结构体中,该结构体一般包括如下的成员:
struct termios
{unsigned short c_iflag; /* 输入模式标志*/
unsigned short c_oflag; /* 输出模式标志*/
unsigned short c_cflag; /* 控制模式标志*/
unsigned short c_lflag; /*区域模式标志或本地模式标志或局部模式*/
unsigned char c_line; /*行控制line discipline */
unsigned char c_cc[NCC]; /* 控制字符特性*/
};


其具体意义如下

c_iflag:输入模式标志,控制终端输入方式,具体参数如下所示。

c_iflag参数表
键值说明
IGNBRK 忽略BREAK键输入
BRKINT如果设置了IGNBRK,BREAK键的输入将被忽略,如果设置了BRKINT ,将产生SIGINT中断
IGNPAR忽略奇偶校验错误
PARMRK标识奇偶校验错误
INPCK允许输入奇偶校验
ISTRIP去除字符的第8个比特
INLCR将输入的NL(换行)转换成CR(回车)
IGNCR忽略输入的回车
ICRNL将输入的回车转化成换行(如果IGNCR未设置的情况下)
IUCLC将输入的大写字符转换成小写字符(非POSIX)
IXON允许输入时对XON/XOFF流进行控制
IXANY输入任何字符将重启停止的输出
IXOFF允许输入时对XON/XOFF流进行控制
IMAXBEL当输入队列满的时候开始响铃,Linux在使用该参数而是认为该参数总是已经设置

c_oflag:输出模式标志,控制终端输出方式,具体参数如下所示。
c_oflag参数
键值说明
OPOST处理后输出
OLCUC将输入的小写字符转换成大写字符(非POSIX)
ONLCR将输入的NL(换行)转换成CR(回车)及NL(换行)
OCRNL将输入的CR(回车)转换成NL(换行)
ONOCR第一行不输出回车符
ONLRET不输出回车符
OFILL发送填充字符以延迟终端输出
OFDEL以ASCII码的DEL作为填充字符,如果未设置该参数,填充字符将是NUL(‘/0’)(非POSIX)
NLDLY换行输出延时,可以取NL0(不延迟)或NL1(延迟0.1s)
CRDLY回车延迟,取值范围为:CR0、CR1、CR2和 CR3
TABDLY水平制表符输出延迟,取值范围为:TAB0、TAB1、TAB2和TAB3
BSDLY空格输出延迟,可以取BS0或BS1
VTDLY垂直制表符输出延迟,可以取VT0或VT1
FFDLY换页延迟,可以取FF0或FF1

c_cflag:控制模式标志,指定终端硬件控制信息,具体参数如下所示。
c_oflag参数
键值说明
CBAUD波特率(4+1位)(非POSIX)
CBAUDEX附加波特率(1位)(非POSIX)
CSIZE字符长度,取值范围为CS5、CS6、CS7或CS8
CSTOPB设置两个停止位
CREAD使用接收器
PARENB使用奇偶校验
PARODD对输入使用奇偶校验,对输出使用偶校验
HUPCL关闭设备时挂起
CLOCAL忽略调制解调器线路状态
CRTSCTS使用RTS/CTS流控制


c_lflag:本地模式标志,控制终端编辑功能,具体参数如下所示。
c_lflag参数
键值说明
ISIG当输入INTR、QUIT、SUSP或DSUSP时,产生相应的信号
ICANON使用标准输入模式
XCASE在ICANON和XCASE同时设置的情况下,终端只使用大写。如果只设置了XCASE,则输入字符将被转换为小写字符,除非字符使用了转义字符(非POSIX,且Linux不支持该参数)
ECHO显示输入字符
ECHOE如果ICANON同时设置,ERASE将删除输入的字符,WERASE将删除输入的单词
ECHOK如果ICANON同时设置,KILL将删除当前行
ECHONL如果ICANON同时设置,即使ECHO没有设置依然显示换行符
ECHOPRT如果ECHO和ICANON同时设置,将删除打印出的字符(非POSIX)
TOSTOP向后台输出发送SIGTTOU信号

与此结构体相关的函数
(一)tcgetattr()
1.原型
int tcgetattr(int fd,struct termois & termios_p);
2.
功能
取得终端介质(fd)初始值,并把其值 赋给temios_p;函数可以从后台进程中调用;但是,终端属性可能被后来的前台进程所改变。


(二)tcsetattr()
1.原型
int tcsetattr(int fd,int actions,const struct termios *termios_p);
2.功能
设置与终端相关的参数 (除非需要底层支持却无法满足),使用 termios_p 引用的 termios 结构。optional_actions (tcsetattr函数的第二个参数)指定了什么时候改变会起作用:
TCSANOW:改变立即发生
TCSADRAIN:改变在所有写入 fd 的输出都被传输后生效。这个函数应当用于修改影响输出的参数时使用。(当前输出完成时将值改变)
TCSAFLUSH :改变在所有写入 fd 引用的对象的输出都被传输后生效,所有已接受但未读入的输入都在改变发生前丢弃(同TCSADRAIN,但会舍弃当前所有值)。


(三)tcsendbreak()
传送连续的 0 值比特流,持续一段时间,如果终端使用异步串行数据传输的话。如果 duration 是 0,它至少传输 0.25 秒,不会超过 0.5 秒。如果 duration 非零,它发送的时间长度由实现定义。
如果终端并非使用异步串行数据传输,tcsendbreak() 什么都不做。


(四)tcdrain()
等待直到所有写入 fd 引用的对象的输出都被传输。


(五)tcflush()
丢弃要写入 引用的对象,但是尚未传输的数据,或者收到但是尚未读取的数据,取决于 queue_selector 的值:

TCIFLUSH :刷新收到的数据但是不读
TCOFLUSH :刷新写入的数据但是不传送
TCIOFLUSH :同时刷新收到的数据但是不读,并且刷新写入的数据但是不传送

(六)tcflow()
挂起 fd 引用的对象上的数据传输或接收,取决于 action 的值:

TCOOFF :挂起输出
TCOON :重新开始被挂起的输出
TCIOFF :发送一个 STOP 字符,停止终端设备向系统传送数据
TCION :发送一个 START 字符,使终端设备向系统传输数据
打开一个终端设备时的默认设置是输入和输出都没有挂起。


(七)波特率函数
被用来获取和设置 termios 结构中,输入和输出波特率的值。新值不会马上生效,直到成功调用了 tcsetattr() 函数。
设置速度为 B0 使得 modem "挂机"。与 B38400 相应的实际比特率可以用 setserial(8) 调整。
输入和输出波特率被保存于 termios 结构中。
cfmakeraw 设置终端属性如下:
termios_p->c_iflag &= ~(IGNBRK|BRKINT|PARMRK|ISTRIP|INLCR|IGNCR|ICRNL|IXON);
termios_p->c_oflag &= ~OPOST;
termios_p->c_lflag &= ~(ECHO|ECHONL|ICANON|ISIG|IEXTEN);
termios_p->c_cflag &= ~(CSIZE|PARENB);
termios_p->c_cflag |= CS8;

1.cfgetospeed()返回 termios_p 指向的 termios 结构中存储的输出波特率
2.cfsetospeed()设置 termios_p 指向的 termios 结构中存储的输出波特率为 speed。取值必须是以下常量之一:
B0 B50 B75 B110 B134 B150 B200 B300 B600 B1200 B1800 B2400 B4800 B9600 B19200 B38400 B57600 B115200 B230400
其中:零值 B0 用来中断连接。如果指定了 B0,不应当再假定存在连接。通常,这样将断开连接。CBAUDEX 是一个掩码,指示高于 POSIX.1 定义的速度的那一些 (57600 及以上)。因此,B57600 & CBAUDEX 为非零。
3.cfgetispeed()返回 termios 结构中存储的输入波特率。
4.cfsetispeed()设置 termios 结构中存储的输入波特率为 speed。如果输入波特率被设为0,实际输入波特率将等于输出波特率。


RETURN VALUE 返回值
1.cfgetispeed() 返回 termios 结构中存储的输入波特率。
2.cfgetospeed() 返回 termios 结构中存储的输出波特率。
3.其他函数返回:
(1)0:成功
(2) -1:失败,
并且为 errno 置值来指示错误。
注意 tcsetattr() 返回成功,如果任何所要求的修改可以实现的话。因此,当进行多重修改时,应当在这个函数之后再次调用 tcgetattr() 来检测是否所有修改都成功实现


我的工程例子:


#include<stdio.h>

#include<string.h>

#include<unistd.h>

#include<fcntl.h>

#include<errno.h>

#include<termios.h>

#include<sys/time.h>


staticspeed_t getBaudrate(jint baudrate)

{

switch(baudrate){

case 0: return B0;

.....

case4800: return B4800;

case9600: return B9600;

case19200: return B19200;

case38400: return B38400;

.........

case576000: return B576000;

case1152000: return B1152000;

...

case 4000000: return B4000000;

default:return -1;

}

}




/*

*Class: cedric_serial_SerialPort

*Method: open

*Signature: (Ljava/lang/String;)V

*/

JNIEXPORTjobject JNICALL Java_com_jenny_iRelax_serialport_SerialPort_open

(JNIEnv*env, jobject thiz, jstring path, jint baudrate,,int stopbits,jint parity)

{

int fd;

speed_t speed;

jobject mFileDescriptor;


/*Check arguments */

{

speed= getBaudrate(baudrate);

if(speed == -1) {

/*TODO: throw an exception */

LOGI("Invalidbaudrate");

return NULL;

}

}

/*Opening device */

{

jboolean iscopy;

constchar *path_utf = (*env)->GetStringUTFChars(env, path, &iscopy);

LOGI("Openingserial port %s", path_utf);

fd= open(path_utf, O_RDWR | O_SYNC);// | O_DIRECT

LOGI("open()fd = %d,%s", fd,strerror(errno));

(*env)->ReleaseStringUTFChars(env,path, path_utf);

if(fd == -1)

{

/*Throw an exception */

LOGI("Cannotopen port");

/*TODO: throw an exception */

return NULL;

}

}

/*Configure device */

structtermios cfg;

LOGI("Configuringserial port");

//取得终端介质(fd)初始值,并把其值 赋给cfg;

if(tcgetattr(fd, &cfg))

{

LOGI("tcgetattr()failed");

close(fd);

/*TODO: throw an exception */

return NULL;

}

bzero(&cfg,sizeof(cfg));

//setting c_cflag

cfg.c_cflag &=~CSIZE;

switch(databits) /*设置数据位数*/

{

case7: cfg.c_cflag|= CS7; //7位数据位

break;

case8: cfg.c_cflag|= CS8; //8位数据位

break;

default: cfg.c_cflag|= CS8;

break;

}

switch(parity) //设置校验

{

case'n':

case'N':

cfg.c_cflag&= ~PARENB; /*输出不进行奇偶校验*/

cfg.c_iflag&= ~INPCK; /*输入不进行奇偶校验*/

break;

case'o':

case'O':

cfg.c_cflag|= (PARODD | PARENB); /*设置为奇校验*/

cfg.c_iflag|= INPCK; /* Disable parity checking */

break;

case'e':

case'E':

cfg.c_cflag|= PARENB; /* Enable parity */

cfg.c_cflag&= ~PARODD;/* 转换为偶校验*/

cfg.c_iflag|= INPCK; /* Disnable parity checking */

break;

case'S':

case's': /*as no parity*/

cfg.c_cflag&= ~PARENB;

cfg.c_cflag&= ~CSTOPB;break;

default:

cfg.c_cflag&= ~PARENB; /* Clear parity enable */

cfg.c_iflag&= ~INPCK; /* Enable parity checking */

break;

}

switch(stopbits)//设置停止位

{

case 1: cfg.c_cflag&= ~CSTOPB;

break;

case 2: cfg.c_cflag|= CSTOPB;

break;

default: cfg.c_cflag&= ~CSTOPB;

break;

}

cfg.c_cc[VTIME]= 0;

cfg.c_cc[VMIN]= 0;

cfg.c_cflag |= (CLOCAL|CREAD);

cfg.c_oflag|=OPOST;

cfg.c_iflag &=~(IXON|IXOFF|IXANY);

cfmakeraw(&cfg);

cfsetispeed(&cfg,speed);

cfsetospeed(&cfg,speed);

//丢弃要写入引用的对象,TCIFLUSH刷新收到的数据但是不读

tcflush(fd, TCIFLUSH);

//设置与终端相关的参数,TCSANOW ----改变立即发生

if(tcsetattr(fd, TCSANOW, &cfg))

{

LOGI("tcsetattr()failed");

close(fd);

/*TODO: throw an exception */

return NULL;

}


/*Create a corresponding file descriptor */

...........


return mFileDescriptor;

}


分享到:
评论

相关推荐

    LINUXCC++串口读写串口读写[参照].pdf

    LINUX C/C++ 串口读写串口读写【参照】 Linux C/C++ 串口读写串口读写是计算机中一种常用的接口,具有连接线少,通讯简单,得到广泛的使用。本文将介绍 Linux C/C++ 串口读写的基本概念、串口操作、串口设置和波特...

    用C语言写的linux串口读写源代码com serial,适用于arm和各种linux系统

    本文将深入探讨标题和描述中提及的C语言编写的Linux串口读写源代码,以及其在ARM处理器和各类Linux系统中的应用。 首先,串口通信是一种点对点的数据传输方式,它通过串行数据线进行通信,通常用于设备调试、数据...

    linux下的串口读写

    总之,`read_seri.c`和`write_seri.c`是实现Linux串口通信的基础示例,它们展示了如何使用C语言直接操作底层设备文件进行串口读写。通过学习和理解这两个程序,开发者可以掌握在Linux环境下进行串口通信的基本技巧,...

    tty.tar.gz_linux tty examp_linux 串口_linux串口读写_串口读写

    对于串口读写,以下是一些核心知识点: 1. **打开串口**:使用 `open()` 函数打开 `/dev/ttySx` 设备文件,通常需要以非阻塞模式打开。 2. **配置串口**:使用 `tcgetattr()` 获取当前设置,然后用 `cfsetospeed()`...

    linux串口termios.pdf

    Linux中的termios接口提供了一组操作终端设备的函数,它允许用户获取和设置串口设备的属性。termios结构体和相关函数在处理串口通信时起着关键作用,允许程序员精确控制串口的配置。接下来,我们将详细探讨termios...

    Linux_串口读写

    ### Linux串口读写知识点详解 #### 一、串口简介与标准 串行口,作为计算机硬件中不可或缺的一部分,自其诞生以来便在数据通信领域占据着举足轻重的地位。尤其对于早期的计算机系统而言,串口是实现设备间通信的...

    串口读写Linux_C_C++ .doc

    本文将详细介绍如何使用C或C++进行Linux串口的读写操作。 首先,串行口RS-232-C是一种广泛应用于计算机和其他设备之间的通信接口标准,由美国电子工业协会(EIA)制定。该标准定义了25针DB25连接器上的引脚功能,...

    linux串口编程从驱动到应用

    Linux 系统中,串口读写主要通过 `termios` 结构体实现的。开发者可以使用 `termios` 结构体来设置串口的参数,例如波特率、数据位、停止位等。 四、RTS 引脚的控制 在 Linux 系统中,RTS 引脚的控制主要通过 `...

    linuxserial.rar_linux 串口读写

    本文将深入探讨Linux下的串口读写,并基于提供的`uart.c.bak`和`uart.c`文件,讲解如何实现串口通信。 首先,串口通信,也称为UART(通用异步接收/发送器),是一种异步通信协议,允许两个设备通过串行数据链路进行...

    linux serial port 串口读写函数

    本文将深入探讨Linux下的串口读写函数,以及如何基于这些函数进行其他应用的开发。 首先,Linux中的串口通常通过/dev/ttyS*设备文件来访问,其中*ttyS*代表串行端口,例如/dev/ttyS0表示第一个串口。在进行串口编程...

    Linux_C_C++串口读写串口读写

    在Linux中,串口通信被抽象为文件,可以通过标准的文件操作函数进行读写。例如,打开串口可以使用`open()`函数,传入/dev下的相应串口文件,如/dev/ttyS0表示串口一。例如: ```c int fd; fd = open("/dev/ttyS0", ...

    Linux下简单的串口读写程序编写

    Linux下简单的串口读写程序编写 Linux 操作系统中,串口通信是常用的通信方式之一。串口通信可以实现设备之间的数据交换,例如,电脑与串口设备之间的数据交换。在 Linux 系统中,串口通信通过文件描述符来实现,...

    tty.zip_linux 串口_linux 串口API_linux的串口_tty linux_串口 linux

    描述中提到的"linux下串口操作API,编写的一个简单linux下串口操作程序,可供参考"意味着我们将讨论如何通过编程来操作Linux串口。通常,开发者会使用C语言来编写这类程序,因为C语言可以方便地调用底层的系统调用。...

    linux 串口类(c/c++)

    Linux串口编程简介 #### 1.1 串口设备的应用背景 - **工控领域**:工业控制系统经常需要通过串口与外部设备进行数据交换。 - **嵌入式设备**:嵌入式系统通常也包含串口作为其基本通信接口之一。 #### 1.2 为什么...

    Linux 下串口标准读写

    本文将详细讲解如何在Linux环境下进行串口标准读写,以及涉及的相关程序。 首先,理解串口通信的基础概念是必要的。串口,即串行接口,通常指的是UART(Universal Asynchronous Receiver/Transmitter,通用异步收发...

    Linux 串口通信实例

    综上所述,Linux串口通信涉及到硬件接口、串口参数配置、数据读写以及相关编程。通过掌握这些知识,开发者能够有效地在Linux系统中实现设备间的串口通信,如嵌入式开发、物联网应用、调试工具等。对于`Android.mk`、...

    Linux串口通讯调试助手

    2. **性能监控**:检查串口读写速度,优化数据传输效率。 3. **异常处理**:完善异常处理机制,提高程序健壮性。 4. **实时性**:对于实时性要求高的应用,要考虑中断处理和实时调度。 六、实际应用 Linux串口...

    经典linux c语言 串口读写 以及UDP读写 例程

    本文将详细解析"经典linux c语言 串口读写 以及UDP读写 例程"的相关知识点。 首先,让我们关注串口通信。在Linux环境下,串口通信通常通过标准输入/输出流(stdio)或者低级I/O函数(如open、read、write、close等...

    linux串口编程实例

    1. **Linux串口基础**: - Linux中的串口通常指的是TTY设备,如/dev/ttyS0, /dev/ttyUSB0等,它们是系统中与串行通信硬件交互的接口。 - 串口通信的两个基本参数是波特率(baud rate)和数据位(data bits),还有...

    嵌入式linux串口终端测试程序

    编译嵌入式Linux串口程序通常需要包含头文件如&lt;termios.h&gt;,并使用函数如tcgetattr()和tcsetattr()来设置串口属性,open()和close()来打开和关闭串口,write()和read()来进行数据传输。在编译时,可能需要链接诸如-...

Global site tag (gtag.js) - Google Analytics