VXWORKS串口设置说明:

一般有这么几步:

打开串口

设置串口raw模式,清空输入输出的缓冲区

设置波特率,数据位,停止位,校验方式

便可以开始读和写

打开串口:

fd = open("/tyCo/0", O_RDWR, 0);

"/tyCo/0" 串口1的设备名,O_RDWR:open for reading and writing

设置串口raw模式,清空输入输出的缓冲区

ioctl(fd,FIOSETOPTIONS,OPT_RAW);

ioctl(fd,FIOFLUSH,0);

ioctl(int fd,int function,int arg);这个函数解释如下:

function这个参数有如下:(tty)

FIOBAUDRATE

设置波特率,arg为一整数,表示要设定的波特率

FIOGETOPTIONS

取得设备控制字,arg表示读出的内容存放的位置

FIOSETOPTIONS

设置设备控制字,arg表示要设置的选项

FIOGETNAME

取得文件描述符对应的文件名,arg存放文件名的缓冲区

FIOREAD

取得输入缓冲区内未读取的字符数,arg用于接收结果的整型指针

FIOWRITE

取得输出缓冲区内的字符个数,arg用于接收结果的整型指针

FIOFLUSH

清空输入输出缓冲区的字符

FIOCANCEL

取消读和写

FIOSETOPTIONS对应的arg有 OPT_LINE,OPT_RAW,OPT_ECHO等等

关于这些的定义,可以在sioLib.h,ioLib.h里寻找。

设置波特率,数据位,停止位,校验方式

STOPB:两位停止位,默认是1位停止位。PARENB使能校验,PARODD奇校验,使能后默认是偶校验,未使能则是无校验

CS5,CS6,CS7,CS8:5,6,7,8位数据位

如:CS8|PARENB :8位数据位,1位停止位,偶校验;

CS8|PARENB|PARODD:8位数据位,1位停止位,奇校验;

CS8 :8位数据位,1位停止位,无校验;

CS8|STOPB:8位数据位,2位停止位,无校验;

int SerialOps = 0;

ioctl(fd,FIOBAUDRATE,9600); //9600波特率

SerialOps |= CS8;//8数据位,1位停止位,无校验

ioctl(fd,SIO_HW_OPTS_SET,SerialOps);//设置

SIO_HW_OPTS_SET(设置硬件选项)是在XXDrv里的function

SIO_HW_OPTS_SET对应的arg:

CLOCAL

忽略modem控制信号

CREAD

启动接收器

CSIZE

指定数据位:CS5~CS8

HUPCL

最后关闭时挂断modem连接

STOPB

被设置时指定2位停止位,否则1位停止位

PARENB

被设置时启用奇偶校验,否则不进行奇偶校验

PARODD

被设置时启用奇校验,否则偶校验

(PARENB被设置时才有效)

可以开始读写

int read

(

int    fd,                /* file descriptor from which to read */

char * buffer,            /* pointer to buffer to receive bytes */

size_t maxbytes           /* max no. of bytes to read into buffer */

)

int write

(

int    fd,                /* file descriptor on which to write */

char * buffer,            /* buffer containing bytes to be written */

size_t nbytes             /* number of bytes to write */

)

关于串口的设置,需要参考tty和xxDrv。详细的还是需要看书的。

下面举个例子:在有些的设置需要如下:

fd=open(tyco,2,0);

logMsg("/n%s;fd=%d/n",tyco,fd,0,0,0,0);

ioctl(fd, FIOOPTIONS, OPT_RAW);

ioctl(fd,FIOBAUDRATE,115200); //设置串口波特率为9600bps

ioctl(fd,FIOFLUSH,0);//清空输入输出缓冲

//ioctl(fd,SIO_HW_OPTS_SET,CS8|PARENB|PARODD|CLOCAL|CREAD); //设置 8 位数据位,1位停止位,带校验位,奇校验,没有流控制CLOCAL,使能读CREAD

//ioctl(fd,SIO_HW_OPTS_SET,CS8|PARENB|CLOCAL|CREAD); //设置 8 位数据位,1位停止位,带校验位,偶校验,没有流控制CLOCAL,使能读CREAD

ioctl(fd,SIO_HW_OPTS_SET,CS8|CLOCAL|CREAD); //设置 8 位数据位,1位停止位,带校验位,无校验,没有流控制CLOCAL,使能读CREAD

write(fd,str,48);//需放在清缓存后,mpc8280不用。和SIO_HW_OPTS_SET之后,因为会reset串口

上面粗字体,需要注意。有些需要,有些不需要的。

#include <ioLib.h>
#include <stdio.h>
#include <taskLib.h>
#include <sioLib.h>
#include <string.h>

