在ubuntu 12.04中使用C向teltonika GSM调制解调器发送AT命令

时间:2014-04-08 14:27:06

标签: c linux

您好我正在尝试使用我的ubuntu桌面的com端口(ttyS0)将AT命令发送到teltonika gsm调制解调器。问题是没有得到“OK”回复AT命令(或任何其他命令或字符串),相同的AT命令回送回来。在这方面的任何帮助将不胜感激。以下是C代码:

#include <sys/types.h>                                                  
#include <sys/stat.h>                                                      
#include <fcntl.h>                                                       
#include <termios.h>                                                    
#include <stdio.h> 
#include <string.h>
#include <stdlib.h>
#include <unistd.h> 
#include <time.h>
#include <errno.h>   
#define BAUDRATE B115200
#define COM1 "/dev/ttyS0"
static int fd;
static struct termios oldtio,newtio;

//==============================================================
int tty_read(char *buf1,int nbytes)
{
int temp;
temp = read(fd,buf1,nbytes);
printf("Read string: %s\n", buf1);
return temp;
}
//==============================================================
int tty_end()
{
tcsetattr(fd,TCSANOW,&oldtio);
close(fd);
}
//==============================================================
int tty_writecmd(char *buf,int nbytes)
{ 

write(fd,buf,nbytes);

usleep(1000);
return tcdrain(fd);
}
//==============================================================
int baud = B115200;
int tty_init()
{
fd = open(COM1, O_RDWR );
if (fd <0) {
  perror(COM1);
  exit(1);
}
tcgetattr(fd,&oldtio);
bzero(&newtio, sizeof(newtio)); 
newtio.c_cflag = baud | CRTSCTS | CS8 | CLOCAL | CREAD ;

newtio.c_iflag = IGNPAR | ICRNL; 
newtio.c_oflag = 0; 
newtio.c_lflag = ICANON;
newtio.c_cc[VINTR]    = 0;     
newtio.c_cc[VQUIT]    = 0;     
newtio.c_cc[VERASE]   = 0;     
newtio.c_cc[VKILL]    = 0;    
newtio.c_cc[VEOF]     = 4;     
newtio.c_cc[VTIME]    = 0;
newtio.c_cc[VMIN]     = 1;
newtio.c_cc[VSWTC]    = 0;     
newtio.c_cc[VSTART]   = 0;     
newtio.c_cc[VSTOP]    = 0;
newtio.c_cc[VSUSP]    = 0; 
newtio.c_cc[VEOL]     = 0;
newtio.c_cc[VREPRINT] = 0; 
newtio.c_cc[VDISCARD] = 0;
newtio.c_cc[VWERASE]  = 0;
newtio.c_cc[VLNEXT]   = 0;
newtio.c_cc[VEOL2]    = 0; 
tcflush(fd, TCIFLUSH);
tcsetattr(fd,TCSANOW,&newtio);
return 0;
}
int main(int argc, char *argv[])
{ int wr,rd;
char *buff;
char recv[15];
char command[] = "AT\r\n";
tty_init();
printf("Write: %d\n", tty_writecmd(command, sizeof(command)));

usleep(10000);
printf("Read: %d\n", tty_read(recv ,sizeof(recv)));
tty_end();
}

and the output is like
write:0
Read string: AT
Read:3

由于 P.S:在Ubuntu桌面中发生此行为,程序从VMware Station中的串行端口读取任何内容。

1 个答案:

答案 0 :(得分:0)

而不是usleep(10000); 使用 usleep(1000);