hsy75的个人空间 https://blog.eetop.cn/vivilife [收藏] [复制] [分享] [RSS]

空间首页 动态 记录 日志 相册 主题 分享 留言板 个人资料

日志

[z]Qt交叉编译工具建立 中篇

已有 1597 次阅读| 2012-9-11 14:57 |个人分类:linux

  

Qt交叉编译工具建立 中篇

2011-06-23 18:04 佚名 互联网 我要评论(0) 字号:T | T
一键收藏,随时查看,分享好友!

本文介绍了Qt交叉编译工具建立,主要介绍了Qt/Embedded 的交叉编译,建立本机Qtopia 虚拟平台,其他内容想要了解请看本文指引。先来看本篇内容。

AD: 51CTO云计算架构师峰会 抢票进行中!

继续上面的内容继续讲 Qt交叉编译工具建立 上篇 ,主要介绍了Qt/Embedded 的交叉编译,建立本机Qtopia 虚拟平台这两个方面介绍的!

一、Qt/Embedded的交叉编译

要将我们写好的程序发布到开发板上,我们需要对Qt/Embedded 重新编译,与前面在宿主机上编译类似,步骤如下:

1. Build Qt/Embedded

  1. tar –xzvf qt-embedded-2.3.10-free.tar.gz
  2. mv qt-2.3.10
  3. qt-2.3.10-target
  4. export TMAKEDIR=$PWD/tmake-1.13
  5. export QT2DIR=$PWD/qt-2.3.2
  6. export QTEDIR=$PWD/qt-2.3.10-target
  7. cd $QTEDIR
  8. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-arm-g++
  9. export QTDIR=$QTEDIR
  10. export PATH=$QTDIR/bin:$PATH
  11. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
  12. make clean
  13. ./configure -xplatform. linux-arm-g++ -no-xft -no-qvfb -depths 4,8,16,32
  14. make

这步完成后,我们会在/$QTEDIR/lib/目录下面看到libqte.so libqte.so.2 libqte.so.2.3 libqte.so.2.3.10 这四个文件,我们可以使用file 命令来查看这个库文件是否是我们需要的在开发板上跑的库。

  1. file libqte.so.2.3.10
  2. libqte.so.2.3.10: ELF 32-bit LSB shared object, ARM, version 1 (ARM), stripped

有了这个库以后我们就可以把它拷贝到我们的开发板中相应的库目录下面,这里我们选择了开发板上的/usr/lib 目录,将/$QTEDIR/lib/下的libqte.so*复制到/usr/lib 目录下。

首先要建立宿主机和开发板的通讯,假设本机的ip 地址为192.168.0.56 并且/root/share 为共享文件夹。

  1. cp –arf /$QTEDIR/lib/libqte.so* /root/share
  2. 启动minicom
  3. mount –t nfs –o nolock 192.168.0.56:/root/share /mnt/nfs将文件复制到开发板上
  4. cp –arf /mnt/nfs/libqte.so* /usr/lib

2. 修改tmake 配置文件

  1. vi $ TMAKEDIR/lib/qws/linux-arm-g++/tmake.conf
  2. 将其中“TMAKE_LINK= arm-linux-gcc”
  3. TMAKE_LINK_SHLIB= arm-linux-gcc”
  4. 修改为:“TMAKE_LINK= arm-linux-g++”
  5. TMAKE_LINK_SHLIB= arm-linux-g++”

3.生成可执行文件

这里我们采用了Qt/Embedded自带的一个demo,它在/$QTEDIR/examples/progressbar目录下,这个目录包括下面几个文件: main.cpp、Makefile.in 、progressbar.h 、

Makefile、progressbar.cpp、progressbar.pro,如果已经有了progressbar 的执行文件,可以使用make clean删除。

  1. progen –t app.t –o progressbar.pro
  2. echo $TMAKEPATH

查看返回的结果的结尾字符是否是“……/qws/linux-arm-g++”,如果不是的话需要在命令行中重新设置TMAKEPATH

export TMAKEPATH=/tmake 的安装路径(如$TMAKEDIR)/lib/qws/linux-arm-g++

此外还要使QTDIR指向Qt/Embedded 的安装路径,如:

export QTDIR=$QTEDIR 或者直接指定路径

  1. export QTDIR=……/qt-2.3.10-target

完成了上面的环境变量的设置,并用echo 命令检查无误以后,就可以使用tmake 工具来生成我们需要的makefile 文件,在命令行中输入如下命令:

  1. tmake –o makefile progressbar.pro
  2. make

如果没出现错误的话就可以在当前目录下找到progressbar这个可执行文件,它就是在我们开发板上的相应目录中运行“./progressbar -qws”就可以运行程序了。

注: (1)如果执行命令

  1. [/mnt/nfs]./progressbar -qws
  2. ./progressbar: error while loading shared libraries: libstdc++.so.6: cannot open shared object file: No such file or direy

我的解决办法是从编译器目录下查找,并拷贝到开发板/usr/lib/中


即拷贝/usr/local/arm/3.4.1/arm-linux/lib/libstdc++.so* 到开发板/usr/lib/中

(2).[/mnt/nfs]./progressbar –qws

  1. /progressbar: error while loading shared libraries: libgcc_s.so.1: cannot open shared object file: No such fy

