移植sqlite到OK6410开发板上

前端之家收集整理的这篇文章主要介绍了移植sqlite到OK6410开发板上前端之家小编觉得挺不错的,现在分享给大家,也给大家做个参考。

1 下载 sqlite3源码

sqlite3 地址:http://www.sqlite.org/download.html.我用的版本是sqlite-autoconf-3071300.tar.gz

2 解压源码包

我的文件是放在自己创建的forlinx/root下,再进行解压。

@H_502_24@@H_502_24@tar zxvfsqlite-autoconf-3071300.tar.gz

3、配置编译选项

@H_502_24@
@H_502_24@前提:你的系统下已安装4.2.2的编译器,我试过4.3.2的去编译,会有问题
@H_502_24@@H_502_24@cd /forlinx/root/@H_502_24@sqlite-autoconf-3071300@H_502_24@@H_502_24@ //打开解压后的文件
@H_502_24@@H_502_24@
@H_502_24@@H_502_24@@H_502_24@./configure@H_502_24@--prefix=/forlinx/root/sqlite3 --host=arm-linux CC=/usr/local/arm/4.2.2-eabi/usr/bin/arm-linux-gcc

@H_502_24@@H_502_24@配置参数--prefix@H_502_24@=/forlinx/root/sqlite3@H_502_24@指明编译后文件的安装路径

@H_502_24@@H_502_24@配置参数@H_502_24@--host=arm-linux指明运行的系统平台

@H_502_24@@H_502_24@配置参数@H_502_24@CC=/usr/local/arm/4.2.2-eabi/usr/bin/arm-linux-gcc指明交叉编译器的路径

@H_502_24@其中,

@H_502_24@-@H_502_24@--host:指定交叉编译工具,一般为arm-none-linux-gnueabi、arm-linux-gnueabihf、arm-linux等,具体要和目标板用的交叉编译工具对应。
@H_502_24@-@H_502_24@--prefix:指定安装目录,编译后的文件会全部放在安装目录中。注意:必须是@R_301_331@!

4 编译

@H_502_24@
@H_502_24@make
make install
@H_502_24@运行sqlite3,看Ubuntu下能否正常运行,以下为正常运行情况,@H_502_24@Ubuntu下能正常运行再去做移植,否则移植可能会出问题。
注:我在Ubuntu下安装完后就除了问题,问题如下:
@H_502_24@error while loading shared libraries: libsqlite3.so.0: cannot open shared object file: No such file or directory //这个问题可能是我一开始没装好才导致的
@H_502_24@这个问题折磨了我两个晚上,最后终于在网上找到解决方法
@H_502_24@运行:ldconfig //重建/etc/ld.so.cache
再次运行:sqlite3,结果成功了,自己都被感动的要哭了
接下来就是和移植有关系的部分了
@H_502_24@

5 去除调试信息

 
  
@H_502_24@cd /sqlite3 //编译后产生的文件
@H_502_24@@H_502_24@bin@H_502_24@目录下是可执行文件@H_502_24@sqlite3

@H_502_24@@H_502_24@@H_502_24@include目录下是头文件@H_502_24@sqlite3.h sqlite3ext.h

@H_502_24@@H_502_24@@H_502_24@lib目录下是编译生成的库文件包括静态库和共享库。

@H_502_24@@H_502_24@@H_502_24@share目录下是帮助文档@H_502_24@man

@H_502_24@@H_502_24@/usr/local/arm/4.2.2-eabi/usr/bin/arm-linux-strip sqlite3@H_502_24@@H_502_24@ //@H_502_24@arm-linux-strip@H_502_24@用于剥离调试信息,使文件变小
@H_502_24@
@H_502_24@

6 移植到开发板

通过sftp、nfs或者U盘等方式,将 sqlite3 复制到目标板 /usr/bin 目录,将动态库文件libsqlite3.so.0.8.6 复制到目标板 /usr/lib 目录,并对动态库做链接

 
  
cp sqlite3 /usr/bin //将整个sqlite3移植到板上的/usr/bin下 cp libsqlite3.so.@H_502_24@0.@H_502_24@8.6 /usr/lib //将/@H_502_24@sqlite3/lib下的@H_502_24@libsqlite3.so.@H_502_24@0@H_502_24@.@H_502_24@8.6移植到板上的
/usr/lib下
以上操作可以用也可以用U盘或SD卡 @H_502_24@cd /usr/lib //打开板上的@H_502_24@/usr/lib@H_502_24@ ln -s libsqlite3.so.@H_502_24@0@H_502_24@.@H_502_24@8.6@H_502_24@ libsqlite3.so.@H_502_24@0@H_502_24@ ln -s libsqlite3.so.@H_502_24@0@H_502_24@.@H_502_24@8.6@H_502_24@ libsqlite3.so
@H_502_24@这里要注意的是@H_502_24@libsqlite3.so.@H_502_24@0和@H_502_24@libsqlite3.so不需要我们从sqlite3移植过来,它是自动生成链接,而上面的目的就是@H_502_24@创建共享库的软链接

7 运行测试sqlite3

在开发板上执行 sqlite3 命令,看到如下信息说明 sqlite3 移植成功!、

当然最后我还是遇到了问题:当我输入sqlite3出现了以下的错误
sqlite3: error while loading shared libraries: libncurses.so.5: cannot open shared object file: No such file or directory
解决办法:下载libncurses.so.5,然后拷贝到/usr/lib下
最后再运行sqlite3
最后想说一句:尼玛,总算成功了

猜你在找的Sqlite相关文章