社区
Linux/Unix社区
帖子详情
***关于串口通信的问题!***
reso
2004-05-13 10:06:53
请问:
如何计算用串口发送一个字符串的cpu使用率(串口通信是使用一个线程实现的)?我的发送数据是用write实现的,但我想write只是将数据发送的发送缓冲区,并不表示通信已经完成。能否给一个简单程序?
谢谢!!
...全文
202
7
打赏
收藏
***关于串口通信的问题!***
请问: 如何计算用串口发送一个字符串的cpu使用率(串口通信是使用一个线程实现的)?我的发送数据是用write实现的,但我想write只是将数据发送的发送缓冲区,并不表示通信已经完成。能否给一个简单程序? 谢谢!!
复制链接
扫一扫
分享
转发到动态
举报
写回复
配置赞助广告
用AI写文章
7 条
回复
切换为时间正序
请发表友善的回复…
发表回复
打赏红包
vctony
2004-07-02
打赏
举报
回复
up一下
kzlong
2004-07-02
打赏
举报
回复
#include <stdio.h> /*标准输入输出定义*/
#include <stdlib.h> /*标准函数库定义*/
#include <unistd.h> /*Unix标准函数定义*/
#include <sys/types.h> /**/
#include <sys/stat.h> /**/
#include <fcntl.h> /*文件控制定义*/
#include <termios.h> /*PPSIX终端控制定义*/
#include <errno.h> /*错误号定义*/
#include <sys/ioctl.h>
/***@brief 设置串口通信速率
*@param fd 类型 int 打开串口的文件句柄
*@param speed 类型 int 串口速度
*@return void*/
int speed_arr[] = { B38400, B19200, B9600, B4800, B2400, B1200, B300,
B38400, B19200, B9600, B4800, B2400, B1200, B300, };
int name_arr[] = {38400, 19200, 9600, 4800, 2400, 1200, 300,
38400, 19200, 9600, 4800, 2400, 1200, 300, };
void set_speed(int fd, int speed)
{
int i;
int status;
struct termios Opt;
tcgetattr(fd, &Opt);
for ( i= 0; i < sizeof(speed_arr) / sizeof(int); i++)
{
if (speed == name_arr[i])
{
tcflush(fd, TCIOFLUSH);
cfsetispeed(&Opt, speed_arr[i]);
cfsetospeed(&Opt, speed_arr[i]);
status = tcsetattr(fd, TCSANOW, &Opt);
if (status != 0)
perror("tcsetattr fd1");
return;
}
tcflush(fd,TCIOFLUSH);
}
}
/**
*@brief 设置串口数据位,停止位和效验位
*@param fd 类型 int 打开的串口文件句柄*
*@param databits 类型 int 数据位 取值 为 7 或者8*
*@param stopbits 类型 int 停止位 取值为 1 或者2*
*@param parity 类型 int 效验类型 取值为N,E,O,,S
*/
int set_Parity(int fd,int databits,int stopbits,int parity)
{
struct termios options;
if ( tcgetattr( fd,&options) != 0)
{
perror("SetupSerial 1");
return(0);
}
options.c_cflag &= ~CSIZE;
switch (databits) /*设置数据位数*/
{
case 7:
options.c_cflag |= CS7;
break;
case 8:
options.c_cflag |= CS8;
break;
default:
fprintf(stderr,"Unsupported data size\n");
return (0);
}
switch (parity)
{
case 'n':
case 'N':
options.c_cflag &= ~PARENB; /* Clear parity enable */
options.c_iflag &= ~INPCK; /* Enable parity checking */
break;
case 'o':
case 'O':
options.c_cflag |= (PARODD | PARENB); /* 设置为奇效验*/
options.c_iflag |= INPCK; /* Disnable parity checking */
break;
case 'e':
case 'E':
options.c_cflag |= PARENB; /* Enable parity */
options.c_cflag &= ~PARODD; /* 转换为偶效验*/
options.c_iflag |= INPCK; /* Disnable parity checking */
break;
case 'S':
case 's': /*as no parity*/
options.c_cflag &= ~PARENB;
options.c_cflag &= ~CSTOPB;
break;
default:
fprintf(stderr,"Unsupported parity\n");
return (0);
}
/* 设置停止位*/
switch (stopbits)
{
case 1:
options.c_cflag &= ~CSTOPB;
break;
case 2:
options.c_cflag |= CSTOPB;
break;
default:
fprintf(stderr,"Unsupported stop bits\n");
return (0);
}
/* Set input parity option */
if (parity != 'n')
options.c_iflag |= INPCK;
options.c_cc[VTIME] = 150; // 15 seconds
options.c_cc[VMIN] = 0;
tcflush(fd,TCIFLUSH); /* Update the options and do it NOW */
if (tcsetattr(fd,TCSANOW,&options) != 0)
{
perror("SetupSerial 3");
return (0);
}
return (1);
}
/**
*@breif 打开串口
*/
int OpenDev(char *Dev)
{
int fd = open( Dev, O_RDWR | O_NOCTTY | O_NDELAY);
if (-1 == fd)
{
perror("Can't Open Serial Port");
return -1;
}
else
return fd;
}
/**
*@breif main()
*/
kbhit()
{
int n;
ioctl(0, FIONREAD, &n);
return n;
}
int main(int argc, char **argv)
{
int fd;
int c;
int nread;
char buff[100];
char *dev ="/dev/ttyS0";
fd = OpenDev(dev);
if (fd>0)
{
set_speed(fd,9600);
printf("open success\n");
}
else
{
printf("Can't Open Serial Port!\n");
exit(0);
}
if (set_Parity(fd,8,1,'N')== 0)
{
printf("Set Parity Error\n");
exit(1);
}
else
{
printf("Set Parity Success\n");
}
system("stty raw");
while(1){
if(kbhit())
{
c=getchar();
if(c=='q')
{
printf("exit\n");
system("stty cooked");
exit(1);
}
else if(c=='c')//call
{
nread=write(fd,buff,5);
if(nread>0)
{
printf("->%s\n",buff);
}
else
{
printf("!sent error\n");
}
}
else if(c=='s')//sms
{
}
else if(c=='d')//data
{
}
}
if((nread = read(fd,buff,100))>0)
{
//printf("\nLen %d\n",nread);
buff[nread]='\0';
printf("%s\r\n",buff);
}
}
//close(fd);
//exit(0);
}
tengulre
2004-07-01
打赏
举报
回复
UP
leemuxiang
2004-07-01
打赏
举报
回复
http://www-900.ibm.com/developerWorks/cn/linux/l-serials/index.shtml
aaronwjj
2004-06-26
打赏
举报
回复
我也想要串口通信的程序,各位大侠,能不能帮帮忙!
zky
2004-05-13
打赏
举报
回复
open设备时使用O_NOCTTY | O_NDELAY即可。
reso
2004-05-13
打赏
举报
回复
各位大侠帮帮忙啊!!
SCI串行通讯接口程序
//*******************接收字节 char RecChar() { byte rec_char; if (SCIS1_RDRF) //清除RDRF rec_char = SCID; // 清除RDRF第二步 SCIC2_RE = 1; // enable Rx while(!SCIS1_RDRF){ //feedCOP();...
51单片机
串口
通信
程序(pc控制输入)
看了很多
串口
通信
,应该是配置
问题
很多代码烧进去都不对,或者没有反应。 代码控制输入,
串口
输出区输出自己想要的数据,下面直接上代码:(代码亲测有效) /*****************************************************...
单片机——
串口
通信
(从
串口
接收多位数据保存到数组,发送多位数据到
串口
)
单片机
串口
通信
中,接收多位数据到数组,发送多位数据的代码 // 下面的代码用于:单片机的
串口
何上位机的
串口
进行
通信
,上位机发送的数据是“abcd”就开灯,如果是“abde”就关灯。 /*****************************...
关于
串口
通信
介绍
串口
通信
:
通信
有串行
通信
和并行
通信
两种方式。在多微机系统以及现代测控系统中信息的交换多采用串行
通信
方式。 **并行
通信
:**通常是将数据字节的各位用多条数据线同时进行传送。 优点:控制简单、传输数据快。 ...
232
通信
c语言设计,基于C语言的RS232串行接口
通信
设计与实现
摘要:
串口
通信
是一种广泛使用且实用的
通信
方式,介绍RS232串行
通信
的联结方式,研究利用c语言编程实现RS232串行
通信
的过程。结合实际应用,在约定双方串行
通信
协议的基础上,运用C语言开发的串行
通信
软件,实现了...
Linux/Unix社区
23,125
社区成员
74,509
社区内容
发帖
与我相关
我的任务
Linux/Unix社区
Linux/Unix社区 应用程序开发区
复制链接
扫一扫
分享
社区描述
Linux/Unix社区 应用程序开发区
社区管理员
加入社区
获取链接或二维码
近7日
近30日
至今
加载中
查看更多榜单
社区公告
暂无公告
试试用AI创作助手写篇文章吧
+ 用AI写文章