/*ioctl(com2_Fd,FIOSETOPTIONS,OPT_RAW);*/
int tyRecv(int fd,int fd2)
{
	int readCnt1;
	char rd;
    char buff[512];
	int i;
	FOREVER
	{
		i=0;
		taskDelay(25);
		ioctl(fd,FIONREAD,&readCnt1); /* 判断com1接收数据缓冲区是否有数据到来 */
		if(readCnt1>0)
		{
			while(readCnt1>0)
			{
				read(fd,&rd,1);
				readCnt1--;
				buff[i++]=rd;
				taskDelay(1);
			}
			buff[i]='\0';
			printf("read1 [%s] \n",buff);
		}

		i=0;
		taskDelay(25);
		ioctl(fd2,FIONREAD,&readCnt1); /* 判断com2接收数据缓冲区是否有数据到来 */
		if(readCnt1>0)
		{
			while(readCnt1>0)
			{
				read(fd2,&rd,1);
				readCnt1--;
				buff[i++]=rd;
				taskDelay(1);
			}
			buff[i]='\0';
			printf("read2 [%s] \n",buff);
		}
	}
}
int tySend(int fd,int fd2)
{
	int wrtCount,i;
	char buff[]="  I am god of war!"; /* 发送内容 */
	for(i=0;i<10;i++)
	{
		buff[0] = '1'+i;
		wrtCount = write(fd,buff,strlen(buff));
		printf("write1 %d bytes \n",wrtCount); /* 写com1口,然后数据就会通过串口直连线发送到com2方了 */
		taskDelay(60);
		buff[0] = 'a'+i;
		wrtCount = write(fd2,buff,strlen(buff));
		printf("write2 %d bytes \n",wrtCount); /* 写com2口,然后数据就会通过串口直连线发送到com2方了 */
		taskDelay(60);
	}
}

int com1_Fd,com2_Fd;
int taskID;
int taskID2;
int test()
{

	com1_Fd = open("/tyCo/0",2,0) ; /* 打开串口0,即serial<->com1 */
	com2_Fd = open("/tyCo/1",2,0); /* 打开串口1,即serial2<->com2 */

	ioctl(com1_Fd,FIOSETOPTIONS,OPT_RAW);
	ioctl(com2_Fd,FIOSETOPTIONS,OPT_RAW);
	/* 设置串口0,亦即com1的波特率9600,8数据为,1停止位,无校验位 */
	if ( ERROR==ioctl(com1_Fd,FIOBAUDRATE,9600) )
	{
		printf("can not set BAUDRATE!\n") ;
		return ERROR ;
	}
	if ( ERROR==ioctl(com1_Fd,SIO_HW_OPTS_SET,(CLOCAL|CREAD|CS8)&~(HUPCL|STOPB|PARENB)))
	{
		printf("can not set OPT!\n") ;
		return ERROR ;
	}
	ioctl(com1_Fd,FIOFLUSH,0);

	/* 设置串口1,亦即com2的波特率9600,8数据为,1停止位,无校验位 */
	if ( ERROR==ioctl(com2_Fd,FIOBAUDRATE,9600) )
	{
		printf("can not set BAUDRATE!\n") ;
		return ERROR ;
	}
	if ( ERROR==ioctl(com2_Fd,SIO_HW_OPTS_SET,(CLOCAL|CREAD|CS8)&~(HUPCL|STOPB|PARENB)))
	{
		printf("can not set OPT!\n") ;
		return ERROR ;
	}
	ioctl(com2_Fd,FIOFLUSH,0);

	printf("com1:0x%x  com2:0x%x!\n",com1_Fd,com2_Fd) ;
	/* 发起接受数据的任务 */

	taskID = taskSpawn("recv",60,0,0x2000,(FUNCPTR)tyRecv,com1_Fd,com2_Fd,0,0,0,0,0,0,0,0);
	/* 发起发送数据的任务*/
	taskSpawn("send",80,0,0x2000,(FUNCPTR)tySend,com1_Fd,com2_Fd,0,0,0,0,0,0,0,0);

}

void del()
{
	taskDelete(taskID);
	/*taskDelete(taskID2);*/
	close(com1_Fd);
	close(com2_Fd);
}

