温馨提示×

温馨提示×

您好,登录后才能下订单哦!

密码登录×
登录注册×
其他方式登录
点击 登录注册 即表示同意《亿速云用户服务条款》

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

发布时间:2020-08-22 04:09:17 来源:网络 阅读:893 作者:炉yu 栏目:编程语言

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

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

#include <sys/socket.h>
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有没有可替换的方案,如果没有的话,现阶段是以裁剪为主。删去不必要的功能。

向AI问一下细节

免责声明:本站发布的内容(图片、视频和文字)以原创、转载和分享为主,文章观点不代表本网站立场,如果涉及侵权请联系站长邮箱:is@yisu.com进行举报,并提供相关证据,一经查实,将立刻删除涉嫌侵权内容。

AI