MySQL数据库在ARM+Linux平台上的移植
最近需要在pxa270的嵌入式平台上应用数据库进行通信信息管理,客户要求使用MySQL数据库,接下任务后,在网上一查才知道MySQL 根本很
最近需要在pxa270的嵌入式平台上应用数据库进行通信信息管理,客户要求使用MySQL数据库,接下任务后,在网上一查才知道MySQL 根本很少用于嵌入式环境,而且支持的少数几种芯片中并没有arm的分发包!继续搜索有没有MySQL在arm平台移植的相关文章,几乎找不到相关资料.而自己在网上发了一些帖却没有收到一个回复,没办法,只能硬着头皮自己动手了.幸好经过一番”苦战”,今天终于克服了所有障碍,让MySQL在270板子上跑了起来!而且简单的测试也都收到了预期的效果,不过还要看客户的经一步测试了.
现在将MySQL 的arm+linux移植经验贴出来,希望对以后做相关方面工作的人有所帮助.
首先是要从网上获取MySQL的源码包,官方网址如下:
我用的是MySQL-5.0.22.tar.gz
采用的交叉编译器是适合于270板子的codesourcery这要根据具体的情况来进行修改.
以下分几个阶段来介绍:
一: configure
解开包以后得到文件夹MySQL-5.0.22我将其改名为MySQL-pc,进入目录后,首先要做configure 来生成交叉编译的Makefile文件,编译的时候一般configure是都能通过的但我用./configure --host=arm-none-linux-gnueabi来生成Makefile时却出现了多个错误,如下:
1) return type of sprintf : error: cannot run test program while cross compiling
检查configure脚本,发现脚本在检测到在做cross-compile时就提示以上错误并退出,说明至少是这个版本的MySQL并不支持交叉编译,但我用了最新的版本试了也还是有同样的错误,基本可以肯定MySQL还没有支持交叉编译的版本出现.但为了让编译继续,我在configure脚本中将多处这样的命令全都注释掉以让configure通过.
2) error: Your compiler cannot convert a longlong value to a float!
这个问题在较低版本的MySQL中是一个bug,但5.0的版本已经修复了这个问题,有可能是交叉编译器的问题,找不到解决的方法,这里我也将它注释屏蔽了.
3) error: No curses/termcap library found
缺少curses和termcap的库,反复安装了各种相关的软件包,还是解决不了这个问题,最后是在configure的参数里直接指定了安装的ncurses-5.6下的libncurses.a库根据我的路径参数设置如下:
--with-named-curses-libs=/home/huaming/MySQL/ncurses-arm-d501/lib/libncurses.a
(这里要注意的是ncurses的安装也要采用交叉编译的方式在pc上装好,否则后面做make的时候编译器会指出libncurses.a的格式不对)
经过反复尝试我最后使用的参数如下:
./configure --host=arm-none-linux-gnueabi --with-named-curses-libs=/home/huaming/MySQL/ncurses-arm-270/lib/libncurses.a --prefix=/home/huaming/MySQL/MySQL_arm_270 --without-debug --without-docs --without-man --without-bench --with-extra-charset=gbk,gb2312
,