版主: wanchong , wangyu , eepwwp , firedom

分享到:
共5条 1/1 1   

Edison狂龙折腾记(2)

    [您是本帖的第7931位阅读者]
狱锁狂龙
我是GG
高级会员

最后登陆时间:2014-10-23 19:37:35

直达楼层
1# 发表于 2014-10-31 20:16:14

自己编了个TCP转串口的程序,发送经典字符串“Hello word!”调试如图:

饥渴的“小爱”粉丝们!我来附上TCP_serial程序:tcp_serial.zip

今天USB终于识别,不是驱动的原因,是硬件的关系,重新纠正一下之前的接口图:

当你使用power jack 供电且USB HOST POWER SWITCH 处于on时,usb才能被使用,来张设置图:

看吧终于识别了,来一张USBLCD1602显示当前时间和IP的图:

由于,opkg无法安装python pip包管理软件,移植了两天才成功,不知道为什么intel为什么不支持apt-get包管理,纠结啊……

      昨晚回去试了三个摄像头,分别是罗技的C110、中星微301(linux免驱)、还有支持MJPEG解码的天敏S608(Openwrt常用的方案),小爱只识别

C110和301摄像头,但是在dev/目录下没有video0这个设备,原因是没有webcam节点,需要自己建立节点,这就涉及到内核的编译,系统镜像的制作,

对于一个菜鸟来说,还是得保持敬仰,不能轻易挑战之!

我只能设计wifi遥控小车了,视频这一项暂时保留,等日后条件具备了在开发!由于本人没有学习过arduino单片机,不知道怎么利用arduino方案操作GPIO,

而且Edison也没有现成的GPIO库,只好通过用户空间调用GPIO了,但是有个问题来了,板子引出的GPIO序号是多少呢?Edison没有详细的说明,自己试吧!

这么多GPIO啊,够我测试一阵子的了……





此帖由狱锁狂龙于2014-11-04 11:45:50最后编辑

RE: Edison狂龙折腾记(2)

二叔
我是GG
高级会员

最后登陆时间:2014-10-23 10:40:53

2# 发表于 2014-11-01 17:20:39
程序呢?

RE: Edison狂龙折腾记(2)

colinzou
我是GG
高级会员

最后登陆时间:2014-10-28 15:12:13

3# 发表于 2014-11-03 09:22:25
狱锁狂龙的原帖
自己编了个TCP转串口的程序,发送经典字符串“Hello word!”调试如图:

大哥程序呢?

RE: Edison狂龙折腾记(2)

狱锁狂龙
我是GG
高级会员

最后登陆时间:2014-10-23 19:37:35

4# 发表于 2014-11-03 11:22:59
狱锁狂龙的原帖
自己编了个TCP转串口的程序,发送经典字符串“Hello word!”调试如图:
colinzou的原帖
大哥程序呢?

传上来了,你看附件吧
此帖由狱锁狂龙于2014-11-03 12:23:18最后编辑

RE: Edison狂龙折腾记(2)

二叔
我是GG
高级会员

最后登陆时间:2014-10-23 10:40:53

5# 发表于 2014-11-03 12:42:53
/**
 *Author:Dragon
 *QQ:915852915
 */
#include <stdio.h>
#include <stdlib.h>

#include <unistd.h>
#include <errno.h>
#include <string.h>
#include <netdb.h>
#include <sys/types.h>
#include <time.h>
#include <sys/socket.h>
#include <arpa/inet.h>

#include <string.h>
#include <sys/stat.h>
#include <fcntl.h>
#include <termios.h>

#define BUFSIZE 512

typedef struct CLIENT {
	int fd;
	struct sockaddr_in addr;
}CLIENT;

