CWMP开源代码研究7——cwmp移植

Posted 京月飞鸿

tags:

篇首语:本文由小常识网(cha138.com)小编为大家整理,主要介绍了CWMP开源代码研究7——cwmp移植相关的知识,希望对你有一定的参考价值。

原创作品,转载请注明出处,严禁非法转载。如有错误,请留言!

email:40879506@qq.com         

淘宝店:https://shop484606081.taobao.com

声明:本系列涉及的开源程序代码学习和研究,严禁用于商业目的。 如有任何问题,欢迎和我交流。(企鹅号:408797506)

本篇用到的文件包下载路径:http://download.csdn.net/detail/eryunyong/9735149

一. 环境
1.GNU/Linux Centos6.5操作系统
2.gcc
二. 依赖包的安装
1. expat-2.1.0
1)下载安装包expat-2.1.0.tar.gz ,路径http://www.libexpat.org/
2)解压
  tar -xvf expat-2.1.0.tar.gz
3)进入目录
  cd expat-2.1.0;mkdir tmp
4) 配置安装路径到tmp
  ./configure  --prefix=$PWD/tmp(如果是本地linux系统,只需要./configure)
5) 安装
  make;make install
6)拷贝tmp目录下相应的文件到需要的位置(暂跳过

2. openssl-1.0.2(暂时跳过)
因为curl的安装包依赖于openssl以及在CWMP中要用到SSL证书的HTTPS安全方式,所以提前先安装上openssl
1)下载安装包openssl-1.0.2.tar.gz,路径http://distfiles.macports.org/openssl/
2)解压
  tar -xvf openssl-1.0.2.tar.gz
3) 进入目录
  cd openssl-1.0.2;mkdir tmp;mkdir tmp/openssl
4) 配置安装路径和配置文件路径
  ./config shared --prefix=$PWD/tmp --openssldir=$PWD/tmp/openssl(如果是本地linux系统,只需要./config shared)
5)安装
  make;make install
6) 拷贝tmp目录下相应的文件到需要的位置(暂跳过

3.curl-7.21.4
1)下载安装包curl-7.21.4.tar.gz,路径: http://pkgs.fedoraproject.org/repo/pkgs/curl/
2) 解压
  tar -xvf curl-7.21.4.tar.gz
3) 进入目录
  cd curl-7.21.4;mkdir tmp
4) 配置安装路径和SSL选项(SSL支持放到以后的高级部分专门介绍)
  ./configure --without-ssl  --prefix=$PWD/tmp
5) 安装
  make;make install
6) 拷贝tmp目录下相应的文件到需要的位置(暂跳过
至此,CWMP core依赖的安装包已经完成了。


三. 安装cwmp
因为CWMP core不开源,这里提供X86 Centos6.5平台下编译好的安装程序。如果有不同环境的读者需要此程序,可以留言。
把编译出来的可执行文件cwmp拷贝到电脑或者设备的可行性路径下即可。

四. libcwmp库安装
这里涉及到对数据的存储和操作,我们知道openwrt引入了UCI,是一套配置参数管理系统。所以我们首先需要了解UCI的基本操作和知识,这里不做介绍了,此外也可以通过轻量级嵌入式数据库sqlite来管理数据。
1. UCI安装
  为了便于后续的开发,这里移植了在曾经的产品中开发过的luci,主要变化是在/usr/config/下面多出了一份动态存储参数,而在/etc/config/目录下的配置是默认参数配置。即,当uci程序获取某配置参数信息的时候,首先会从/usr/config/目录加载配置,如果读到则返回。若读取不到,再从/etc/config/目录加载配置。
1)下载安装包uci-0.4.0.tar.gz,路径http://distfiles.macports.org/openssl/
2)解压
  tar -xvf uci-0.4.0.tar.gz
3) 进入目录
  cd uci-0.4.0;mkdir tmp
4) 编译
   make
5) 安装 (暂跳过)
   将产生的*.h *.so 拷贝到需要的位置
Note: 也可以手动修改源码目录下Makefile的install规则,然后make install。
2)libcwmp安装
   提供源码,可以自由开发。将编译出来后的so放到/usr/lib目录下即可。(需要源码可留言邮箱地址)

五. 下载安装包

下载路径:http://download.csdn.net/detail/eryunyong/9735149

