关于串口通信的问题 急啊!!!

haitukeji 2013-01-30 03:49:30
我写一个串口通信的代码,通过串口发送数据,首先申明硬件已经通了,就是发送的时候发送不出去,接收端显示不出数据,接受端也是正确的,通过发送工具发送是可以的,代码如下,请指教一下为什么我发送不出去!哪里设置可能出问题了。
void set_speed(int fd, int speed)
{
struct termios Opt;
tcgetattr(fd, &Opt);
for(int 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]);
int status = tcsetattr(fd, TCSANOW, &Opt);
if(status != 0) perror("tcsetattr fd1");
return;
}
tcflush(fd,TCIOFLUSH);
}
}

int set_parity(int fd, int databits, int stopbits, int parity)
{
struct termios options;
if ( tcgetattr( fd,&options) != 0)
{
perror("SetupSerial 1");
return(FALSE);
}
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 (FALSE);
}
switch (parity)
{
case 'n':
case 'N':
options.c_cflag &= ~PARENB;
options.c_iflag &= ~INPCK;
break;
case 'o':
case 'O':
options.c_cflag |= (PARODD | PARENB);
options.c_iflag |= INPCK;
break;
case 'e':
case 'E':
options.c_cflag |= PARENB;
options.c_cflag &= ~PARODD;
options.c_iflag |= INPCK;
break;
case 'S':
case 's':
options.c_cflag &= ~PARENB;
options.c_cflag &= ~CSTOPB;
break;
default:
fprintf(stderr,"Unsupported parity\n");
return (FALSE);
}

switch (stopbits)
{
case 1:
options.c_cflag &= ~CSTOPB;
break;
case 2:
options.c_cflag |= CSTOPB;
break;
default:
fprintf(stderr,"Unsupported stop bits\n");
return (FALSE);
}


if(parity != 'n') options.c_iflag |= INPCK;
options.c_cc[VTIME] = 150;
options.c_cc[VMIN] = 0;

tcflush(fd,TCIFLUSH);
if (tcsetattr(fd,TCSANOW,&options) != 0)
{
perror("SetupSerial 3");
return (FALSE);
}
return (TRUE);
}

int port_in()
{
if(fd != 0){
char data[8];
int i = read(fd, data, sizeof(data));
printf("recv i=%d\n",i);
for(int j=0;j<i;j++){
printf("recv %d\n",data[i]);
}
printf("\n");
}
}
int port_in_w(){
while(fd != 0){
port_in();
}
}
void disable_terminal_return(int fd)
{
struct termios newt;

tcgetattr(fd, &newt);

newt.c_lflag &= ~(ICANON | ECHO);

tcsetattr(fd, TCSANOW, &newt);
}
void check_port_open(unsigned baud)
{
if(fd == 0){
char * dev ="/dev/ttyAMA1";
fd = open(dev, O_RDWR);
if(-1 == fd)
{
fd = 0;
printf("Can't Open Serial Port!\n");
return;
}
else
{
printf("dev=%s\n",dev);
}

set_speed(fd, baud);
set_parity(fd, 8, 1, 'N');
disable_terminal_return(fd);
}
}

int port(unsigned baud, char *data, int data_length)
{
// printf("send len=%d\n", data_length);
for(int i = 0; i < data_length; ++i){
printf("sned %d\n",data[i]);
}
printf("\n");

check_port_open(baud);

if(fd != 0){
write(fd, data, data_length);
}
printf("send buffer\n");
}

void close_port()
{
if(fd == 0)return;
close(fd);
fd = 0;
}


int main()
{
char buffer[3];
buffer[0]=1;
buffer[1]=2;
buffer[2]=3;
printf("buffer0=%d,buffer1=%d,buffer2=%d\n",buffer[0],buffer[1],buffer[2]);
port(9600,buffer,3);
while(1){
port(9600,buffer,3);
sleep(2);
}
return 0;
}

...全文
244 4 点赞 打赏 收藏 举报
写回复
4 条回复
切换为时间正序
当前发帖距今超过3年,不再开放新的回复
发表回复
wjb955201 2014-02-14
引用 2 楼 Wang_sir 的回复:
先用示波器量TX、RX上有没有数据信号, 如果TX、RX都没有,则为发送有问题,检测自己的软件代码。 如果TX、RX都有,则硬件没有问题,发送也没有问题,检查自己的接收buffer内数据是否有变化,以及timeout设定是不是太短。 如果TX有RX没有,则是硬件收到数据没有发送数据回来或者硬件收到了错误的数据,检查软件对发送数据的设置和硬件端接收的设置。
这个兄弟一看就做的项目挺多, 软硬件都懂.
  • 打赏
  • 举报
回复
reaibiancheng 2013-09-24
这是在什么平台上写的串口程序啊?
  • 打赏
  • 举报
回复
Jackshengwang 2013-01-30
先用示波器量TX、RX上有没有数据信号, 如果TX、RX都没有,则为发送有问题,检测自己的软件代码。 如果TX、RX都有,则硬件没有问题,发送也没有问题,检查自己的接收buffer内数据是否有变化,以及timeout设定是不是太短。 如果TX有RX没有,则是硬件收到数据没有发送数据回来或者硬件收到了错误的数据,检查软件对发送数据的设置和硬件端接收的设置。
  • 打赏
  • 举报
回复
zhaokai115 2013-01-30
linux的console编程不太懂,串口一般就是波特率、数据位、停止位、校验位以及流控方式。这几个参数两边match了就没太大问题。 还有你的buffer里还是填几个可显示字符比如‘a’,‘b’,‘c’之类的吧,也许你已经接收到了,只是1,2,3不能显示出来而已。
  • 打赏
  • 举报
回复
相关推荐
发帖
驱动开发/核心开发
加入

2.1w+

社区成员

硬件/嵌入开发 驱动开发/核心开发
申请成为版主
帖子事件
创建了帖子
2013-01-30 03:49
社区公告
暂无公告