中国IT动力,最新最全的IT技术教程
最新100篇 | 推荐100篇 | 专题100篇 | 排行榜 | 搜索 | 在线API文档
首 页 | 程序开发 | 操作系统 | 软件应用 | 图形图象 | 网络应用 | 精文荟萃 | 教育认证 | 硬件维护 | 未整理篇 | 站长教程
ASP JS PHP工程 ASP.NET 网站建设 UML J2EESUN .NET VC VB VFP 网络维护 数据库 DB2 SQL2000 Oracle Mysql
服务器 Win2000 Office C DreamWeaver FireWorks Flash PhotoShop 上网宝典 CorelDraw 协议大全 网络安全 微软认证
硬件维护  CPU  主板  硬盘  内存  显卡  显示器  键盘鼠标  声卡音箱  打印机  机箱电源  BIOS  网卡  C#  Java  Delphi  vs.net2005
  当前位置:> 程序开发 > 编程语言 > C/C++
请教一个FreeBSD与Linux下串口编程的区别问题
作者:未知 时间:2005-09-13 19:22 出处:ChinaUnix.net 责编:chinaitpower
              摘要:请教一个FreeBSD与Linux下串口编程的区别问题

兄弟我对编程其实七窍通了六窍,不过最近在研究一个UPS管理程序,在Linux RedHat 7.2下,可以通过串口的RI位正确的检测到UPS市电和电池的区别,但同样的程序在FreeBSD 5.0下就行不通了。
      整个源程序如下(来自powerd):

#include <stdio.h>
#include <stdlib.h>
#include <unistd.h>
#include <fcntl.h>
#include <ctype.h>
#include <sys/types.h>
#include <sys/ioctl.h>
#include <errno.h>

int main(int argc, char **argv)
{
int fd, timeout=0;
char *me=argv[0];
uint bits, mask=~0, outb=0;


  if (argc<2 || !strcmp(argv[1],"--help") || !strcmp(argv[1],"-h"))
    {
    printf("%s: Usage: \"%s <device> [options]\"\n",me,me);
    printf("    <device>        is a serial device, like /dev/cua0\n"
   "    \"-rts\" \"+rts\"   clear/set Requst To Send\n"
   "    \"-dtr\" \"+dtr\"   clear/set Data Terminal Ready\n"
   "    a number        report data every that many seconds\n\n");
    exit(1);
    }

  if ((fd=open(argv[1], O_RDWR | O_NDELAY)) < 0)
    {fprintf(stderr, "%s: %s: %s\n",me,argv[1],strerror(errno));exit(1);}

  while(++argv,--argc)
    {
    if (!strcmp(*argv,"-rts") || !strcmp(*argv,"+rts"))
      {mask &= ~TIOCM_RTS; outb |= (**argv=='+' ? TIOCM_RTS : 0);}
    if (!strcmp(*argv,"-dtr") || !strcmp(*argv,"+dtr"))
      {mask &= ~TIOCM_DTR; outb |= (**argv=='+' ? TIOCM_DTR : 0);}
    if (isdigit(**argv))
      timeout=atoi(*argv);
    }

  ioctl(fd,TIOCMGET,&bits); bits&=mask; bits|=outb; ioctl(fd,TIOCMSET,&bits);

  printf("CTS DSR RI\n"); do
    {
    ioctl(fd,TIOCMGET,&bits);
    [b:e48b5b2dd9]printf(" %i   %i   %i\n", (bits & TIOCM_CTS) != 0,
                 (bits & TIOCM_DSR) != 0, (bits & TIOCM_RI) !=0);[/b:e48b5b2dd9]
    sleep(timeout);
    }
  while(timeout);

  exit(0);
}

在Linux下:
setserial /dev/ttyS0 1 每秒钟检测一次UPS状态,当市电正常时,RI = 1,市电中断后,RI = 0,但在FreeBSD下,却没有反应,不过插上串口电缆,RI = 1,而拔下串口电缆 RI = 0,请问这是什么问题呢?为什么FreeBSD下得到的结果不一样,能够解决吗?或者提供这方面的资料也好,谢谢。

 qjlemon 回复于:2003-06-19 15:35:38
这个程序既用ioctl、fopen之类的标准调用,又用inb,outb直接读端口,感觉很混乱,在不同的平台下可能就会有不同的结果。

 NetSnake 回复于:2003-06-19 16:46:59
我找了一些串口编程资料,但好像都没有讲如何实现这样简单的获取信息的过程,例如这一段:
int gettty(void)
{
int status = 0;
int fd = 0;
int res = 0;
char device[32];
char buf[255];
struct termios oldtio, newtio;

strcpy(device,"/dev/cuaa0");
printf("the serial port is %s\n",device);
fd = open(device, O_RDONLY | O_NDELAY);
tcgetattr(fd, &oldtio);
bzero(&newtio, sizeof(newtio));
newtio.c_cflag = BAUDRATE | CS7 | CREAD | PARENB | HUPCL | CLOCAL;
tcflush(fd, TCIOFLUSH);
tcsetattr(fd, TCSANOW, &newtio);
while(1)
{
memset(buf, 0, 255);
res = read(fd, buf, 255);
printf("%s", buf);
sleep(1);
}
return(0) ;
}

执行后没有任何反应,不知道这样读取数据和获取各个位的状态有何区别和联系?

 qjlemon 回复于:2003-06-19 17:04:01
这个通过标准的调用可能是不行的。标准的系统调用对硬件做了一些抽象,一些特殊的状态可能就得不到了。如果全部用inb,outb实现可能就没问题。

 NetSnake 回复于:2003-06-20 08:33:56
我用了
     ioctl(fd, TIOCMGET, &bits)
     循环读取信息,发现可以,当市电OK时bits = 133,市电中断时bits = 5,已经可以用了,只是对很多细节不了解。

 无双 回复于:2003-06-30 14:10:14
学习串口编程的可以参考一下

关闭本页
 
首页 | 投资与合作 | 服务条款 | 隐私政策 | 收藏本站 | 设为首页 | 新用户注册 | 免责声明 | 使用帮助
Copyright ©2005-2008 chinaitpower.com All rights reserved. www.chinaitpower.com 版权所有