方法同上

二、建立本机Qtopia 虚拟平台

软件:Redhat Linux9.0 for PC + minicom + Embeded Linux for 2410

  1. tmake-1.13.tar.gz qtopia-free-source-2.1.1.tar.bz2 qt-embedded-2.3.10-free.tar.gz qt-x11-2.3.2.tar.gz

将本次实验所需的四个文件拷贝到/root/qtopia 目录下,我们以下的实验都是在这个目录下进行的。

宿主机上建立虚拟的Qtopia 环境需要以下几个步骤:

1. 解压缩安装文件:

  1. tar jxvf qtopia-free-source-2.1.1.tar.bz2
  2. mv qtopia-2.1.1 qtopia-2.1.1-target
  3. tar xzf tmake-1.13.tar.gz
  4. tar xzf qt-x11-2.3.2.tar.gz
  5. tar xzf qt-embedded-2.3.10-free.tar.gz
  6. mv qt-2.3.10 qt-2.3.10-target
  7. export QPEDIR=$PWD/qtopia-2.1.1-target
  8. export TMAKEDIR=$PWD/tmake-1.13
  9. export QT2DIR=$PWD/qt-2.3.2
  10. export QTEDIR=$PWD/qt-2.3.10-target

2. Build Qt/X11:

  1. cd $QT2DIR
  2. export TMAKEPATH=$TMAKEDIR/lib/linux-g++
  3. export QTDIR=$QT2DIR
  4. export PATH=$QTDIR/bin:$PATH
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
  6. ./configure -no-xft
  7. make
  8. mkdir $QTEDIR/bin
  9. cp bin/uic $QTEDIR/bin/

3. Build Qvfb:

  1. export TMAKEPATH=$TMAKEDIR/lib/linux-g++
  2. export QTDIR=$QT2DIR
  3. export PATH=$QTDIR/bin:$PATH:$TMAKEDIR/bin
  4. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
  5. cd $QTEDIR/tools/qvfb
  6. tmake -o Makefile qvfb.pro
  7. make
  8. mv qvfb $QTEDIR/bin/

4.Build libqte:

  1. cd $QTEDIR
  2. export TMAKEPATH=$TMAKEDIR/lib/qws/linux-x86-g++
  3. export QTDIR=$QTEDIR
  4. export PATH=$QTDIR/bin:$PATH
  5. export LD_LIBRARY_PATH=$QTDIR/lib:$LD_LIBRARY_PATH
  6. cp -f $QPEDIR/src/qt/qconfig-qpe.h src/tools/
  7. ./configure -system-jpeg -no-xft -qconfig qpe -qvfb -depths 4,8,16,32
  8. make sub-src

5.Build Qtopia:

  1. cd $QPEDIR
  2. export QTDIR=$QTEDIR
  3. export PATH=$QPEDIR/bin:$PATH
  4. export
  5. LD_LIBRARY_PATH=$QPEDIR/lib:$LD_LIBRARY_PATH
  6. ./configure
  7. make

和前面编译Qt/Embedded 的基本步骤一样,还可以参考“./configure --help”,来进行选择。为了保证qvfb 能够正确显示qtopia 的结果,我们必须保证环境变量设置正确,我们可以通过“env”命令来检查下面的环境变量,也可以用下面的方法来检查。

  1. echo $QPEDIR
  2. /root/qtopia/qtopia-free-2.1.1/
  3. echo $QTDIR
  4. /root/qtopia/qt-2.3.10
  5. echo $LD_LIBRARY_PATH
  6. /root/qtopia/qtopia-free-2.1.1/lib:/root/qtopia/qt-2.3.10/lib
  7. echo $PATH
  8. /root/qtopia/qt-2.3.10/bin:/usr/kerberos/sbin:/usr/kerberos/bin:/usr/local
  9. /sbin:/usr/local/bin:/sbin:/bin:/usr/sbin:/usr/bin:/usr/X11R6/bin:/root/bin

出现上面的结果就可以正常的显示Virtual framebuffer,我们可以通过下面的命令在Virtual framebuffer 中实现Qtopia。

  1. cd $QPEDIR/bin
  2. qvfb &
  3. sleep 10
  4. ./qpe.sh

小结:关于Qt交叉编译工具建立的内容介绍完了,想要深入了解的话,请继续关注 Qt交叉编译工具建立 下篇 ,最后希望本文对你有所帮助!

【编辑推荐】

 

ref:
【责任编

点赞

评论 (0 个评论)

facelist

您需要登录后才可以评论 登录 | 注册

  • 关注TA
  • 加好友
  • 联系TA
  • 0

    周排名
  • 0

    月排名
  • 0

    总排名
  • 0

    关注
  • 2

    粉丝
  • 1

    好友
  • 2

    获赞
  • 14

    评论
  • 3241

    访问数
关闭

站长推荐 上一条 /1 下一条

小黑屋| 关于我们| 联系我们| 在线咨询| 隐私声明| EETOP 创芯网
( 京ICP备:10050787号 京公网安备:11010502037710 )

GMT+8, 2024-4-26 02:59 , Processed in 0.015838 second(s), 7 queries , Gzip On, Redis On.

eetop公众号 创芯大讲堂 创芯人才网
返回顶部