vxworks下的串口测试程序的更多相关文章

  1. Linux下的串口编程及非阻塞模式

    本篇介绍了如何在linux系统下向串口发送数据.包括read的阻塞和非阻塞.以及select方法. 打开串口 在Linux系统下,打开串口是通过使用标准的文件打开函数操作的. #include < ...

  2. [小技巧] shell 下查看串口是否工作正常

    在 Linux 下调试串口,是个麻烦的事情,尤其是嵌入式环境,很多时候要借助另一台设备来进行调试. 这里琢磨出一种可行的串口调试方法,可以简单的查看串口是否在正确工作. 1. 短接 tx 和 rx,让 ...

  3. Mac下的串口通信-ORSSerialPort

    ================================2015/11/05======================================= 最近在工作中遇到有关Mac下串口通信 ...

  4. vxworks下网络编程一:网络字节序问题

    inet_addr("192.168.1.1");//返回网络字节序整型ip地址inet_ntoa(saddr);//将包含网络字节序整型ip地址的in_addr对象转换成本地ch ...

  5. linux下查看串口信息

    rs232串口通信接口:当通信距离较近时(<12m),可以使用电缆线直接连接,若距离较远,需附加调制解调器. 9个脚针的定义: CDC数据载波检测,RXD接收数据,TXD发送数据,DTR数据中断 ...

  6. MFC下对串口的操作以及定时器的调用

    最近研究了一下MFC下对串口的操作,测试了一下对设备的读写. 1.打开串口 GetDlgItem(IDC_BUTTON_OPEN)->EnableWindow(FALSE); m_hComm = ...

  7. VxWorks下USB驱动总结2

    3:USBD驱动详解 这一部分将要描述USBD(USB Host Driver)的典型应用.例如初始化,client注册,动态连接注册,设备配置,数据传输,同时还探讨了USBD内部设计的关键特性.这部 ...

  8. Vxworks下的SATA提速

    1.       ATA接口的三种数据传输方式 (1)PIO(Programmable Input-Output)传输,可以分为PIO寄存器传输和PIO数据传输.PIO寄存器传输主要用于对ATA设备中 ...

  9. vxWorks下dosFs文件系统的创建

    .cdromFs:允许系统从按照ISO9660标准文件系统格式化的CD-ROM上读取设备: 通常文件系统驱动位于磁盘(块存取)设备驱动和IO系统之间,这一点在VxWorks中也不例外,但它在此基础上扩 ...

随机推荐

  1. softmax_cross_entropy_with_logits

    softmax_cross_entropy_with_logits 原创文章,请勿转载 函数定义 def softmax_cross_entropy_with_logits(_sentinel=Non ...

  2. Tomcat日志与Log4j日志

    一:日志作用 更好的调试,分析问题. 普通的一个请求处理10秒钟,日志10秒钟,总共就得20秒钟,这肯定是不行的,因为日志严重影响了性能.所以,我们就有必要了解日志的实现方式,以及它是如何降低IO的时 ...

  3. srs2录制flv文件metadata不准确

    测试环境:server:srs2client:librestreaming / yasea srs 配置 dvr录制24分钟flv文件. e:\flv $ ll total drwxr-xr-x Ad ...

  4. console引起的eclipse 僵死/假死 问题排查及解决[转]

    原文链接:http://www.iteye.com/topic/1133941 症状: 使用Eclipse win 64位版本,indigo及kepler都重现了,使用tomcat 6.0.39,jd ...

  5. BZOJ 2938: [Poi2000]病毒 [AC自动机 拓扑排序]

    2938: [Poi2000]病毒 题意:判断是否存在无限长的不含模式串的字符串.只有01. 建出套路DP的转移图,判断有环就行了 练习一下拓扑排序 #include <iostream> ...

  6. 在window上安装redis

    redis没有官方的windows版本,如果需要在windows安装可以下载由微软维护的redis(https://github.com/MicrosoftArchive/redis). 在这里我们采 ...

  7. 孤立的SQL用户

    问题 最近公司很多数据库在上云,也有一部分在下云.这期间出现了很多问题,其中一个比较恶心的问题就是"孤立用户".当数据库备份还原以后用以前的用户发现不能登录.一开始以为是登录账号没 ...

  8. 测试同学难道要写一辈子的hello world?

    最近我们在测试团队内推行自动化用例责任制,大致的意思是:我们安排培训资源,提供技术支持和一对一辅导,要求每一个自主选择了自动化和接口测试发展通道的同学必须让自己负责的项目自动化用例覆盖率有所提升. 后 ...

  9. 记一次内存溢出的分析经历——thrift带给我的痛orz

    说在前面的话 朋友,你经历过部署好的服务突然内存溢出吗? 你经历过没有看过Java虚拟机,来解决内存溢出的痛苦吗? 你经历过一个BUG,百思不得其解,头发一根一根脱落的烦恼吗? 我知道,你有过! 但是 ...

  10. SCU 4438 Censor KMP/Hash

    题意:给定一个模式串和文本,要求删除所有模式串.可能删除后会形成新的模式串,必须全部删除. 思路1:kmp算法求得失配数组,用一个match数组记录文本串中第i字符和未删除的字符能匹配模式串的长度.这 ...