网站建设资讯

NEWS

网站建设资讯

移植libnoPoll到SylixOS遇到的问题总结

1.概述
关于libnoPoll移植到SylixOS的移植过程及移植方法参考工程技术笔记《移植libnopoll到SylixOS技术笔记》。本篇文档旨在描述移植过程遇到的问题及解决问题的方法。

创新互联服务项目包括嘉鱼网站建设、嘉鱼网站制作、嘉鱼网页制作以及嘉鱼网络营销策划等。多年来,我们专注于互联网行业,利用自身积累的技术优势、行业经验、深度合作伙伴关系等,向广大中小型企业、政府机构等提供互联网行业的解决方案,嘉鱼网站推广取得了明显的社会效益与经济效益。目前,我们服务的客户以成都为中心已经辐射到嘉鱼省份的部分城市,未来相信会继续扩大服务区域并继续获得客户的支持与信任!

2、问题描述及解决方法
2.1 编译提示未定义选项
在完成libnoPoll库工程的创建后,在编译时提示“'SO_BINDTODEVICE'undeclared (first use in this function)”,经过查阅资料得知‘SO_BINDTODEVICE’是一个套接字选项,该选项用于将套接口绑定到指定的网络接口上。一般用于实现多网口负载均衡的方法。通常调用setsockopt接口对某个套接口进行套接字选项的设置。
在SylixOS中setsockopt函数原型如下所示。

#include 
int setsockopt(int s, int level, int optname, const void *optval, socklen_t optlen);

函数setsockopt原型分析:
此函数成功时返回0,失败时返回-1并设置错误号;
参数s是套接字(socket函数返回);
参数level是选项等级如下表 所示;
参数optname是选项名如下表所示;
参数optval是选项值;
参数optlen是选项长度。
通过调用setsockopt函数来设置不同选项等级的不同选项,参数optval是一个指向变量的指针类型,根据不同的选项,类型也不同。
移植libnoPoll到SylixOS遇到的问题总结
在libnoPoll中的调用如下所示。

setsockopt (socket, SOL_SOCKET, SO_BINDTODEVICE, options->_interface, strlen (options->_interface));  

对于'SO_BINDTODEVICE'套接字选项,在Linux的man手册中,有如下三点结论:

  • 对于TCP套接口、UDP套接口、RAW套接口,可以通过SO_BINDTODEVICE套接口选项将套接口绑定到指定的网络接口上。绑定之后,套接口的所有数据包收发都只经过指定的网络接口。
  • 对于PACKET类型的套接口,不能通过SO_BINDTODEVICE绑定到指定的网络接口上,而要通过bind接口来与特定的网络接口绑定,所用的套接口地址结构为struct sockaddr_ll,此套接口地址结构是链路层的地址结构,独立于具体的网络设备。比如,该地址结构既可以用于表示PPP设备,也能用于表示Ethernet设备。
  • SO_BINDTODEVICE套接口选项只适用于Linux系统。如果要编写运行在多操作系统平台上的程序,不能依赖SO_BINDTODEVICE来完成套接口与具体设备的绑定。
    通过阅读SylixOS的源码并由第三点结论可知,在SylixOS下并没有提供该套接字选项,在没有指定该套接字选项的情况下,每次在发送数据包之前,内核会先查找路由表从而决定从哪个网络接口上发送数据包。因此,为了能够保证工程能够正确编译,需要将该套接口选项剪裁掉。剪裁后的libnoPoll将不再具有实现多网口负载均衡的功能。

2.2 测试用例运行时出错
在libnoPoll的测试代码中会使用system函数来运行某些shell命令,但有些shell命令在SylixOS下并不支持或支持相同功能但shell命令名不同,因此,在测试代码运行过程中有可能会出错,遇到这种情况,可根据具体情况修改libnoPoll中提供的测试代码。
在RealEvo IDE的base工程中,默认会有libcextern(SylixOS C库)和libsylixos(SylixOS内核组件)这两个工程文件夹,在编译base工程后会生成C库文件和内核库文件。在测试用例运行失败后,通过跟踪源代码,发现在C库和内核库中都同时定义了getaddrinfo接口。默认情况下,在应用程序没有指定引用哪个库文件时,编译时会使用内核库中定义的函数。在工程属性中可以重新设置引用的库文件,通过将应用程序重新指定使用C库之后,重新编译应用程序,再次部署就能够正常运行。

2.3 总结
由于大多数移植的中间件是从Linux下的工程移植过来的,因此,对于SylixOS不支持的特性,通常做法是看SylixOS有没有可替换的方案,如果没有的话,现阶段是以裁剪为主。删去不必要的功能。


分享标题:移植libnoPoll到SylixOS遇到的问题总结
分享路径:http://cdweb.net/article/iicjee.html