基于上述操作,我把依赖包的依赖程序(动态库和头文件)和测试数据的配置放到了一个打包文件里,并写了相应的脚本文件。下面是使用说明,可供参考。
脚本的使用说明:
如果你和我一样,新装了X86平台下的Centos6.5系统,只需要解压安装包并执行make命令即可完成cwmp的core安装和所有依赖包程序需要的文件。
如何环境不一样,比如使用Ubuntu或者Fedora等系统,直接执行我在Centos6.5环境编译出来的程序会遇到很多错误,有的是共享库出错,有的是软件版本不一致(比如Glibc)等(参考第七节)。
所以,除了CWMP core没有源码之外,其他所有程序建议重新编译,并且把编译后产生的程序或者依赖文件(动态库和头文件)放到你的环境中。

下载安装包,解压后看到如下目录:

cwmp_dep_packet用到的上述依赖包。

etc和usr目录存放的是数据。

lib和include存储的是上述依赖包编译出来的头文件和动态库(暂时不需要静态库)。(现在明白为什么依赖包安装的时候最后一个步骤是"暂跳过"了吧,只需要把所有安装的程序拷贝到这里,并执行make就自动完成了cwmp的部署

bin是用到的可执行程序。

脚本install_dep.sh安装所用到的配置数据。(可单独操作)

脚本install_dep.sh.sh安装所用到的依赖文件。(可单独操作)

/lib/link.sh脚本是创建lib目录下用到的动态库so文件的软连接。(可单独操作)

Makefile主要是完成上面三个脚本的动作。

六. 测试

在测试之前,必须先配置好参数和环境。

acs url 和CPE 地址对应的文件位置,根据自己的环境进行修改。

执行命令:

命令和测试:
[root@localhost X86移植_CentOS]# make
[root@localhost X86移植_CentOS]# cwmp -F /etc/config/cwmp_global.conf

log默认输出到/tmp/log/cwmp1.log 文件,可使用命令tail -f /tmp/log/cwmp1.log 追踪查看。如果需要修改log存储路径,可以修改配置/etc/config/log1.conf文件里的路径。

Note:首次安装后/tmp/log目录会被创建,由于tmp目录下内容断电会丢失,所以每次重启系统需要手动创建/tmp/log目录。

七. 跨平台或操作系统遇到的问题

下面是将Ubuntu12.04操作系统的依赖包直接移植到Centos6.5移植过程中遇到的错误,而不是重新编译了一把依赖包和程序,仅供参考:

问题一:

cwmp: error while loading shared libraries: librtmp.so.0: cannot open shared object file: No such file or directory
原因:
[root@localhost X86移植]# grep "rtmp" . -R
Binary file ./lib/libcurl.so.4.2.0 matches
解决方法:
1)重新编译libcurl去掉rtmp协议支持,(2)或者在Centos系统上安装rtmp库,而安装rtmp协议需要openssl和zlib库的支持。
参考:http://blog.csdn.net/u014037733/article/details/22978887
这里用第一种方式,重新编译libcurl,去掉librtmp支持。选项--without-librtmp
即配置libcurl时使用命令:./configure --without-ssl  --prefix=$PWD/tmp --without-librtmp
最后把make出来的文件拷贝到需要的位置即可。

问题二:
root@localhost X86移植]# easycwmp -F /etc/config/cwmp_global.conf  
easycwmp: /lib/libc.so.6: version `GLIBC_2.15\' not found (required by easycwmp)
easycwmp: /lib/libldap_r-2.4.so.2: no version information available (required by /usr/lib/libcurl.so.4)
easycwmp: /lib/libc.so.6: version `GLIBC_2.15\' not found (required by /usr/lib/libcurl.so.4)
原因:glibc版本太低,升级即可。参考:http://blog.csdn.net/hnhuangyiyang/article/details/50392997

八. 移植到arm,mips等平台
  因为考虑大部分读者无法实践(没有开发板),所以X86平台的移植写的比较详细。参考上述步骤,应该很容易移植成功,至于其他平台的移植,未来根据读者的留言考虑是否再写一篇跨平台的移植。
  如需交叉编译,请提供交叉编译工具链,我会把编译后的cwmp core程序发给你。

以上是关于CWMP开源代码研究7——cwmp移植的主要内容,如果未能解决你的问题,请参考以下文章

CWMP开源代码研究5——CWMP程序设计思想

开源免费 TR069 协议 CPE 代理程序对比

TR069事件类型(EVENT CODE对应的含义)

TR069网管协议应用在Android系统开发的前言

TR-069_Amendment-4:附录G.穿越NAT网关的连接请求方式

TR069协议