/**serial init set*/
int set_opt(int fd,int nSpeed, int nBits, char nEvent, int nStop)
{
    struct termios newtio,oldtio;
    if  ( tcgetattr( fd,&oldtio)  !=  0)
    {
        perror("SetupSerial 1");
        return -1;
    }
    bzero( &newtio, sizeof( newtio ) );
    newtio.c_cflag  |=  CLOCAL | CREAD;
    newtio.c_cflag &= ~CSIZE;

    switch( nBits )
    {
    case 7:
        newtio.c_cflag |= CS7;
        break;
    case 8:
        newtio.c_cflag |= CS8;
        break;
    }

    switch( nEvent )
    {
    case 'O':                     //奇校验
        newtio.c_cflag |= PARENB;
        newtio.c_cflag |= PARODD;
        newtio.c_iflag |= (INPCK | ISTRIP);
        break;
    case 'E':                     //偶校验
        newtio.c_iflag |= (INPCK | ISTRIP);
        newtio.c_cflag |= PARENB;
        newtio.c_cflag &= ~PARODD;
        break;
    case 'N':                    //无校验
        newtio.c_cflag &= ~PARENB;
        break;
    }

switch( nSpeed )
    {
    case 2400:
        cfsetispeed(&newtio, B2400);
        cfsetospeed(&newtio, B2400);
        break;
    case 4800:
        cfsetispeed(&newtio, B4800);
        cfsetospeed(&newtio, B4800);
        break;
    case 9600:
        cfsetispeed(&newtio, B9600);
        cfsetospeed(&newtio, B9600);
        break;
    case 115200:
        cfsetispeed(&newtio, B115200);
        cfsetospeed(&newtio, B115200);
        break;
    default:
        cfsetispeed(&newtio, B9600);
        cfsetospeed(&newtio, B9600);
        break;
    }
    if( nStop == 1 )
    {
        newtio.c_cflag &=  ~CSTOPB;
    }
    else if ( nStop == 2 )
    {
        newtio.c_cflag |=  CSTOPB;
    }
    newtio.c_cc[VTIME]  = 0;
    newtio.c_cc[VMIN] = 0;
    tcflush(fd,TCIFLUSH);
    if((tcsetattr(fd,TCSANOW,&newtio))!=0)
    {
        perror("com set error");
        return -1;
    }
    printf("set done!\n");
    return 0;
}

int open_port(int fd,int comport)
{

    if (comport==1)
    {    fd = open( "/dev/ttyS2", O_RDWR|O_NOCTTY|O_NDELAY);
        if (-1 == fd)
        {
            perror("Can't Open Serial Port");
            return(-1);
        }
        else
        {
            printf("open ttyS0 .....\n");
        }
    }
    else if(comport==2)
    {    fd = open( "/dev/ttyS1", O_RDWR|O_NOCTTY|O_NDELAY);
        if (-1 == fd)
        {
            perror("Can't Open Serial Port");
            return(-1);
        }
        else
        {
            printf("open ttyS1 .....\n");
        }
    }
    else if (comport==3)
    {
        fd = open( "/dev/ttyS2", O_RDWR|O_NOCTTY|O_NDELAY);
        if (-1 == fd)
        {
            perror("Can't Open Serial Port");
            return(-1);
        }
        else
        {
            printf("open ttyS2 .....\n");
        }
    }
    if(fcntl(fd, F_SETFL, 0)<0)
    {
        printf("fcntl failed!\n");
    }
    else
    {
        printf("fcntl=%d\n",fcntl(fd, F_SETFL,0));
    }
   //if(isatty(STDIN_FILENO)==0)
   if(isatty(fd)==0)
    {
        printf("standard input is not a terminal device\n");
    }
    else
    {
        printf("isatty success!\n");
    }
    printf("fd-open=%d\n",fd);
    return fd;
}

