bbblack的网络socket通信实验

1. 本次用bbblack作网络的通信实验,对了,这个板子必须装SD卡才能启动吗?板载的4GB eMMC Flash 存储器,eMMC (Embedded Multi Media Card) 为MMC协会所订立的,eMMC 相当于 NandFlash+主控IC,对外的接口协议与SD、TF卡一样,主要是针对手机或平板电脑等产品的内嵌式存储器标准规格。eMMC的一个明显优势是在封装中集成了一个控制器,它提供标准接口并管理闪存,使得手机厂商就能专注于产品开发的其它部分,看下原理图,果然是SD卡的接口,不过是8位数据线。

bbblack的网络socket通信实验

2. 看下数据手册里面的,有3个MMC接口,EMMC是MMC1的接口,板子上的SD卡接的是MMC0

bbblack的网络socket通信实验

3. 言归正传测试下socket的通信。先看下原理图,使用的是LAN8710

bbblack的网络socket通信实验

4. 搞个程序测试一下,一个问题,这些头文件的包含是怎么设置的?sys的文件夹是那个?恕我懵逼,去linux内核里面都不知道在哪里?如果是和内核相关的程序,比如驱动程序,那么所包含的头文件是在内核源码的安装目录下,即/usr/src/kernel/include,这时一般要在Makefile文件中指定内核源码目录,在编译时指定INCLUDE目录,那我这次编译这个文件,需要写一个makefile的吧,应用层的代码,按照以前驱动LED的方式。应该不可以在开发板上直接编译的吧,是在电脑上用交叉编译环境编译的才对,生成.o文件,传给开发板,为啥LED的文档,直接放板子上编译?不敢相信。

如果是应用程序,并且使用GCC进行普通编译,如果编译时没有使用-I选项指定包含目录的话,那么默认的头文件目录在/usr/include(电脑ubuntu的路径)下,刚才去ubuntu电脑看了一下,果然是有代码,我以前以为所有这些头文件都是开发板上的kernel内核里面的,也就是说编译的时候也会用到电脑ubuntu的头文件。

那么这个sys/socket.h头文件在什么地方?是电脑ubuntu里面的,还是开发板的内核源码里面的?位置在哪里?不会是在交叉编译器的路径里面吧。我只是不觉的交叉编译器会这么强大,连socket.h这种头文件都包含了?理论上这些不是应该用内核里面的吗?

如果是应用程序,采用交叉编译】,编译时没有使用-I选项指定包含目录的话,那么默认的头文件搜索路径为/usr/local/arm/2.95.3/arm-linux/include,即交叉编译器的安装目录下的include目录。

#include<stdio.h>
#include<string.h>
#include<strings.h>
#include <ctype.h>
#include <unistd.h>
#include <stdlib.h>
#include <time.h>
#include <sys/socket.h>
#include <arpa/inet.h>
#include <netinet/in.h>
#include <sys/types.h>
#include <sys/time.h>
#include <fcntl.h>
#include <sys/stat.h>
#define SERVER_IP "192.168.1.106"
#define SERVER_PORT 10010
#define MY_IP "192.168.1.106"
#define MY_PORT 10010
#define FILE_NAME "/dev/ttyO0"
#define MAX_LEN 128
int main(void)
{
    int serial_buffer[MAX_LEN] = {0};
    char data2send[4096] = {0};
    int numbers2send = 0;
    int i = 0;
    int serial_fd = open(FILE_NAME, O_RDWR);
    if(serial_fd < 0)
    {
        printf("Serial port open error.\n");
        return -1;
    }
    int socket_fd = socket(AF_INET, SOCK_STREAM, 0);
    if(socket_fd < 0)
    {
        perror("socket_fd");
        return -1;
    }
    printf("Ready to connect the server...\n");
    struct sockaddr_in server_addr = {0};
    server_addr.sin_family = AF_INET;
    server_addr.sin_port = htons(SERVER_PORT);
    server_addr.sin_addr.s_addr = inet_addr(SERVER_IP);
    int ret = connect(socket_fd, (struct sockaddr *)&server_addr, sizeof(server_addr));
    if(ret < 0)
    {
        perror("connect");
        return -1;
    }
    printf("connect success.\n");
    while(1)
    {
      for(i=0; i<MAX_LEN; i++)
      {
        serial_buffer[i] = 0;
      }
      read(serial_fd, serial_buffer, MAX_LEN);
      printf("[%s].\n", serial_buffer);
      send(socket_fd, serial_buffer, MAX_LEN, 0);
    }
    close(serial_fd);
    close(socket_fd);
    return 0;
}

5. 安装个交叉编译器看下里面有啥

相关推荐