/**TCP_server*/
int main(int argc, char *argv[])
{
    int sockfd;
    int listenfd;
    int connectfd;

    int ret;
    int maxfd=-1;
    struct timeval tv;

    struct sockaddr_in server_addr;
    struct sockaddr_in client_addr;

    socklen_t len;
    int portnumber;

    char buf[BUFSIZE];

    int z,i,maxi = -1;

    int serial_fd = -1;
    int nread;

    fd_set rset,allset;

    CLIENT client[FD_SETSIZE];

    if(argc != 2)
    {
        fprintf(stderr,"Usage£º%s portnumber\a\n",argv[0]);
        exit(1);
    }

    if((portnumber = atoi(argv[1]))<0)
    {
        fprintf(stderr,"Usage£º%s portnumber\a\n",argv[0]);
        exit(1);
    }
    /** serial**********************/

    if((serial_fd=open_port(serial_fd,1))<0)
    {
        perror("open_port error");
        //return;
    }
    if((i=set_opt(serial_fd,115200,8,'N',1))<0)
    {
        perror("set_opt error");
        //return;
    }
    printf("serial_fd=%d\n",serial_fd);

    /*******************************/

    if((listenfd = socket(PF_INET, SOCK_STREAM, 0)) == -1)
    {
        fprintf(stderr, "Socket error: %s\a\n", strerror(errno));
        exit(1);
    }


    memset(&server_addr, 0, sizeof server_addr);
    server_addr.sin_family = AF_INET;
    server_addr.sin_addr.s_addr = htonl(INADDR_ANY);
    server_addr.sin_port = htons(portnumber);


    if((bind(listenfd, (struct sockaddr *)(&server_addr), sizeof server_addr)) == -1)
    {
        fprintf(stderr, "Bind error: %s\a\n", strerror(errno));
        exit(1);
    }

    if(listen(listenfd, 128) == -1)
    {
        fprintf(stderr, "Listen error: %s\a\n", strerror(errno));
        exit(1);
    }

    for(i=0;i<FD_SETSIZE;i++)
	{
		client[i].fd = -1;
	}

	FD_ZERO(&allset);
    FD_SET(listenfd, &allset);

	maxfd = listenfd;

    printf("waiting for the client's request...\n");

    while (1)
	{
		rset = allset;

		tv.tv_sec = 1;      //wait 1 second
        tv.tv_usec = 0;

        ret = select(maxfd + 1, &rset, NULL, NULL, &tv);

		if(ret == 0)
			continue;
		else if(ret < 0)
		{
			printf("select failed!");
			break;
		}
		else
		{
			if(FD_ISSET(listenfd,&rset)) // new connection
			{
				len = sizeof (struct sockaddr_in);
				if((connectfd = accept(listenfd,(struct sockaddr*)(&client_addr),&len)) == -1)
				{
					printf("accept() error");
					continue;
                }

				for(i=0;i<FD_SETSIZE;i++)
				{
					if(client[i].fd < 0)
					{
						client[i].fd = connectfd;
						client[i].addr = client_addr;
						printf("Yout got a connection from %s\n",inet_ntoa(client[i].addr.sin_addr));
						break;
					}
				}

				if(i == FD_SETSIZE)
					printf("Overfly connections");

				FD_SET(connectfd,&allset);

				if(connectfd > maxfd)
					maxfd = connectfd;

				if(i > maxi)
					maxi = i;
			}
			else
			{
				for(i=0;i<=maxi;i++)
				{
					if((sockfd = client[i].fd)<0)
						continue;

                    if(FD_ISSET(sockfd,&rset))
					{
						bzero(buf,BUFSIZE + 1);
						if((z = recv(sockfd,buf,BUFSIZE,0)) > 0)
						{
                            buf[z] = '\0';
                            //printf("received data:%sfrom %s",buf,inet_ntoa(client[i].addr.sin_addr));

                            if((nread=write(serial_fd,buf,strlen(buf)))>0)
                            {
                                buf[nread]='\0';
                                printf("nread=%d,Receievd Data:%s\n",nread,buf);
                            }
                            if(z < 0)
                                printf("write() ERROR");
                        }
						else
						{
						    printf("disconnected by client!");
							close(sockfd);
							FD_CLR(sockfd,&allset);
							client[i].fd = -1;
						}
					}
				}
			}
		}
	}
	close(listenfd);
	return 0;
}

 

共5条 1/1 1   
快速回复主题
  • 匿名不能发帖!请先 [ 登陆 注册 ]